From 60446df733682e274a5deb6f85a7104511608bc6 Mon Sep 17 00:00:00 2001 From: Jeff Garzik Date: Sat, 17 Aug 2013 01:10:54 -0400 Subject: [PATCH 1/2] SIN: spec updated magic number (prefix) to 0x0F --- SIN.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/SIN.js b/SIN.js index d4f15a5..dba5cc3 100644 --- a/SIN.js +++ b/SIN.js @@ -11,7 +11,7 @@ function ClassSpec(b) { }; this.data = new Buffer(1 + 1 + payload.length); this.__proto__ = this.encodings['binary']; - this.prefix(0x18); // SIN magic number, in numberspace + this.prefix(0x0F); // SIN magic number, in numberspace this.type(type); this.payload(payload); }; From 52e5f3fdd489aade383574961f571ce350a6ff46 Mon Sep 17 00:00:00 2001 From: Jeff Garzik Date: Sat, 17 Aug 2013 01:11:23 -0400 Subject: [PATCH 2/2] Support SIN keys in wallets. --- SINKey.js | 6 +++++- Wallet.js | 6 ++++++ 2 files changed, 11 insertions(+), 1 deletion(-) diff --git a/SINKey.js b/SINKey.js index 54bc54a..b80a8a1 100644 --- a/SINKey.js +++ b/SINKey.js @@ -19,9 +19,13 @@ function ClassSpec(b) { this.created = timeUtil.curtime(); }; + SINKey.prototype.pubkeyHash = function() { + return coinUtil.sha256ripe160(this.privKey.public); + }; + SINKey.prototype.storeObj = function() { var pubKey = this.privKey.public.toString('hex'); - var pubKeyHash = coinUtil.sha256ripe160(this.privKey.public); + var pubKeyHash = this.pubkeyHash(); var sin = new SIN(SIN.SIN_EPHEM, pubKeyHash); var obj = { created: this.created, diff --git a/Wallet.js b/Wallet.js index ac5a290..9ca8b79 100644 --- a/Wallet.js +++ b/Wallet.js @@ -17,6 +17,7 @@ function ClassSpec(b) { best_hash: null, best_height: -1, keys: [], + sin: {}, scripts: {}, }; @@ -76,6 +77,11 @@ function ClassSpec(b) { this.dirty = true; }; + Wallet.prototype.addSIN = function(sinObj) { + this.datastore.sin[sinObj.sin] = sinObj; + this.dirty = true; + }; + Wallet.prototype.findKeyHash = function(pubKeyHash) { var pkhStr = pubKeyHash.toString();