|
@ -2,14 +2,13 @@ |
|
|
|
|
|
|
|
|
var should = require('chai').should(); |
|
|
var should = require('chai').should(); |
|
|
var bitcore = require('../..'); |
|
|
var bitcore = require('../..'); |
|
|
var ECDSA = bitcore.ECDSA; |
|
|
var ECDSA = bitcore.crypto.ECDSA; |
|
|
var Hash = bitcore.Hash; |
|
|
var Hash = bitcore.crypto.Hash; |
|
|
var Keypair = bitcore.Keypair; |
|
|
|
|
|
var PrivateKey = bitcore.PrivateKey; |
|
|
var PrivateKey = bitcore.PrivateKey; |
|
|
var PublicKey = bitcore.PublicKey; |
|
|
var PublicKey = bitcore.PublicKey; |
|
|
var Signature = bitcore.Signature; |
|
|
var Signature = bitcore.Signature; |
|
|
var BN = bitcore.BN; |
|
|
var BN = bitcore.crypto.BN; |
|
|
var point = bitcore.Point; |
|
|
var point = bitcore.crypto.Point; |
|
|
|
|
|
|
|
|
describe('ECDSA', function() { |
|
|
describe('ECDSA', function() { |
|
|
|
|
|
|
|
@ -20,12 +19,8 @@ describe('ECDSA', function() { |
|
|
|
|
|
|
|
|
var ecdsa = new ECDSA(); |
|
|
var ecdsa = new ECDSA(); |
|
|
ecdsa.hashbuf = Hash.sha256(new Buffer('test data')); |
|
|
ecdsa.hashbuf = Hash.sha256(new Buffer('test data')); |
|
|
ecdsa.keypair = new Keypair(); |
|
|
ecdsa.privkey = new PrivateKey(BN().fromBuffer(new Buffer('fee0a1f7afebf9d2a5a80c0c98a31c709681cce195cbcd06342b517970c0be1e', 'hex'))); |
|
|
ecdsa.keypair.privkey = new PrivateKey({bn: BN().fromBuffer(new Buffer('fee0a1f7afebf9d2a5a80c0c98a31c709681cce195cbcd06342b517970c0be1e', 'hex'))}); |
|
|
ecdsa.privkey2pubkey(); |
|
|
ecdsa.keypair.pubkey = new PublicKey({ |
|
|
|
|
|
point: point(BN().fromBuffer(new Buffer('ac242d242d23be966085a2b2b893d989f824e06c9ad0395a8a52f055ba39abb2', 'hex')), |
|
|
|
|
|
BN().fromBuffer(new Buffer('4836ab292c105a711ed10fcfd30999c31ff7c02456147747e03e739ad527c380', 'hex'))) |
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
describe('#set', function() { |
|
|
describe('#set', function() { |
|
|
|
|
|
|
|
@ -49,13 +44,10 @@ describe('ECDSA', function() { |
|
|
var r = BN('71706645040721865894779025947914615666559616020894583599959600180037551395766', 10); |
|
|
var r = BN('71706645040721865894779025947914615666559616020894583599959600180037551395766', 10); |
|
|
var s = BN('109412465507152403114191008482955798903072313614214706891149785278625167723646', 10); |
|
|
var s = BN('109412465507152403114191008482955798903072313614214706891149785278625167723646', 10); |
|
|
var ecdsa = new ECDSA(); |
|
|
var ecdsa = new ECDSA(); |
|
|
ecdsa.keypair = new Keypair(); |
|
|
ecdsa.privkey = PrivateKey(BN().fromBuffer(Hash.sha256(new Buffer('test')))); |
|
|
ecdsa.keypair.privkey = PrivateKey(); |
|
|
ecdsa.privkey2pubkey(); |
|
|
ecdsa.keypair.privkey.bn = BN().fromBuffer(Hash.sha256(new Buffer('test'))); |
|
|
|
|
|
ecdsa.keypair.privkey2pubkey(); |
|
|
|
|
|
ecdsa.hashbuf = hashbuf; |
|
|
ecdsa.hashbuf = hashbuf; |
|
|
ecdsa.sig = new Signature({r: r, s: s}); |
|
|
ecdsa.sig = new Signature({r: r, s: s}); |
|
|
|
|
|
|
|
|
ecdsa.calci(); |
|
|
ecdsa.calci(); |
|
|
ecdsa.sig.i.should.equal(1); |
|
|
ecdsa.sig.i.should.equal(1); |
|
|
}); |
|
|
}); |
|
@ -69,7 +61,8 @@ describe('ECDSA', function() { |
|
|
var ecdsa2 = new ECDSA(); |
|
|
var ecdsa2 = new ECDSA(); |
|
|
ecdsa2.fromString(str); |
|
|
ecdsa2.fromString(str); |
|
|
should.exist(ecdsa.hashbuf); |
|
|
should.exist(ecdsa.hashbuf); |
|
|
should.exist(ecdsa.keypair); |
|
|
should.exist(ecdsa.pubkey); |
|
|
|
|
|
should.exist(ecdsa.privkey); |
|
|
}); |
|
|
}); |
|
|
|
|
|
|
|
|
}); |
|
|
}); |
|
@ -100,7 +93,7 @@ describe('ECDSA', function() { |
|
|
ecdsa.sign(); |
|
|
ecdsa.sign(); |
|
|
ecdsa.sig.i = 1; |
|
|
ecdsa.sig.i = 1; |
|
|
var pubkey = ecdsa.sig2pubkey(); |
|
|
var pubkey = ecdsa.sig2pubkey(); |
|
|
pubkey.point.eq(ecdsa.keypair.pubkey.point).should.equal(true); |
|
|
pubkey.point.eq(ecdsa.pubkey.point).should.equal(true); |
|
|
}); |
|
|
}); |
|
|
|
|
|
|
|
|
}); |
|
|
}); |
|
@ -123,8 +116,7 @@ describe('ECDSA', function() { |
|
|
ecdsa.hashbuf = Hash.sha256(new Buffer('test')); |
|
|
ecdsa.hashbuf = Hash.sha256(new Buffer('test')); |
|
|
var pk = new PublicKey(); |
|
|
var pk = new PublicKey(); |
|
|
pk.fromDER(new Buffer('041ff0fe0f7b15ffaa85ff9f4744d539139c252a49710fb053bb9f2b933173ff9a7baad41d04514751e6851f5304fd243751703bed21b914f6be218c0fa354a341', 'hex')); |
|
|
pk.fromDER(new Buffer('041ff0fe0f7b15ffaa85ff9f4744d539139c252a49710fb053bb9f2b933173ff9a7baad41d04514751e6851f5304fd243751703bed21b914f6be218c0fa354a341', 'hex')); |
|
|
ecdsa.keypair = new Keypair(); |
|
|
ecdsa.pubkey = pk; |
|
|
ecdsa.keypair.pubkey = pk; |
|
|
|
|
|
ecdsa.sig = new Signature(); |
|
|
ecdsa.sig = new Signature(); |
|
|
ecdsa.sig.r = BN(0); |
|
|
ecdsa.sig.r = BN(0); |
|
|
ecdsa.sig.s = BN(0); |
|
|
ecdsa.sig.s = BN(0); |
|
@ -151,7 +143,8 @@ describe('ECDSA', function() { |
|
|
it('should should throw an error if hashbuf is not 32 bytes', function() { |
|
|
it('should should throw an error if hashbuf is not 32 bytes', function() { |
|
|
var ecdsa2 = ECDSA().set({ |
|
|
var ecdsa2 = ECDSA().set({ |
|
|
hashbuf: ecdsa.hashbuf.slice(0, 31), |
|
|
hashbuf: ecdsa.hashbuf.slice(0, 31), |
|
|
keypair: ecdsa.keypair |
|
|
pubkey: ecdsa.pubkey, |
|
|
|
|
|
privkey: ecdsa.privkey |
|
|
}); |
|
|
}); |
|
|
ecdsa2.randomK(); |
|
|
ecdsa2.randomK(); |
|
|
(function() { |
|
|
(function() { |
|
@ -197,7 +190,7 @@ describe('ECDSA', function() { |
|
|
describe('@sign', function() { |
|
|
describe('@sign', function() { |
|
|
|
|
|
|
|
|
it('should produce a signature', function() { |
|
|
it('should produce a signature', function() { |
|
|
var sig = ECDSA.sign(ecdsa.hashbuf, ecdsa.keypair); |
|
|
var sig = ECDSA.sign(ecdsa.hashbuf, ecdsa.privkey); |
|
|
(sig instanceof Signature).should.equal(true); |
|
|
(sig instanceof Signature).should.equal(true); |
|
|
}); |
|
|
}); |
|
|
|
|
|
|
|
@ -206,10 +199,10 @@ describe('ECDSA', function() { |
|
|
describe('@verify', function() { |
|
|
describe('@verify', function() { |
|
|
|
|
|
|
|
|
it('should verify a valid signature, and unverify an invalid signature', function() { |
|
|
it('should verify a valid signature, and unverify an invalid signature', function() { |
|
|
var sig = ECDSA.sign(ecdsa.hashbuf, ecdsa.keypair); |
|
|
var sig = ECDSA.sign(ecdsa.hashbuf, ecdsa.privkey); |
|
|
ECDSA.verify(ecdsa.hashbuf, sig, ecdsa.keypair.pubkey).should.equal(true); |
|
|
ECDSA.verify(ecdsa.hashbuf, sig, ecdsa.pubkey).should.equal(true); |
|
|
var fakesig = Signature(sig.r.add(1), sig.s); |
|
|
var fakesig = Signature(sig.r.add(1), sig.s); |
|
|
ECDSA.verify(ecdsa.hashbuf, fakesig, ecdsa.keypair.pubkey).should.equal(false); |
|
|
ECDSA.verify(ecdsa.hashbuf, fakesig, ecdsa.pubkey).should.equal(false); |
|
|
}); |
|
|
}); |
|
|
|
|
|
|
|
|
}); |
|
|
}); |
|
|