|
|
|
'use strict';
|
|
|
|
var imports = require('soop').imports();
|
|
|
|
var coinUtil = imports.coinUtil || require('../util');
|
|
|
|
var Key = imports.Key || require('./Key');
|
|
|
|
|
|
|
|
var Message = function() {};
|
|
|
|
|
|
|
|
Message.sign = function(str, key) {
|
|
|
|
var hash = Message.magicHash(str);
|
|
|
|
var sig = key.signSync(hash);
|
|
|
|
return sig;
|
|
|
|
};
|
|
|
|
|
|
|
|
Message.verifyWithPubKey = function(pubkey, message, sig) {
|
|
|
|
var hash = Message.magicHash(message);
|
|
|
|
var key = new Key();
|
|
|
|
if (pubkey.length == 65)
|
|
|
|
key.compressed = false;
|
|
|
|
key.public = pubkey;
|
|
|
|
|
|
|
|
return key.verifySignatureSync(hash, sig);
|
|
|
|
};
|
|
|
|
|
|
|
|
//TODO: Message.verify ... with address, not pubkey
|
|
|
|
|
|
|
|
Message.magicBytes = new Buffer('Bitcoin Signed Message:\n');
|
|
|
|
|
|
|
|
Message.magicHash = function(str) {
|
|
|
|
var magicBytes = Message.magicBytes;
|
|
|
|
var prefix1 = coinUtil.varIntBuf(magicBytes.length);
|
|
|
|
var message = new Buffer(str);
|
|
|
|
var prefix2 = coinUtil.varIntBuf(message.length);
|
|
|
|
|
|
|
|
var buf = Buffer.concat([prefix1, magicBytes, prefix2, message]);
|
|
|
|
|
|
|
|
var hash = coinUtil.twoSha256(buf);
|
|
|
|
|
|
|
|
return hash;
|
|
|
|
};
|
|
|
|
|
|
|
|
module.exports = require('soop')(Message);
|