2014-09-12 17:24:00 -07:00
|
|
|
var Keypair = require('../lib/keypair');
|
2014-09-10 14:00:53 -07:00
|
|
|
var StealthMessage = require('../lib/expmt/stealthmessage');
|
|
|
|
var Stealthkey = require('../lib/expmt/stealthkey');
|
|
|
|
var StealthAddress = require('../lib/expmt/stealthAddress');
|
|
|
|
var KDF = require('../lib/kdf');
|
|
|
|
var Hash = require('../lib/hash');
|
|
|
|
var should = require('chai').should();
|
|
|
|
var Address = require('../lib/address');
|
|
|
|
|
|
|
|
describe('StealthMessage', function() {
|
|
|
|
|
|
|
|
var payloadKeypair = KDF.buf2keypair(new Buffer('key1'));
|
|
|
|
var scanKeypair = KDF.buf2keypair(new Buffer('key2'));
|
|
|
|
var fromKeypair = KDF.buf2keypair(new Buffer('key3'));
|
2014-09-12 17:24:00 -07:00
|
|
|
var enchex = '3867dce7be22e8551512b25f329b51fd5fe8ecfe0381c7831a20c7c9ec88dcf092ea3683261798ccda991ed65a3a54a036d8125dec0381c7831a20c7c9ec88dcf092ea3683261798ccda991ed65a3a54a036d8125dec9f86d081884c7d659a2feaa0c55ad015aca97de5af3a34a0f47eee0a1f7774dcb759187555003282bd23b047bceb5b2f2c1ee35b8f0be1fda7a41424f6cc8030559c8c32ea8cc812860f4c8123f1417a';
|
2014-09-10 14:00:53 -07:00
|
|
|
var encbuf = new Buffer(enchex, 'hex');
|
|
|
|
var ivbuf = Hash.sha256(new Buffer('test')).slice(0, 128 / 8);
|
|
|
|
var sk = Stealthkey().set({payloadKeypair: payloadKeypair, scanKeypair: scanKeypair});
|
|
|
|
var sa = StealthAddress().fromStealthkey(sk);
|
|
|
|
var messagebuf = new Buffer('this is my message');
|
|
|
|
|
|
|
|
it('should make a new stealthmessage', function() {
|
|
|
|
var sm = new StealthMessage();
|
|
|
|
should.exist(sm);
|
|
|
|
sm = StealthMessage()
|
|
|
|
should.exist(sm);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should allow "set" style syntax', function() {
|
|
|
|
var encbuf = StealthMessage().set({
|
|
|
|
messagebuf: messagebuf,
|
|
|
|
toStealthAddress: sa
|
|
|
|
}).encrypt().encbuf;
|
|
|
|
should.exist(encbuf);
|
|
|
|
encbuf.length.should.equal(113);
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('#set', function() {
|
|
|
|
|
|
|
|
it('should set the messagebuf', function() {
|
|
|
|
var sm = StealthMessage().set({messagebuf: messagebuf});
|
|
|
|
should.exist(sm.messagebuf);
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('@encrypt', function() {
|
|
|
|
|
|
|
|
it('should encrypt a message', function() {
|
|
|
|
var encbuf = StealthMessage.encrypt(messagebuf, sa);
|
|
|
|
encbuf.length.should.equal(166);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should encrypt a message with this fromKeypair and ivbuf the same each time', function() {
|
|
|
|
var encbuf = StealthMessage.encrypt(messagebuf, sa, fromKeypair, ivbuf);
|
|
|
|
encbuf.length.should.equal(166);
|
|
|
|
encbuf.toString('hex').should.equal(enchex);
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('@decrypt', function() {
|
|
|
|
|
|
|
|
it('should decrypt this known message correctly', function() {
|
|
|
|
var messagebuf2 = StealthMessage.decrypt(encbuf, sk);
|
|
|
|
messagebuf2.toString('hex').should.equal(messagebuf.toString('hex'));
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('@isForMe', function() {
|
|
|
|
|
|
|
|
it('should know that this message is for me', function() {
|
|
|
|
StealthMessage.isForMe(encbuf, sk).should.equal(true);
|
|
|
|
});
|
|
|
|
|
2014-09-12 17:24:00 -07:00
|
|
|
it('should know that this message is for me even if my payloadPrivkey is not present', function() {
|
|
|
|
var sk2 = new Stealthkey();
|
|
|
|
sk2.scanKeypair = sk.scanKeypair;
|
|
|
|
sk2.payloadKeypair = Keypair().set({pubkey: sk.payloadKeypair.pubkey});
|
|
|
|
should.not.exist(sk2.payloadKeypair.privkey);
|
|
|
|
StealthMessage.isForMe(encbuf, sk2).should.equal(true);
|
|
|
|
});
|
|
|
|
|
2014-09-10 14:00:53 -07:00
|
|
|
});
|
|
|
|
|
|
|
|
describe('#encrypt', function() {
|
|
|
|
|
|
|
|
it('should encrypt this message', function() {
|
|
|
|
var sm = StealthMessage().set({
|
|
|
|
messagebuf: messagebuf,
|
|
|
|
toStealthAddress: sa,
|
|
|
|
fromKeypair: fromKeypair
|
|
|
|
});
|
|
|
|
sm.encrypt().encbuf.length.should.equal(113);
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('#decrypt', function() {
|
|
|
|
|
|
|
|
it('should decrypt that which was encrypted', function() {
|
|
|
|
var sm = StealthMessage().set({
|
|
|
|
messagebuf: messagebuf,
|
|
|
|
toStealthAddress: sa
|
|
|
|
}).encrypt();
|
|
|
|
var messagebuf2 = StealthMessage().set({
|
|
|
|
encbuf: sm.encbuf,
|
|
|
|
fromKeypair: sm.fromKeypair,
|
|
|
|
toStealthkey: sk
|
|
|
|
}).decrypt().messagebuf;
|
|
|
|
messagebuf2.toString('hex').should.equal(messagebuf.toString('hex'));
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('#isForMe', function() {
|
|
|
|
|
|
|
|
it('should know that this message is for me', function() {
|
|
|
|
StealthMessage().set({
|
|
|
|
encbuf: encbuf,
|
|
|
|
toStealthkey: sk,
|
|
|
|
fromKeypair: fromKeypair,
|
|
|
|
receiveAddress: Address().set({hashbuf: encbuf.slice(0, 20)})
|
|
|
|
}).isForMe().should.equal(true);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should know that this message is not for me', function() {
|
|
|
|
StealthMessage().set({
|
|
|
|
encbuf: encbuf,
|
|
|
|
toStealthkey: sk,
|
|
|
|
fromKeypair: fromKeypair,
|
|
|
|
receiveAddress: Address().set({hashbuf: encbuf.slice(0, 20)})
|
|
|
|
}).isForMe().should.equal(true);
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|