@ledgerhq/hw-ledger-key-ring-protocol 0.2.1-nightly.0 → 0.2.1-spl-test.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.turbo/turbo-build.log +1 -1
- package/CHANGELOG.md +3 -3
- package/lib/ApduDevice.d.ts.map +1 -1
- package/lib/ApduDevice.js +37 -41
- package/lib/ApduDevice.js.map +1 -1
- package/lib/CommandBlock.d.ts +4 -4
- package/lib/CommandBlock.d.ts.map +1 -1
- package/lib/CommandBlock.js +18 -35
- package/lib/CommandBlock.js.map +1 -1
- package/lib/CommandStream.d.ts +1 -1
- package/lib/CommandStream.d.ts.map +1 -1
- package/lib/CommandStream.js +5 -7
- package/lib/CommandStream.js.map +1 -1
- package/lib/Crypto.d.ts +11 -11
- package/lib/Crypto.d.ts.map +1 -1
- package/lib/Device.d.ts +1 -1
- package/lib/Device.d.ts.map +1 -1
- package/lib/Device.js +28 -36
- package/lib/Device.js.map +1 -1
- package/lib/NobleCrypto.d.ts +13 -15
- package/lib/NobleCrypto.d.ts.map +1 -1
- package/lib/NobleCrypto.js +90 -148
- package/lib/NobleCrypto.js.map +1 -1
- package/lib/StreamTreeCipher.d.ts.map +1 -1
- package/lib/StreamTreeCipher.js +32 -36
- package/lib/StreamTreeCipher.js.map +1 -1
- package/lib/__tests__/codec.js +33 -33
- package/lib/__tests__/codec.js.map +1 -1
- package/lib-es/ApduDevice.d.ts.map +1 -1
- package/lib-es/ApduDevice.js +37 -41
- package/lib-es/ApduDevice.js.map +1 -1
- package/lib-es/CommandBlock.d.ts +4 -4
- package/lib-es/CommandBlock.d.ts.map +1 -1
- package/lib-es/CommandBlock.js +18 -35
- package/lib-es/CommandBlock.js.map +1 -1
- package/lib-es/CommandStream.d.ts +1 -1
- package/lib-es/CommandStream.d.ts.map +1 -1
- package/lib-es/CommandStream.js +5 -7
- package/lib-es/CommandStream.js.map +1 -1
- package/lib-es/Crypto.d.ts +11 -11
- package/lib-es/Crypto.d.ts.map +1 -1
- package/lib-es/Device.d.ts +1 -1
- package/lib-es/Device.d.ts.map +1 -1
- package/lib-es/Device.js +28 -36
- package/lib-es/Device.js.map +1 -1
- package/lib-es/NobleCrypto.d.ts +13 -15
- package/lib-es/NobleCrypto.d.ts.map +1 -1
- package/lib-es/NobleCrypto.js +90 -148
- package/lib-es/NobleCrypto.js.map +1 -1
- package/lib-es/StreamTreeCipher.d.ts.map +1 -1
- package/lib-es/StreamTreeCipher.js +32 -36
- package/lib-es/StreamTreeCipher.js.map +1 -1
- package/lib-es/__tests__/codec.js +33 -33
- package/lib-es/__tests__/codec.js.map +1 -1
- package/package.json +2 -2
- package/src/ApduDevice.ts +10 -14
- package/src/CommandBlock.ts +11 -14
- package/src/CommandStream.ts +6 -8
- package/src/Crypto.ts +11 -11
- package/src/Device.ts +26 -34
- package/src/NobleCrypto.ts +20 -59
- package/src/StreamTreeCipher.ts +15 -15
- package/src/__tests__/codec.ts +32 -32
package/lib/StreamTreeCipher.js
CHANGED
|
@@ -44,22 +44,22 @@ class StreamTreeCipher {
|
|
|
44
44
|
encrypt(tree_1, path_1, message_1) {
|
|
45
45
|
return __awaiter(this, arguments, void 0, function* (tree, path, message, nonce = null) {
|
|
46
46
|
if (nonce === null) {
|
|
47
|
-
nonce =
|
|
47
|
+
nonce = _1.crypto.randomBytes(16);
|
|
48
48
|
}
|
|
49
49
|
// Generate ephemeral key pair
|
|
50
|
-
const ephemeralKeyPair =
|
|
50
|
+
const ephemeralKeyPair = _1.crypto.randomKeypair();
|
|
51
51
|
// Get the group public key
|
|
52
52
|
const groupKeypair = yield this.getGroupKeypair(tree, path);
|
|
53
53
|
// Compute the secret via ECDH
|
|
54
|
-
const secret =
|
|
54
|
+
const secret = _1.crypto.ecdh(ephemeralKeyPair, groupKeypair.publicKey);
|
|
55
55
|
let encrypted = new Uint8Array(0);
|
|
56
56
|
switch (this._mode) {
|
|
57
57
|
case StreamTreeCipherMode.AES_256_CBC: {
|
|
58
|
-
encrypted =
|
|
58
|
+
encrypted = _1.crypto.encrypt(secret, nonce, message);
|
|
59
59
|
break;
|
|
60
60
|
}
|
|
61
61
|
case StreamTreeCipherMode.AES_256_GCM: {
|
|
62
|
-
encrypted =
|
|
62
|
+
encrypted = _1.crypto.encrypt(secret, nonce, message);
|
|
63
63
|
break;
|
|
64
64
|
}
|
|
65
65
|
default:
|
|
@@ -81,33 +81,31 @@ class StreamTreeCipher {
|
|
|
81
81
|
}
|
|
82
82
|
// Compute the relative path from the event to the path parameter
|
|
83
83
|
const privateKey = (yield this._device.readKey(tree, path)).slice(0, 32);
|
|
84
|
-
const publicKey =
|
|
84
|
+
const publicKey = _1.crypto.keypairFromSecretKey(privateKey).publicKey;
|
|
85
85
|
return { privateKey, publicKey };
|
|
86
86
|
});
|
|
87
87
|
}
|
|
88
88
|
encodeData(ephemeralPublicKey, nonce, data, message) {
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
return result;
|
|
110
|
-
});
|
|
89
|
+
const result = new Uint8Array(1 + 33 + nonce.length + TAG_LENGTH + data.length);
|
|
90
|
+
let offset = 0;
|
|
91
|
+
// Version
|
|
92
|
+
result[offset] = this._mode;
|
|
93
|
+
offset += 1;
|
|
94
|
+
// Ephemeral public key
|
|
95
|
+
result.set(ephemeralPublicKey, offset);
|
|
96
|
+
offset += ephemeralPublicKey.length;
|
|
97
|
+
// Nonce/IV
|
|
98
|
+
result.set(nonce, offset);
|
|
99
|
+
offset += nonce.length;
|
|
100
|
+
// Checksum
|
|
101
|
+
if (this._mode == StreamTreeCipherMode.AES_256_CBC) {
|
|
102
|
+
const checksum = this.computeChecksum(message);
|
|
103
|
+
result.set(checksum, offset);
|
|
104
|
+
offset += checksum.length;
|
|
105
|
+
}
|
|
106
|
+
// Encrypted data
|
|
107
|
+
result.set(data, offset);
|
|
108
|
+
return result;
|
|
111
109
|
}
|
|
112
110
|
decodeData(payload) {
|
|
113
111
|
const version = payload[0];
|
|
@@ -144,19 +142,19 @@ class StreamTreeCipher {
|
|
|
144
142
|
const encryptedMessage = decodedPayload.encrypted;
|
|
145
143
|
const checksum = decodedPayload.checksum;
|
|
146
144
|
const sharedKeyPair = yield this.getGroupKeypair(tree, path);
|
|
147
|
-
const secret =
|
|
145
|
+
const secret = _1.crypto.ecdh(sharedKeyPair, ephemeralKey);
|
|
148
146
|
let decrypted = new Uint8Array(0);
|
|
149
147
|
switch (this._mode) {
|
|
150
148
|
case StreamTreeCipherMode.AES_256_CBC: {
|
|
151
|
-
decrypted =
|
|
152
|
-
const computedChecksum =
|
|
149
|
+
decrypted = _1.crypto.decrypt(secret, nonce, encryptedMessage);
|
|
150
|
+
const computedChecksum = this.computeChecksum(decrypted);
|
|
153
151
|
if (_1.crypto.to_hex(computedChecksum) !== _1.crypto.to_hex(checksum)) {
|
|
154
152
|
throw new Error("Invalid checksum");
|
|
155
153
|
}
|
|
156
154
|
break;
|
|
157
155
|
}
|
|
158
156
|
case StreamTreeCipherMode.AES_256_GCM: {
|
|
159
|
-
decrypted =
|
|
157
|
+
decrypted = _1.crypto.decrypt(secret, nonce, encryptedMessage);
|
|
160
158
|
break;
|
|
161
159
|
}
|
|
162
160
|
default:
|
|
@@ -166,10 +164,8 @@ class StreamTreeCipher {
|
|
|
166
164
|
});
|
|
167
165
|
}
|
|
168
166
|
computeChecksum(message) {
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
return hash.slice(0, 16);
|
|
172
|
-
});
|
|
167
|
+
const hash = _1.crypto.hash(message);
|
|
168
|
+
return hash.slice(0, 16);
|
|
173
169
|
}
|
|
174
170
|
static create(device, mode = StreamTreeCipherMode.AES_256_GCM) {
|
|
175
171
|
return new StreamTreeCipher(mode, device);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"StreamTreeCipher.js","sourceRoot":"","sources":["../src/StreamTreeCipher.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,wBAAmC;AAGnC;;GAEG;AACH,IAAY,oBAGX;AAHD,WAAY,oBAAoB;IAC9B,6EAAkB,CAAA;IAClB,6EAAkB,CAAA;AACpB,CAAC,EAHW,oBAAoB,oCAApB,oBAAoB,QAG/B;AAED,MAAM,UAAU,GAAG,EAAE,CAAC;AAUtB;;GAEG;AACH,MAAa,gBAAgB;IAI3B,YAAY,IAA0B,EAAE,MAAc;QACpD,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;QAClB,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC;IACxB,CAAC;IAED,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAED;;;;;;;;;OASG;IACG,OAAO;6DACX,IAAgB,EAChB,IAAc,EACd,OAAmB,EACnB,QAA2B,IAAI;YAE/B,IAAI,KAAK,KAAK,IAAI,EAAE,CAAC;gBACnB,KAAK,GAAG,
|
|
1
|
+
{"version":3,"file":"StreamTreeCipher.js","sourceRoot":"","sources":["../src/StreamTreeCipher.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,wBAAmC;AAGnC;;GAEG;AACH,IAAY,oBAGX;AAHD,WAAY,oBAAoB;IAC9B,6EAAkB,CAAA;IAClB,6EAAkB,CAAA;AACpB,CAAC,EAHW,oBAAoB,oCAApB,oBAAoB,QAG/B;AAED,MAAM,UAAU,GAAG,EAAE,CAAC;AAUtB;;GAEG;AACH,MAAa,gBAAgB;IAI3B,YAAY,IAA0B,EAAE,MAAc;QACpD,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;QAClB,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC;IACxB,CAAC;IAED,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAED;;;;;;;;;OASG;IACG,OAAO;6DACX,IAAgB,EAChB,IAAc,EACd,OAAmB,EACnB,QAA2B,IAAI;YAE/B,IAAI,KAAK,KAAK,IAAI,EAAE,CAAC;gBACnB,KAAK,GAAG,SAAM,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;YACjC,CAAC;YAED,8BAA8B;YAC9B,MAAM,gBAAgB,GAAG,SAAM,CAAC,aAAa,EAAE,CAAC;YAEhD,2BAA2B;YAC3B,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;YAE5D,8BAA8B;YAC9B,MAAM,MAAM,GAAG,SAAM,CAAC,IAAI,CAAC,gBAAgB,EAAE,YAAY,CAAC,SAAS,CAAC,CAAC;YAErE,IAAI,SAAS,GAAe,IAAI,UAAU,CAAC,CAAC,CAAC,CAAC;YAC9C,QAAQ,IAAI,CAAC,KAAK,EAAE,CAAC;gBACnB,KAAK,oBAAoB,CAAC,WAAW,CAAC,CAAC,CAAC;oBACtC,SAAS,GAAG,SAAM,CAAC,OAAO,CAAC,MAAM,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC;oBACnD,MAAM;gBACR,CAAC;gBACD,KAAK,oBAAoB,CAAC,WAAW,CAAC,CAAC,CAAC;oBACtC,SAAS,GAAG,SAAM,CAAC,OAAO,CAAC,MAAM,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC;oBACnD,MAAM;gBACR,CAAC;gBACD;oBACE,MAAM,IAAI,KAAK,CAAC,qBAAqB,CAAC,CAAC;YAC3C,CAAC;YAED,2BAA2B;YAC3B,OAAO,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;QAChF,CAAC;KAAA;IAEa,eAAe,CAC3B,IAAgB,EAChB,IAAc;;YAEd,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,oBAAoB,EAAE,EAAE,CAAC;gBACzC,MAAM,IAAI,KAAK,CAAC,2DAA2D,CAAC,CAAC;YAC/E,CAAC;YACD,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,CAAC;YACjD,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;YACpE,IAAI,CAAC,KAAK,EAAE,CAAC;gBACX,MAAM,IAAI,KAAK,CAAC,oDAAoD,CAAC,CAAC;YACxE,CAAC;YAED,iEAAiE;YACjE,MAAM,UAAU,GAAG,CAAC,MAAM,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;YACzE,MAAM,SAAS,GAAG,SAAM,CAAC,oBAAoB,CAAC,UAAU,CAAC,CAAC,SAAS,CAAC;YACpE,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,CAAC;QACnC,CAAC;KAAA;IAEO,UAAU,CAChB,kBAA8B,EAC9B,KAAiB,EACjB,IAAgB,EAChB,OAAmB;QAEnB,MAAM,MAAM,GAAG,IAAI,UAAU,CAAC,CAAC,GAAG,EAAE,GAAG,KAAK,CAAC,MAAM,GAAG,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC;QAChF,IAAI,MAAM,GAAG,CAAC,CAAC;QACf,UAAU;QACV,MAAM,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC;QAC5B,MAAM,IAAI,CAAC,CAAC;QACZ,uBAAuB;QACvB,MAAM,CAAC,GAAG,CAAC,kBAAkB,EAAE,MAAM,CAAC,CAAC;QACvC,MAAM,IAAI,kBAAkB,CAAC,MAAM,CAAC;QACpC,WAAW;QACX,MAAM,CAAC,GAAG,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;QAC1B,MAAM,IAAI,KAAK,CAAC,MAAM,CAAC;QACvB,WAAW;QACX,IAAI,IAAI,CAAC,KAAK,IAAI,oBAAoB,CAAC,WAAW,EAAE,CAAC;YACnD,MAAM,QAAQ,GAAG,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;YAC/C,MAAM,CAAC,GAAG,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;YAC7B,MAAM,IAAI,QAAQ,CAAC,MAAM,CAAC;QAC5B,CAAC;QACD,iBAAiB;QACjB,MAAM,CAAC,GAAG,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;QACzB,OAAO,MAAM,CAAC;IAChB,CAAC;IAEO,UAAU,CAAC,OAAmB;QACpC,MAAM,OAAO,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;QAC3B,IAAI,MAAM,GAAG,CAAC,CAAC;QACf,MAAM,kBAAkB,GAAG,OAAO,CAAC,KAAK,CAAC,MAAM,EAAE,MAAM,GAAG,EAAE,CAAC,CAAC;QAC9D,MAAM,IAAI,EAAE,CAAC;QACb,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,MAAM,EAAE,MAAM,GAAG,EAAE,CAAC,CAAC;QACjD,MAAM,IAAI,EAAE,CAAC;QACb,MAAM,QAAQ,GAAG,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,GAAG,EAAE,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;QACpE,MAAM,SAAS,GAAG,OAAO,CAAC,KAAK,CAAC,MAAM,EAAE,OAAO,CAAC,MAAM,GAAG,EAAE,CAAC,CAAC;QAC7D,OAAO;YACL,OAAO;YACP,kBAAkB;YAClB,KAAK;YACL,SAAS;YACT,QAAQ;SACT,CAAC;IACJ,CAAC;IAED;;;;;;;;;OASG;IACG,OAAO,CACX,IAAgB,EAChB,IAAc,EACd,eAA2B;;YAE3B,MAAM,cAAc,GAAG,IAAI,CAAC,UAAU,CAAC,eAAe,CAAC,CAAC;YAExD,MAAM,YAAY,GAAG,cAAc,CAAC,kBAAkB,CAAC;YACvD,MAAM,KAAK,GAAG,cAAc,CAAC,KAAK,CAAC;YACnC,MAAM,gBAAgB,GAAG,cAAc,CAAC,SAAS,CAAC;YAClD,MAAM,QAAQ,GAAG,cAAc,CAAC,QAAQ,CAAC;YAEzC,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;YAC7D,MAAM,MAAM,GAAG,SAAM,CAAC,IAAI,CAAC,aAAa,EAAE,YAAY,CAAC,CAAC;YAExD,IAAI,SAAS,GAAG,IAAI,UAAU,CAAC,CAAC,CAAC,CAAC;YAClC,QAAQ,IAAI,CAAC,KAAK,EAAE,CAAC;gBACnB,KAAK,oBAAoB,CAAC,WAAW,CAAC,CAAC,CAAC;oBACtC,SAAS,GAAG,SAAM,CAAC,OAAO,CAAC,MAAM,EAAE,KAAK,EAAE,gBAAgB,CAAC,CAAC;oBAC5D,MAAM,gBAAgB,GAAG,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC;oBACzD,IAAI,SAAM,CAAC,MAAM,CAAC,gBAAgB,CAAC,KAAK,SAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,CAAC;wBAChE,MAAM,IAAI,KAAK,CAAC,kBAAkB,CAAC,CAAC;oBACtC,CAAC;oBACD,MAAM;gBACR,CAAC;gBACD,KAAK,oBAAoB,CAAC,WAAW,CAAC,CAAC,CAAC;oBACtC,SAAS,GAAG,SAAM,CAAC,OAAO,CAAC,MAAM,EAAE,KAAK,EAAE,gBAAgB,CAAC,CAAC;oBAC5D,MAAM;gBACR,CAAC;gBACD;oBACE,MAAM,IAAI,KAAK,CAAC,qBAAqB,CAAC,CAAC;YAC3C,CAAC;YAED,OAAO,SAAS,CAAC;QACnB,CAAC;KAAA;IAEO,eAAe,CAAC,OAAmB;QACzC,MAAM,IAAI,GAAG,SAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAClC,OAAO,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IAC3B,CAAC;IAED,MAAM,CAAC,MAAM,CACX,MAAc,EACd,OAA6B,oBAAoB,CAAC,WAAW;QAE7D,OAAO,IAAI,gBAAgB,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;IAC5C,CAAC;CACF;AAtLD,4CAsLC"}
|
package/lib/__tests__/codec.js
CHANGED
|
@@ -16,81 +16,81 @@ const CommandStreamEncoder_1 = require("../CommandStreamEncoder");
|
|
|
16
16
|
const Crypto_1 = require("../Crypto");
|
|
17
17
|
const __1 = require("..");
|
|
18
18
|
describe("Encode/Decode command stream tester", () => {
|
|
19
|
-
it("should encode and decode a byte", () =>
|
|
19
|
+
it("should encode and decode a byte", () => {
|
|
20
20
|
const byte = 42;
|
|
21
21
|
let buffer = new Uint8Array();
|
|
22
22
|
buffer = tlv_1.TLV.pushByte(buffer, 42);
|
|
23
23
|
const decoded = tlv_1.TLV.readVarInt(tlv_1.TLV.readTLV(buffer, 0));
|
|
24
24
|
expect(decoded.value).toBe(byte);
|
|
25
|
-
})
|
|
26
|
-
it("should encode and decode a Int32", () =>
|
|
25
|
+
});
|
|
26
|
+
it("should encode and decode a Int32", () => {
|
|
27
27
|
const varint = 0xdeadbeef;
|
|
28
28
|
let buffer = new Uint8Array();
|
|
29
29
|
buffer = tlv_1.TLV.pushInt32(buffer, varint);
|
|
30
30
|
const decoded = tlv_1.TLV.readVarInt(tlv_1.TLV.readTLV(buffer, 0));
|
|
31
31
|
expect(decoded.value).toBe(varint);
|
|
32
|
-
})
|
|
33
|
-
it("should encode and decode a string", () =>
|
|
32
|
+
});
|
|
33
|
+
it("should encode and decode a string", () => {
|
|
34
34
|
const str = "Hello World";
|
|
35
35
|
let buffer = new Uint8Array();
|
|
36
36
|
buffer = tlv_1.TLV.pushString(buffer, str);
|
|
37
37
|
const decoded = tlv_1.TLV.readString(tlv_1.TLV.readTLV(buffer, 0));
|
|
38
38
|
expect(decoded.value).toBe(str);
|
|
39
|
-
})
|
|
40
|
-
it("should encode and decode a hash", () =>
|
|
41
|
-
const hash =
|
|
39
|
+
});
|
|
40
|
+
it("should encode and decode a hash", () => {
|
|
41
|
+
const hash = Crypto_1.crypto.hash(new Uint8Array([0, 1, 2, 3, 4, 5, 6, 7, 8, 9]));
|
|
42
42
|
let buffer = new Uint8Array();
|
|
43
43
|
buffer = tlv_1.TLV.pushHash(buffer, hash);
|
|
44
44
|
const decoded = tlv_1.TLV.readHash(tlv_1.TLV.readTLV(buffer, 0));
|
|
45
45
|
expect(Crypto_1.crypto.to_hex(decoded.value)).toEqual(Crypto_1.crypto.to_hex(hash));
|
|
46
|
-
})
|
|
47
|
-
it("should encode and decode bytes", () =>
|
|
46
|
+
});
|
|
47
|
+
it("should encode and decode bytes", () => {
|
|
48
48
|
const bytes = new Uint8Array([0, 1, 2, 3, 4, 5, 6, 7, 8, 9]);
|
|
49
49
|
let buffer = new Uint8Array();
|
|
50
50
|
buffer = tlv_1.TLV.pushBytes(buffer, bytes);
|
|
51
51
|
const decoded = tlv_1.TLV.readBytes(tlv_1.TLV.readTLV(buffer, 0));
|
|
52
52
|
expect(decoded.value).toEqual(bytes);
|
|
53
|
-
})
|
|
54
|
-
it("should encode and decode a signature", () =>
|
|
55
|
-
const alice =
|
|
56
|
-
const block =
|
|
53
|
+
});
|
|
54
|
+
it("should encode and decode a signature", () => {
|
|
55
|
+
const alice = Crypto_1.crypto.randomKeypair();
|
|
56
|
+
const block = (0, CommandBlock_1.signCommandBlock)((0, CommandBlock_1.createCommandBlock)(alice.publicKey, []), alice.publicKey, alice.privateKey);
|
|
57
57
|
let buffer = new Uint8Array();
|
|
58
58
|
buffer = tlv_1.TLV.pushSignature(buffer, block.signature);
|
|
59
59
|
const decoded = tlv_1.TLV.readSignature(tlv_1.TLV.readTLV(buffer, 0));
|
|
60
60
|
expect(decoded.value).toEqual(block.signature);
|
|
61
|
-
})
|
|
62
|
-
it("should encode and decode a public key", () =>
|
|
63
|
-
const alice =
|
|
61
|
+
});
|
|
62
|
+
it("should encode and decode a public key", () => {
|
|
63
|
+
const alice = Crypto_1.crypto.randomKeypair();
|
|
64
64
|
let buffer = new Uint8Array();
|
|
65
65
|
buffer = tlv_1.TLV.pushPublicKey(buffer, alice.publicKey);
|
|
66
66
|
const decoded = tlv_1.TLV.readPublicKey(tlv_1.TLV.readTLV(buffer, 0));
|
|
67
67
|
expect(decoded.value).toEqual(alice.publicKey);
|
|
68
|
-
})
|
|
69
|
-
it("should encode and decode a stream. Encoding/Decoding should not alter the stream", () =>
|
|
70
|
-
const alice =
|
|
71
|
-
const groupPk =
|
|
72
|
-
const groupChainCode =
|
|
68
|
+
});
|
|
69
|
+
it("should encode and decode a stream. Encoding/Decoding should not alter the stream", () => {
|
|
70
|
+
const alice = Crypto_1.crypto.randomKeypair();
|
|
71
|
+
const groupPk = Crypto_1.crypto.randomKeypair();
|
|
72
|
+
const groupChainCode = Crypto_1.crypto.randomBytes(32);
|
|
73
73
|
const xpriv = new Uint8Array(64);
|
|
74
|
-
const initializationVector =
|
|
74
|
+
const initializationVector = Crypto_1.crypto.randomBytes(16);
|
|
75
75
|
xpriv.set(groupPk.privateKey);
|
|
76
76
|
xpriv.set(groupChainCode, 32);
|
|
77
|
-
const ephemeralPk =
|
|
78
|
-
const block1 =
|
|
79
|
-
new CommandBlock_1.Seed(
|
|
77
|
+
const ephemeralPk = Crypto_1.crypto.randomKeypair();
|
|
78
|
+
const block1 = (0, CommandBlock_1.signCommandBlock)((0, CommandBlock_1.createCommandBlock)(alice.publicKey, [
|
|
79
|
+
new CommandBlock_1.Seed(Crypto_1.crypto.randomBytes(16), 0, groupPk.publicKey, initializationVector, xpriv, ephemeralPk.publicKey),
|
|
80
80
|
]), alice.publicKey, alice.privateKey);
|
|
81
|
-
const block2 =
|
|
82
|
-
new CommandBlock_1.AddMember("Alice",
|
|
83
|
-
new CommandBlock_1.PublishKey(
|
|
81
|
+
const block2 = (0, CommandBlock_1.signCommandBlock)((0, CommandBlock_1.createCommandBlock)(alice.publicKey, [
|
|
82
|
+
new CommandBlock_1.AddMember("Alice", Crypto_1.crypto.randomBytes(32), CommandBlock_1.Permissions.OWNER),
|
|
83
|
+
new CommandBlock_1.PublishKey(Crypto_1.crypto.randomBytes(16), Crypto_1.crypto.randomBytes(32), Crypto_1.crypto.randomBytes(32), Crypto_1.crypto.randomBytes(32)),
|
|
84
84
|
]), alice.publicKey, alice.privateKey);
|
|
85
|
-
const block3 =
|
|
85
|
+
const block3 = (0, CommandBlock_1.signCommandBlock)((0, CommandBlock_1.createCommandBlock)(alice.publicKey, []), alice.publicKey, alice.privateKey);
|
|
86
86
|
const stream = [block1, block2, block3];
|
|
87
87
|
const encoded = CommandStreamEncoder_1.CommandStreamEncoder.encode(stream);
|
|
88
|
-
const digestEncoded =
|
|
88
|
+
const digestEncoded = Crypto_1.crypto.hash(encoded);
|
|
89
89
|
const decoded = CommandStreamDecoder_1.CommandStreamDecoder.decode(encoded);
|
|
90
90
|
const reencoded = CommandStreamEncoder_1.CommandStreamEncoder.encode(decoded);
|
|
91
|
-
const digestReencoded =
|
|
91
|
+
const digestReencoded = Crypto_1.crypto.hash(reencoded);
|
|
92
92
|
expect(digestEncoded).toEqual(digestReencoded);
|
|
93
|
-
})
|
|
93
|
+
});
|
|
94
94
|
it("decodes a specific command stream", () => __awaiter(void 0, void 0, void 0, function* () {
|
|
95
95
|
const tlv = "0101010220824b3168c79e8b61b599751c107117b5c9b647f2b6859de8a245952559707692062102a13e82cd0d2f77d1ab1434d8bd799571e54cd32e1121c5cf82217f8b0b713b6b01010315a8050c800000008000001080000000062103ccf74aa7775b3d39d6cbb0236acee7a7f980b9f6a556a4d814d44b0bd56cb77b05108c51eda6be26623ca919ed17333afcdb054019c0b60ede1692479cc04ce69eae6a0bd51941bab6f044f3dec10c11cf11e6253504d1df6b0aab7dc1996e4eaa7c6f92c29153c59534578901cd7ff4efcea1ae06210268abdb3d49ba4a274ce8660cde0d1eeaf1fea00e281218be775f6b3aefc39756113a040f7765622d746f6f6c732d6563626638062103a270456b0f95714cc61a6473e6b6d8db354a3c377281096bdd2439a5475ecbf80104ffffffff129a05100e5205b4a616b2a4d79b07b4a4932f560540669e741f38fee07956fb0dc0ea9978d55bd5d8424b0d0f66a2c5a45788f92d0ddc283138c7ba62c521de1d604ee7f847c5aed40a11536bbe742af0be8cfd4132062103a270456b0f95714cc61a6473e6b6d8db354a3c377281096bdd2439a5475ecbf80621027003755248202ea8a67d1fcdcd82d7f7022248f3af892fa5307d3ea250dc81050346304402204422a779fd08723d8cba19c0cc11ef7a24f6f1f459cb01598ff1a26f27ea8976022053a554d4f509223f2d08faa5de796fed13a9762f35da08e94884edd1f7c0d015";
|
|
96
96
|
const decoded = CommandStreamDecoder_1.CommandStreamDecoder.decode(Crypto_1.crypto.from_hex(tlv));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"codec.js","sourceRoot":"","sources":["../../src/__tests__/codec.ts"],"names":[],"mappings":";;;;;;;;;;;AAAA,kDAOyB;AACzB,gCAA6B;AAC7B,kEAA+D;AAC/D,kEAA+D;AAC/D,sCAAmC;AACnC,0BAAmC;AAEnC,QAAQ,CAAC,qCAAqC,EAAE,GAAG,EAAE;IACnD,EAAE,CAAC,iCAAiC,EAAE,
|
|
1
|
+
{"version":3,"file":"codec.js","sourceRoot":"","sources":["../../src/__tests__/codec.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ApduDevice.d.ts","sourceRoot":"","sources":["../src/ApduDevice.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"ApduDevice.d.ts","sourceRoot":"","sources":["../src/ApduDevice.ts"],"names":[],"mappings":"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"}
|
package/lib-es/ApduDevice.js
CHANGED
|
@@ -274,42 +274,40 @@ APDU.INS_SIGN_BLOCK = 0x07;
|
|
|
274
274
|
APDU.INS_INIT = 0x06;
|
|
275
275
|
APDU.INS_SET_TRUSTED_MEMBER = 0x09;
|
|
276
276
|
function injectTrustedProperties(command, properties, secret) {
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
return seedCommand;
|
|
287
|
-
}
|
|
288
|
-
case CommandType.Derive: {
|
|
289
|
-
const deriveCommand = command;
|
|
290
|
-
const deriveProperties = properties;
|
|
291
|
-
deriveCommand.encryptedXpriv = yield crypto.decrypt(secret, deriveProperties.iv, deriveProperties.xpriv);
|
|
292
|
-
deriveCommand.ephemeralPublicKey = deriveProperties.ephemeralPublicKey;
|
|
293
|
-
deriveCommand.initializationVector = deriveProperties.commandIv;
|
|
294
|
-
deriveCommand.groupKey = deriveProperties.groupKey;
|
|
295
|
-
return deriveCommand;
|
|
296
|
-
}
|
|
297
|
-
case CommandType.AddMember:
|
|
298
|
-
return command; // No properties to inject
|
|
299
|
-
case CommandType.PublishKey: {
|
|
300
|
-
const publishKeyCommand = command;
|
|
301
|
-
const publishKeyProperties = properties;
|
|
302
|
-
publishKeyCommand.ephemeralPublicKey = publishKeyProperties.ephemeralPublicKey;
|
|
303
|
-
publishKeyCommand.initializationVector = publishKeyProperties.commandIv;
|
|
304
|
-
publishKeyCommand.encryptedXpriv = yield crypto.decrypt(secret, publishKeyProperties.iv, publishKeyProperties.xpriv);
|
|
305
|
-
return publishKeyCommand;
|
|
306
|
-
}
|
|
307
|
-
case CommandType.CloseStream:
|
|
308
|
-
return command; // No properties to inject
|
|
309
|
-
default:
|
|
310
|
-
throw new Error("Unsupported command type");
|
|
277
|
+
switch (command.getType()) {
|
|
278
|
+
case CommandType.Seed: {
|
|
279
|
+
const seedCommand = command;
|
|
280
|
+
const seedProperties = properties;
|
|
281
|
+
seedCommand.encryptedXpriv = crypto.decrypt(secret, seedProperties.iv, seedProperties.xpriv);
|
|
282
|
+
seedCommand.ephemeralPublicKey = seedProperties.ephemeralPublicKey;
|
|
283
|
+
seedCommand.initializationVector = seedProperties.commandIv;
|
|
284
|
+
seedCommand.groupKey = seedProperties.groupKey;
|
|
285
|
+
return seedCommand;
|
|
311
286
|
}
|
|
312
|
-
|
|
287
|
+
case CommandType.Derive: {
|
|
288
|
+
const deriveCommand = command;
|
|
289
|
+
const deriveProperties = properties;
|
|
290
|
+
deriveCommand.encryptedXpriv = crypto.decrypt(secret, deriveProperties.iv, deriveProperties.xpriv);
|
|
291
|
+
deriveCommand.ephemeralPublicKey = deriveProperties.ephemeralPublicKey;
|
|
292
|
+
deriveCommand.initializationVector = deriveProperties.commandIv;
|
|
293
|
+
deriveCommand.groupKey = deriveProperties.groupKey;
|
|
294
|
+
return deriveCommand;
|
|
295
|
+
}
|
|
296
|
+
case CommandType.AddMember:
|
|
297
|
+
return command; // No properties to inject
|
|
298
|
+
case CommandType.PublishKey: {
|
|
299
|
+
const publishKeyCommand = command;
|
|
300
|
+
const publishKeyProperties = properties;
|
|
301
|
+
publishKeyCommand.ephemeralPublicKey = publishKeyProperties.ephemeralPublicKey;
|
|
302
|
+
publishKeyCommand.initializationVector = publishKeyProperties.commandIv;
|
|
303
|
+
publishKeyCommand.encryptedXpriv = crypto.decrypt(secret, publishKeyProperties.iv, publishKeyProperties.xpriv);
|
|
304
|
+
return publishKeyCommand;
|
|
305
|
+
}
|
|
306
|
+
case CommandType.CloseStream:
|
|
307
|
+
return command; // No properties to inject
|
|
308
|
+
default:
|
|
309
|
+
throw new Error("Unsupported command type");
|
|
310
|
+
}
|
|
313
311
|
}
|
|
314
312
|
function findTrustedMember(params, member) {
|
|
315
313
|
return params.members.get(crypto.to_hex(member)) || null;
|
|
@@ -330,9 +328,7 @@ export class ApduDevice {
|
|
|
330
328
|
});
|
|
331
329
|
}
|
|
332
330
|
getSeedId(data) {
|
|
333
|
-
return
|
|
334
|
-
return APDU.getSeedId(this.transport, data);
|
|
335
|
-
});
|
|
331
|
+
return APDU.getSeedId(this.transport, data);
|
|
336
332
|
}
|
|
337
333
|
assertStreamIsValid(stream) {
|
|
338
334
|
const blockToSign = stream.filter(block => block.signature.length == 0).length;
|
|
@@ -461,7 +457,7 @@ export class ApduDevice {
|
|
|
461
457
|
}
|
|
462
458
|
sign(stream) {
|
|
463
459
|
return __awaiter(this, void 0, void 0, function* () {
|
|
464
|
-
const sessionKey =
|
|
460
|
+
const sessionKey = this.sessionKeyPair;
|
|
465
461
|
const trustedProperties = [];
|
|
466
462
|
// We expect the stream to have a single block to sign (the last one)
|
|
467
463
|
this.assertStreamIsValid(stream);
|
|
@@ -483,8 +479,8 @@ export class ApduDevice {
|
|
|
483
479
|
// Finalize block signature
|
|
484
480
|
const signature = yield APDU.finalizeSignature(this.transport);
|
|
485
481
|
// Decrypt and inject trusted issuer
|
|
486
|
-
const secret =
|
|
487
|
-
const issuer =
|
|
482
|
+
const secret = crypto.ecdh(sessionKey, signature.sessionKey);
|
|
483
|
+
const issuer = crypto.decrypt(secret, trustedIssuer.iv, trustedIssuer.issuer);
|
|
488
484
|
// Inject trusted properties for commands
|
|
489
485
|
for (let commandIndex = 0; commandIndex < blockToSign.commands.length; commandIndex++) {
|
|
490
486
|
blockToSign.commands[commandIndex] = yield injectTrustedProperties(blockToSign.commands[commandIndex], trustedProperties[commandIndex], secret);
|
package/lib-es/ApduDevice.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ApduDevice.js","sourceRoot":"","sources":["../src/ApduDevice.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"ApduDevice.js","sourceRoot":"","sources":["../src/ApduDevice.ts"],"names":[],"mappings":"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"}
|
package/lib-es/CommandBlock.d.ts
CHANGED
|
@@ -107,8 +107,8 @@ export interface CommandBlock {
|
|
|
107
107
|
* @param parent The parent command block hash (if null, the block is the first block and a parent will be generated)
|
|
108
108
|
* @returns
|
|
109
109
|
*/
|
|
110
|
-
export declare function createCommandBlock(issuer: Uint8Array, commands: Command[], signature?: Uint8Array, parent?: Uint8Array | null):
|
|
111
|
-
export declare function signCommandBlock(block: CommandBlock, issuer: Uint8Array, secretKey: Uint8Array):
|
|
112
|
-
export declare function hashCommandBlock(block: CommandBlock):
|
|
113
|
-
export declare function verifyCommandBlock(block: CommandBlock):
|
|
110
|
+
export declare function createCommandBlock(issuer: Uint8Array, commands: Command[], signature?: Uint8Array, parent?: Uint8Array | null): CommandBlock;
|
|
111
|
+
export declare function signCommandBlock(block: CommandBlock, issuer: Uint8Array, secretKey: Uint8Array): CommandBlock;
|
|
112
|
+
export declare function hashCommandBlock(block: CommandBlock): Uint8Array;
|
|
113
|
+
export declare function verifyCommandBlock(block: CommandBlock): boolean;
|
|
114
114
|
//# sourceMappingURL=CommandBlock.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CommandBlock.d.ts","sourceRoot":"","sources":["../src/CommandBlock.ts"],"names":[],"mappings":"AAGA;;GAEG;AACH,MAAM,WAAW,OAAO;IACtB,OAAO,IAAI,WAAW,CAAC;CACxB;AAED;;GAEG;AACH,oBAAY,WAAW;IACrB,IAAI,KAAO;IACX,SAAS,KAAO;IAChB,UAAU,KAAO;IACjB,UAAU,KAAO;IACjB,MAAM,KAAO;IACb,WAAW,KAAO;CACnB;AAED;;GAEG;AACH,eAAO,MAAM,WAAW;;;;;;;;;;CAWvB,CAAC;AAEF;;GAEG;AACH,qBAAa,IAAK,YAAW,OAAO;IAClC,KAAK,EAAE,UAAU,GAAG,IAAI,CAAC;IACzB,eAAe,EAAE,MAAM,CAAC;IACxB,QAAQ,EAAE,UAAU,CAAC;IACrB,oBAAoB,EAAE,UAAU,CAAC;IACjC,cAAc,EAAE,UAAU,CAAC;IAC3B,kBAAkB,EAAE,UAAU,CAAC;gBAG7B,KAAK,EAAE,UAAU,GAAG,IAAI,EACxB,eAAe,EAAE,MAAM,EACvB,QAAQ,EAAE,UAAU,EACpB,oBAAoB,EAAE,UAAU,EAChC,cAAc,EAAE,UAAU,EAC1B,gBAAgB,EAAE,UAAU;IAW9B,OAAO,IAAI,WAAW;CAGvB;AAED;;GAEG;AACH,qBAAa,MAAO,YAAW,OAAO;IACpC,IAAI,EAAE,MAAM,EAAE,CAAC;IACf,QAAQ,EAAE,UAAU,CAAC;IACrB,oBAAoB,EAAE,UAAU,CAAC;IACjC,cAAc,EAAE,UAAU,CAAC;IAC3B,kBAAkB,EAAE,UAAU,CAAC;gBAG7B,IAAI,EAAE,MAAM,EAAE,EACd,QAAQ,EAAE,UAAU,EACpB,oBAAoB,EAAE,UAAU,EAChC,cAAc,EAAE,UAAU,EAC1B,kBAAkB,EAAE,UAAU;IAShC,OAAO,IAAI,WAAW;CAGvB;AAED;;GAEG;AACH,qBAAa,SAAU,YAAW,OAAO;IACvC,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,UAAU,CAAC;IACtB,WAAW,EAAE,MAAM,CAAC;gBAER,IAAI,EAAE,MAAM,EAAE,SAAS,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM;IAMpE,OAAO,IAAI,WAAW;CAGvB;AAED;;GAEG;AACH,qBAAa,UAAW,YAAW,OAAO;IACxC,oBAAoB,EAAE,UAAU,CAAC;IACjC,cAAc,EAAE,UAAU,CAAC;IAC3B,SAAS,EAAE,UAAU,CAAC;IACtB,kBAAkB,EAAE,UAAU,CAAC;gBAG7B,oBAAoB,EAAE,UAAU,EAChC,cAAc,EAAE,UAAU,EAC1B,SAAS,EAAE,UAAU,EACrB,kBAAkB,EAAE,UAAU;IAQhC,OAAO,IAAI,WAAW;CAGvB;AAED;;GAEG;AACH,qBAAa,UAAW,YAAW,OAAO;IACxC,MAAM,EAAE,UAAU,CAAC;IACnB,IAAI,EAAE,MAAM,GAAG,IAAI,CAAC;IACpB,WAAW,EAAE,MAAM,GAAG,IAAI,CAAC;gBAEf,MAAM,EAAE,UAAU,EAAE,IAAI,EAAE,MAAM,GAAG,IAAI,EAAE,WAAW,EAAE,MAAM,GAAG,IAAI;IAM/E,OAAO,IAAI,WAAW;CAGvB;AAED;;GAEG;AACH,qBAAa,WAAY,YAAW,OAAO;;IAGzC,OAAO,IAAI,WAAW;CAGvB;AAUD,MAAM,WAAW,YAAY;IAE3B,OAAO,EAAE,MAAM,CAAC;IAEhB,MAAM,EAAE,UAAU,CAAC;IAEnB,MAAM,EAAE,UAAU,CAAC;IAEnB,QAAQ,EAAE,OAAO,EAAE,CAAC;IAEpB,SAAS,EAAE,UAAU,CAAC;CACvB;AAED;;;;;;;GAOG;AACH,
|
|
1
|
+
{"version":3,"file":"CommandBlock.d.ts","sourceRoot":"","sources":["../src/CommandBlock.ts"],"names":[],"mappings":"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"}
|
package/lib-es/CommandBlock.js
CHANGED
|
@@ -1,12 +1,3 @@
|
|
|
1
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
2
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
3
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
4
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
5
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
6
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
7
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
8
|
-
});
|
|
9
|
-
};
|
|
10
1
|
import { CommandStreamEncoder } from "./CommandStreamEncoder";
|
|
11
2
|
import { crypto } from "./Crypto";
|
|
12
3
|
/**
|
|
@@ -124,37 +115,29 @@ export class CloseStream {
|
|
|
124
115
|
* @param parent The parent command block hash (if null, the block is the first block and a parent will be generated)
|
|
125
116
|
* @returns
|
|
126
117
|
*/
|
|
127
|
-
export function createCommandBlock(
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
};
|
|
139
|
-
});
|
|
118
|
+
export function createCommandBlock(issuer, commands, signature = new Uint8Array(), parent = null) {
|
|
119
|
+
if (parent === null) {
|
|
120
|
+
parent = parent = crypto.randomBytes(32);
|
|
121
|
+
}
|
|
122
|
+
return {
|
|
123
|
+
version: 1,
|
|
124
|
+
issuer,
|
|
125
|
+
parent,
|
|
126
|
+
commands,
|
|
127
|
+
signature,
|
|
128
|
+
};
|
|
140
129
|
}
|
|
141
130
|
export function signCommandBlock(block, issuer, secretKey) {
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
return Object.assign(Object.assign({}, block), { signature });
|
|
145
|
-
});
|
|
131
|
+
const signature = crypto.sign(hashCommandBlock(block), crypto.keypairFromSecretKey(secretKey));
|
|
132
|
+
return Object.assign(Object.assign({}, block), { signature });
|
|
146
133
|
}
|
|
147
134
|
export function hashCommandBlock(block) {
|
|
148
|
-
return
|
|
149
|
-
return yield crypto.hash(CommandStreamEncoder.encode([block]));
|
|
150
|
-
});
|
|
135
|
+
return crypto.hash(CommandStreamEncoder.encode([block]));
|
|
151
136
|
}
|
|
152
137
|
export function verifyCommandBlock(block) {
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
return yield crypto.verify(hash, block.signature, block.issuer);
|
|
158
|
-
});
|
|
138
|
+
const unsignedBlock = Object.assign({}, block);
|
|
139
|
+
unsignedBlock.signature = new Uint8Array();
|
|
140
|
+
const hash = hashCommandBlock(unsignedBlock);
|
|
141
|
+
return crypto.verify(hash, block.signature, block.issuer);
|
|
159
142
|
}
|
|
160
143
|
//# sourceMappingURL=CommandBlock.js.map
|