HEX
Server: Apache/2.4.41 (Ubuntu)
System: Linux ip-172-31-42-149 5.15.0-1084-aws #91~20.04.1-Ubuntu SMP Fri May 2 07:00:04 UTC 2025 aarch64
User: ubuntu (1000)
PHP: 7.4.33
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /var/www/vhost/disk-apps/alq-cali.bikenow.co/node_modules/crypto-browserify/test/ecdh.js
'use strict';

var mods = [
	'secp256k1',
	'secp224r1',
	'prime256v1',
	'prime192v1'
];
var test = require('tape');
var createECDH1 = require('../').createECDH;
var createECDH2 = require('create-ecdh/browser');

mods.forEach(function (mod) {
	test('createECDH: ' + mod + ' uncompressed', function (t) {
		t.plan(2);
		var dh1 = createECDH1(mod);
		dh1.generateKeys();
		var dh2 = createECDH2(mod);
		dh2.generateKeys();
		var pubk1 = dh1.getPublicKey();
		var pubk2 = dh2.getPublicKey();
		t.notEquals(pubk1.toString('hex'), pubk2.toString('hex'), 'diff public keys');
		var pub1 = dh1.computeSecret(pubk2).toString('hex');
		var pub2 = dh2.computeSecret(pubk1).toString('hex');
		t.equals(pub1, pub2, 'equal secrets');
	});

	test('createECDH: ' + mod + ' compressed', function (t) {
		t.plan(2);
		var dh1 = createECDH1(mod);
		dh1.generateKeys();
		var dh2 = createECDH2(mod);
		dh2.generateKeys();
		var pubk1 = dh1.getPublicKey(null, 'compressed');
		var pubk2 = dh2.getPublicKey(null, 'compressed');
		t.notEquals(pubk1.toString('hex'), pubk2.toString('hex'), 'diff public keys');
		var pub1 = dh1.computeSecret(pubk2).toString('hex');
		var pub2 = dh2.computeSecret(pubk1).toString('hex');
		t.equals(pub1, pub2, 'equal secrets');
	});

	test('createECDH: ' + mod + ' set stuff', function (t) {
		t.plan(5);
		var dh1 = createECDH1(mod);
		var dh2 = createECDH2(mod);
		dh1.generateKeys();
		dh2.generateKeys();
		dh1.setPrivateKey(dh2.getPrivateKey());
		dh1.setPublicKey(dh2.getPublicKey());
		var priv1 = dh1.getPrivateKey('hex');
		var priv2 = dh2.getPrivateKey('hex');
		t.equals(priv1, priv2, 'same private key');
		var pubk1 = dh1.getPublicKey();
		var pubk2 = dh2.getPublicKey();
		t.equals(pubk1.toString('hex'), pubk2.toString('hex'), 'same public keys, uncompressed');
		t.equals(dh1.getPublicKey('hex', 'compressed'), dh2.getPublicKey('hex', 'compressed'), 'same public keys compressed');
		t.equals(dh1.getPublicKey('hex', 'hybrid'), dh2.getPublicKey('hex', 'hybrid'), 'same public keys hybrid');
		var pub1 = dh1.computeSecret(pubk2).toString('hex');
		var pub2 = dh2.computeSecret(pubk1).toString('hex');
		t.equals(pub1, pub2, 'equal secrets');
	});
});