2014-05-06 23:14:10 -07:00
|
|
|
"use strict";
|
|
|
|
|
2014-07-10 08:39:09 -07:00
|
|
|
var bignum = require('bignum');
|
|
|
|
var CPPKey = require('bindings')('KeyModule').Key;
|
2014-05-06 23:14:10 -07:00
|
|
|
var assert = require('assert');
|
2014-07-10 18:14:13 -07:00
|
|
|
var Point = require('./common/Point');
|
2014-05-06 23:14:10 -07:00
|
|
|
|
|
|
|
Point.add = function(p1, p2) {
|
|
|
|
var u1 = p1.toUncompressedPubKey();
|
|
|
|
var u2 = p2.toUncompressedPubKey();
|
|
|
|
var pubKey = CPPKey.addUncompressed(u1, u2);
|
|
|
|
return Point.fromUncompressedPubKey(pubKey);
|
|
|
|
};
|
|
|
|
|
2014-05-06 22:08:10 -07:00
|
|
|
Point.multiply = function(p1, x) {
|
2014-07-11 11:52:05 -07:00
|
|
|
if (Buffer.isBuffer(x) && x.length !== 32)
|
|
|
|
throw new Error('if x is a buffer, it must be 32 bytes')
|
2014-05-06 22:08:10 -07:00
|
|
|
var u1 = p1.toUncompressedPubKey();
|
2014-07-11 11:52:05 -07:00
|
|
|
if (typeof x === 'number' || typeof x === 'string')
|
|
|
|
x = (new bignum(x)).toBuffer({size: 32});
|
2014-05-07 17:10:07 -07:00
|
|
|
var pubKey = CPPKey.multiplyUncompressed(u1, x);
|
2014-05-06 22:08:10 -07:00
|
|
|
return Point.fromUncompressedPubKey(pubKey);
|
|
|
|
};
|
|
|
|
|
2014-07-12 03:14:56 -07:00
|
|
|
module.exports = Point;
|