@ledgerhq/hw-ledger-key-ring-protocol 0.3.1 → 0.3.2-nightly.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 +7 -0
- package/lib/ApduDevice.d.ts +1 -0
- package/lib/ApduDevice.d.ts.map +1 -1
- package/lib/ApduDevice.js +195 -240
- package/lib/ApduDevice.js.map +1 -1
- package/lib/CommandBlock.js +26 -2
- package/lib/CommandBlock.js.map +1 -1
- package/lib/CommandStream.js +69 -85
- package/lib/CommandStream.js.map +1 -1
- package/lib/CommandStreamResolver.js +42 -56
- package/lib/CommandStreamResolver.js.map +1 -1
- package/lib/Device.js +115 -131
- package/lib/Device.js.map +1 -1
- package/lib/IndexedTree.js +2 -0
- package/lib/IndexedTree.js.map +1 -1
- package/lib/PublicKey.js +1 -0
- package/lib/PublicKey.js.map +1 -1
- package/lib/SeedId.js +12 -0
- package/lib/SeedId.js.map +1 -1
- package/lib/StreamTree.js +56 -72
- package/lib/StreamTree.js.map +1 -1
- package/lib/StreamTreeCipher.js +62 -75
- package/lib/StreamTreeCipher.js.map +1 -1
- package/lib/__tests__/codec.js +3 -12
- package/lib/__tests__/codec.js.map +1 -1
- package/lib/__tests__/crypto.js +22 -31
- package/lib/__tests__/crypto.js.map +1 -1
- package/lib/__tests__/indexed_tree.js +2 -3
- package/lib/__tests__/indexed_tree.js.map +1 -1
- package/lib/__tests__/key_exchange.js +40 -49
- package/lib/__tests__/key_exchange.js.map +1 -1
- package/lib/__tests__/shared_object.js +34 -47
- package/lib/__tests__/shared_object.js.map +1 -1
- package/lib-es/ApduDevice.d.ts +1 -0
- package/lib-es/ApduDevice.d.ts.map +1 -1
- package/lib-es/ApduDevice.js +195 -240
- package/lib-es/ApduDevice.js.map +1 -1
- package/lib-es/CommandBlock.js +26 -2
- package/lib-es/CommandBlock.js.map +1 -1
- package/lib-es/CommandStream.js +69 -85
- package/lib-es/CommandStream.js.map +1 -1
- package/lib-es/CommandStreamResolver.js +42 -56
- package/lib-es/CommandStreamResolver.js.map +1 -1
- package/lib-es/Device.js +115 -131
- package/lib-es/Device.js.map +1 -1
- package/lib-es/IndexedTree.js +2 -0
- package/lib-es/IndexedTree.js.map +1 -1
- package/lib-es/PublicKey.js +1 -0
- package/lib-es/PublicKey.js.map +1 -1
- package/lib-es/SeedId.js +12 -0
- package/lib-es/SeedId.js.map +1 -1
- package/lib-es/StreamTree.js +56 -72
- package/lib-es/StreamTree.js.map +1 -1
- package/lib-es/StreamTreeCipher.js +62 -75
- package/lib-es/StreamTreeCipher.js.map +1 -1
- package/lib-es/__tests__/codec.js +3 -12
- package/lib-es/__tests__/codec.js.map +1 -1
- package/lib-es/__tests__/crypto.js +22 -31
- package/lib-es/__tests__/crypto.js.map +1 -1
- package/lib-es/__tests__/indexed_tree.js +2 -3
- package/lib-es/__tests__/indexed_tree.js.map +1 -1
- package/lib-es/__tests__/key_exchange.js +40 -49
- package/lib-es/__tests__/key_exchange.js.map +1 -1
- package/lib-es/__tests__/shared_object.js +34 -47
- package/lib-es/__tests__/shared_object.js.map +1 -1
- package/package.json +5 -5
- package/tsconfig.json +0 -1
package/lib/CommandBlock.js
CHANGED
|
@@ -33,6 +33,12 @@ exports.Permissions = {
|
|
|
33
33
|
*
|
|
34
34
|
*/
|
|
35
35
|
class Seed {
|
|
36
|
+
topic;
|
|
37
|
+
protocolVersion;
|
|
38
|
+
groupKey;
|
|
39
|
+
initializationVector;
|
|
40
|
+
encryptedXpriv;
|
|
41
|
+
ephemeralPublicKey;
|
|
36
42
|
constructor(topic, protocolVersion, groupKey, initializationVector, encryptedXpriv, ephemerPublicKey) {
|
|
37
43
|
this.topic = topic;
|
|
38
44
|
this.protocolVersion = protocolVersion;
|
|
@@ -51,6 +57,11 @@ exports.Seed = Seed;
|
|
|
51
57
|
*
|
|
52
58
|
*/
|
|
53
59
|
class Derive {
|
|
60
|
+
path;
|
|
61
|
+
groupKey;
|
|
62
|
+
initializationVector;
|
|
63
|
+
encryptedXpriv;
|
|
64
|
+
ephemeralPublicKey;
|
|
54
65
|
constructor(path, groupKey, initializationVector, encryptedXpriv, ephemeralPublicKey) {
|
|
55
66
|
this.path = path;
|
|
56
67
|
this.groupKey = groupKey;
|
|
@@ -67,6 +78,9 @@ exports.Derive = Derive;
|
|
|
67
78
|
*
|
|
68
79
|
*/
|
|
69
80
|
class AddMember {
|
|
81
|
+
name;
|
|
82
|
+
publicKey;
|
|
83
|
+
permissions;
|
|
70
84
|
constructor(name, publicKey, permissions) {
|
|
71
85
|
this.name = name;
|
|
72
86
|
this.publicKey = publicKey;
|
|
@@ -81,6 +95,10 @@ exports.AddMember = AddMember;
|
|
|
81
95
|
*
|
|
82
96
|
*/
|
|
83
97
|
class PublishKey {
|
|
98
|
+
initializationVector;
|
|
99
|
+
encryptedXpriv;
|
|
100
|
+
recipient;
|
|
101
|
+
ephemeralPublicKey;
|
|
84
102
|
constructor(initializationVector, encryptedXpriv, recipient, ephemeralPublicKey) {
|
|
85
103
|
this.encryptedXpriv = encryptedXpriv;
|
|
86
104
|
this.initializationVector = initializationVector;
|
|
@@ -96,6 +114,9 @@ exports.PublishKey = PublishKey;
|
|
|
96
114
|
*
|
|
97
115
|
*/
|
|
98
116
|
class EditMember {
|
|
117
|
+
member;
|
|
118
|
+
name;
|
|
119
|
+
permissions;
|
|
99
120
|
constructor(member, name, permissions) {
|
|
100
121
|
this.name = name;
|
|
101
122
|
this.permissions = permissions;
|
|
@@ -139,7 +160,10 @@ function createCommandBlock(issuer, commands, signature = new Uint8Array(), pare
|
|
|
139
160
|
exports.createCommandBlock = createCommandBlock;
|
|
140
161
|
function signCommandBlock(block, issuer, secretKey) {
|
|
141
162
|
const signature = Crypto_1.crypto.sign(hashCommandBlock(block), Crypto_1.crypto.keypairFromSecretKey(secretKey));
|
|
142
|
-
return
|
|
163
|
+
return {
|
|
164
|
+
...block,
|
|
165
|
+
signature,
|
|
166
|
+
};
|
|
143
167
|
}
|
|
144
168
|
exports.signCommandBlock = signCommandBlock;
|
|
145
169
|
function hashCommandBlock(block) {
|
|
@@ -147,7 +171,7 @@ function hashCommandBlock(block) {
|
|
|
147
171
|
}
|
|
148
172
|
exports.hashCommandBlock = hashCommandBlock;
|
|
149
173
|
function verifyCommandBlock(block) {
|
|
150
|
-
const unsignedBlock =
|
|
174
|
+
const unsignedBlock = { ...block };
|
|
151
175
|
unsignedBlock.signature = new Uint8Array();
|
|
152
176
|
const hash = hashCommandBlock(unsignedBlock);
|
|
153
177
|
return Crypto_1.crypto.verify(hash, block.signature, block.issuer);
|
package/lib/CommandBlock.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CommandBlock.js","sourceRoot":"","sources":["../src/CommandBlock.ts"],"names":[],"mappings":";;;AAAA,iEAA8D;AAC9D,qCAAkC;AASlC;;GAEG;AACH,IAAY,WAOX;AAPD,WAAY,WAAW;IACrB,8CAAW,CAAA;IACX,wDAAgB,CAAA;IAChB,0DAAiB,CAAA;IACjB,0DAAiB,CAAA;IACjB,kDAAa,CAAA;IACb,4DAAkB,CAAA;AACpB,CAAC,EAPW,WAAW,2BAAX,WAAW,QAOtB;AAED;;GAEG;AACU,QAAA,WAAW,GAAG;IACzB,UAAU,EAAE,IAAI;IAChB,WAAW,EAAE,IAAI;IACjB,WAAW,EAAE,IAAI;IACjB,UAAU,EAAE,IAAI;IAChB,aAAa,EAAE,IAAI;IACnB,yBAAyB,EAAE,IAAI;IAC/B,kBAAkB,EAAE,IAAI;IAExB,MAAM,EAAE,CAAC;IACT,KAAK,EAAE,UAAU;CAClB,CAAC;AAEF;;GAEG;AACH,MAAa,IAAI;
|
|
1
|
+
{"version":3,"file":"CommandBlock.js","sourceRoot":"","sources":["../src/CommandBlock.ts"],"names":[],"mappings":";;;AAAA,iEAA8D;AAC9D,qCAAkC;AASlC;;GAEG;AACH,IAAY,WAOX;AAPD,WAAY,WAAW;IACrB,8CAAW,CAAA;IACX,wDAAgB,CAAA;IAChB,0DAAiB,CAAA;IACjB,0DAAiB,CAAA;IACjB,kDAAa,CAAA;IACb,4DAAkB,CAAA;AACpB,CAAC,EAPW,WAAW,2BAAX,WAAW,QAOtB;AAED;;GAEG;AACU,QAAA,WAAW,GAAG;IACzB,UAAU,EAAE,IAAI;IAChB,WAAW,EAAE,IAAI;IACjB,WAAW,EAAE,IAAI;IACjB,UAAU,EAAE,IAAI;IAChB,aAAa,EAAE,IAAI;IACnB,yBAAyB,EAAE,IAAI;IAC/B,kBAAkB,EAAE,IAAI;IAExB,MAAM,EAAE,CAAC;IACT,KAAK,EAAE,UAAU;CAClB,CAAC;AAEF;;GAEG;AACH,MAAa,IAAI;IACf,KAAK,CAAoB;IACzB,eAAe,CAAS;IACxB,QAAQ,CAAa;IACrB,oBAAoB,CAAa;IACjC,cAAc,CAAa;IAC3B,kBAAkB,CAAa;IAE/B,YACE,KAAwB,EACxB,eAAuB,EACvB,QAAoB,EACpB,oBAAgC,EAChC,cAA0B,EAC1B,gBAA4B;QAE5B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,eAAe,GAAG,eAAe,CAAC;QACvC,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,MAAM,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,UAAU,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC;QACrE,IAAI,CAAC,oBAAoB;YACvB,oBAAoB,CAAC,MAAM,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,UAAU,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,oBAAoB,CAAC;QAC/E,IAAI,CAAC,cAAc,GAAG,cAAc,CAAC,MAAM,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,UAAU,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC;QACvF,IAAI,CAAC,kBAAkB,GAAG,gBAAgB,CAAC,MAAM,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,UAAU,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,gBAAgB,CAAC;IACjG,CAAC;IAED,OAAO;QACL,OAAO,WAAW,CAAC,IAAI,CAAC;IAC1B,CAAC;CACF;AA5BD,oBA4BC;AAED;;GAEG;AACH,MAAa,MAAM;IACjB,IAAI,CAAW;IACf,QAAQ,CAAa;IACrB,oBAAoB,CAAa;IACjC,cAAc,CAAa;IAC3B,kBAAkB,CAAa;IAE/B,YACE,IAAc,EACd,QAAoB,EACpB,oBAAgC,EAChC,cAA0B,EAC1B,kBAA8B;QAE9B,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,oBAAoB,GAAG,oBAAoB,CAAC;QACjD,IAAI,CAAC,cAAc,GAAG,cAAc,CAAC;QACrC,IAAI,CAAC,kBAAkB,GAAG,kBAAkB,CAAC;IAC/C,CAAC;IAED,OAAO;QACL,OAAO,WAAW,CAAC,MAAM,CAAC;IAC5B,CAAC;CACF;AAxBD,wBAwBC;AAED;;GAEG;AACH,MAAa,SAAS;IACpB,IAAI,CAAS;IACb,SAAS,CAAa;IACtB,WAAW,CAAS;IAEpB,YAAY,IAAY,EAAE,SAAqB,EAAE,WAAmB;QAClE,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;IACjC,CAAC;IAED,OAAO;QACL,OAAO,WAAW,CAAC,SAAS,CAAC;IAC/B,CAAC;CACF;AAdD,8BAcC;AAED;;GAEG;AACH,MAAa,UAAU;IACrB,oBAAoB,CAAa;IACjC,cAAc,CAAa;IAC3B,SAAS,CAAa;IACtB,kBAAkB,CAAa;IAE/B,YACE,oBAAgC,EAChC,cAA0B,EAC1B,SAAqB,EACrB,kBAA8B;QAE9B,IAAI,CAAC,cAAc,GAAG,cAAc,CAAC;QACrC,IAAI,CAAC,oBAAoB,GAAG,oBAAoB,CAAC;QACjD,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,IAAI,CAAC,kBAAkB,GAAG,kBAAkB,CAAC;IAC/C,CAAC;IAED,OAAO;QACL,OAAO,WAAW,CAAC,UAAU,CAAC;IAChC,CAAC;CACF;AArBD,gCAqBC;AAED;;GAEG;AACH,MAAa,UAAU;IACrB,MAAM,CAAa;IACnB,IAAI,CAAgB;IACpB,WAAW,CAAgB;IAE3B,YAAY,MAAkB,EAAE,IAAmB,EAAE,WAA0B;QAC7E,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAC/B,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;IACvB,CAAC;IAED,OAAO;QACL,OAAO,WAAW,CAAC,UAAU,CAAC;IAChC,CAAC;CACF;AAdD,gCAcC;AAED;;GAEG;AACH,MAAa,WAAW;IACtB,gBAAe,CAAC;IAEhB,OAAO;QACL,OAAO,WAAW,CAAC,WAAW,CAAC;IACjC,CAAC;CACF;AAND,kCAMC;AAuBD;;;;;;;GAOG;AACH,SAAgB,kBAAkB,CAChC,MAAkB,EAClB,QAAmB,EACnB,YAAwB,IAAI,UAAU,EAAE,EACxC,SAA4B,IAAI;IAEhC,IAAI,MAAM,KAAK,IAAI,EAAE,CAAC;QACpB,MAAM,GAAG,MAAM,GAAG,eAAM,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;IAC3C,CAAC;IACD,OAAO;QACL,OAAO,EAAE,CAAC;QACV,MAAM;QACN,MAAM;QACN,QAAQ;QACR,SAAS;KACV,CAAC;AACJ,CAAC;AAhBD,gDAgBC;AAED,SAAgB,gBAAgB,CAC9B,KAAmB,EACnB,MAAkB,EAClB,SAAqB;IAErB,MAAM,SAAS,GAAG,eAAM,CAAC,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,EAAE,eAAM,CAAC,oBAAoB,CAAC,SAAS,CAAC,CAAC,CAAC;IAC/F,OAAO;QACL,GAAG,KAAK;QACR,SAAS;KACV,CAAC;AACJ,CAAC;AAVD,4CAUC;AAED,SAAgB,gBAAgB,CAAC,KAAmB;IAClD,OAAO,eAAM,CAAC,IAAI,CAAC,2CAAoB,CAAC,MAAM,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;AAC3D,CAAC;AAFD,4CAEC;AAED,SAAgB,kBAAkB,CAAC,KAAmB;IACpD,MAAM,aAAa,GAAG,EAAE,GAAG,KAAK,EAAE,CAAC;IACnC,aAAa,CAAC,SAAS,GAAG,IAAI,UAAU,EAAE,CAAC;IAC3C,MAAM,IAAI,GAAG,gBAAgB,CAAC,aAAa,CAAC,CAAC;IAC7C,OAAO,eAAM,CAAC,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,SAAS,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;AAC5D,CAAC;AALD,gDAKC"}
|
package/lib/CommandStream.js
CHANGED
|
@@ -1,13 +1,4 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
-
});
|
|
10
|
-
};
|
|
11
2
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
4
|
};
|
|
@@ -22,33 +13,34 @@ const EMPTY = new Uint8Array();
|
|
|
22
13
|
*
|
|
23
14
|
*/
|
|
24
15
|
class CommandStreamIssuer {
|
|
16
|
+
_stream;
|
|
17
|
+
_steps = [];
|
|
25
18
|
constructor(stream) {
|
|
26
|
-
this._steps = [];
|
|
27
19
|
this._stream = stream;
|
|
28
20
|
}
|
|
29
21
|
seed(topic = null) {
|
|
30
|
-
const step = (device, tempStream, streamTree) =>
|
|
22
|
+
const step = async (device, tempStream, streamTree) => {
|
|
31
23
|
device;
|
|
32
24
|
tempStream;
|
|
33
25
|
streamTree;
|
|
34
26
|
return [new CommandBlock_1.Seed(topic, 0, EMPTY, EMPTY, EMPTY, EMPTY)];
|
|
35
|
-
}
|
|
27
|
+
};
|
|
36
28
|
this._steps.push(step);
|
|
37
29
|
return this;
|
|
38
30
|
}
|
|
39
31
|
derive(path) {
|
|
40
|
-
const step = (device, tempStream, streamTree) =>
|
|
32
|
+
const step = async (device, tempStream, streamTree) => {
|
|
41
33
|
device;
|
|
42
34
|
tempStream;
|
|
43
35
|
streamTree;
|
|
44
36
|
const derivationPath = Crypto_1.DerivationPath.toIndexArray(path);
|
|
45
37
|
return [new CommandBlock_1.Derive(derivationPath, EMPTY, EMPTY, EMPTY, EMPTY)];
|
|
46
|
-
}
|
|
38
|
+
};
|
|
47
39
|
this._steps.push(step);
|
|
48
40
|
return this;
|
|
49
41
|
}
|
|
50
42
|
addMember(name, publicKey, permissions, publishKey = true) {
|
|
51
|
-
const step = (device, tempStream, streamTree) =>
|
|
43
|
+
const step = async (device, tempStream, streamTree) => {
|
|
52
44
|
device;
|
|
53
45
|
tempStream;
|
|
54
46
|
streamTree;
|
|
@@ -61,46 +53,44 @@ class CommandStreamIssuer {
|
|
|
61
53
|
else {
|
|
62
54
|
return [new CommandBlock_1.AddMember(name, publicKey, permissions)];
|
|
63
55
|
}
|
|
64
|
-
}
|
|
56
|
+
};
|
|
65
57
|
this._steps.push(step);
|
|
66
58
|
return this;
|
|
67
59
|
}
|
|
68
60
|
publishKey(publicKey) {
|
|
69
|
-
const step = (device, tempStream, streamTree) =>
|
|
61
|
+
const step = async (device, tempStream, streamTree) => {
|
|
70
62
|
device;
|
|
71
63
|
tempStream;
|
|
72
64
|
streamTree;
|
|
73
65
|
return [new CommandBlock_1.PublishKey(EMPTY, EMPTY, publicKey, EMPTY)];
|
|
74
|
-
}
|
|
66
|
+
};
|
|
75
67
|
this._steps.push(step);
|
|
76
68
|
return this;
|
|
77
69
|
}
|
|
78
70
|
close() {
|
|
79
|
-
const step = (device, tempStream, streamTree) =>
|
|
71
|
+
const step = async (device, tempStream, streamTree) => {
|
|
80
72
|
device;
|
|
81
73
|
tempStream;
|
|
82
74
|
streamTree;
|
|
83
75
|
return [new CommandBlock_1.CloseStream()];
|
|
84
|
-
}
|
|
76
|
+
};
|
|
85
77
|
this._steps.push(step);
|
|
86
78
|
return this;
|
|
87
79
|
}
|
|
88
|
-
issue(device, streamTree, parentHash) {
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
return yield stream.issue(device, commands, streamTree, parentHash);
|
|
103
|
-
});
|
|
80
|
+
async issue(device, streamTree, parentHash) {
|
|
81
|
+
const lastBlockHash = this._stream.blocks.length > 0
|
|
82
|
+
? (0, CommandBlock_1.hashCommandBlock)(this._stream.blocks[this._stream.blocks.length - 1])
|
|
83
|
+
: null;
|
|
84
|
+
const block = (0, CommandBlock_1.createCommandBlock)(Device_1.ISSUER_PLACEHOLDER, [], new Uint8Array(), parentHash || lastBlockHash);
|
|
85
|
+
const stream = new CommandStream(this._stream.blocks.concat([]));
|
|
86
|
+
const tempStream = new CommandStream(this._stream.blocks.concat([block]));
|
|
87
|
+
let commands = [];
|
|
88
|
+
for (const step of this._steps) {
|
|
89
|
+
const newCommands = await step(device, tempStream, streamTree);
|
|
90
|
+
commands = commands.concat(newCommands);
|
|
91
|
+
tempStream.blocks[tempStream.blocks.length - 1].commands = commands;
|
|
92
|
+
}
|
|
93
|
+
return await stream.issue(device, commands, streamTree, parentHash);
|
|
104
94
|
}
|
|
105
95
|
}
|
|
106
96
|
exports.CommandStreamIssuer = CommandStreamIssuer;
|
|
@@ -108,8 +98,8 @@ exports.CommandStreamIssuer = CommandStreamIssuer;
|
|
|
108
98
|
*
|
|
109
99
|
*/
|
|
110
100
|
class CommandStream {
|
|
101
|
+
_blocks = [];
|
|
111
102
|
constructor(blocks = []) {
|
|
112
|
-
this._blocks = [];
|
|
113
103
|
this._blocks = blocks;
|
|
114
104
|
}
|
|
115
105
|
resolve(incomplete = false) {
|
|
@@ -132,60 +122,54 @@ class CommandStream {
|
|
|
132
122
|
throw new Error("Malformed CommandStream");
|
|
133
123
|
}
|
|
134
124
|
}
|
|
135
|
-
push(block, issuer, tree) {
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
throw new Error("Null or empty tree cannot be used to sign the new block");
|
|
147
|
-
}
|
|
148
|
-
stream = [root.blocks[0]].concat(this._blocks);
|
|
149
|
-
}
|
|
150
|
-
else {
|
|
151
|
-
stream = this._blocks;
|
|
152
|
-
}
|
|
153
|
-
if (block.commands[0].getType() === CommandBlock_1.CommandType.Derive) {
|
|
154
|
-
// Set the parent hash of the block to the root hash
|
|
155
|
-
const b = Object.assign({}, block);
|
|
156
|
-
b.parent = (0, CommandBlock_1.hashCommandBlock)(stream[0]);
|
|
157
|
-
stream = stream.concat([b]);
|
|
158
|
-
}
|
|
159
|
-
else {
|
|
160
|
-
stream = stream.concat([block]);
|
|
125
|
+
async push(block, issuer, tree) {
|
|
126
|
+
let stream = [];
|
|
127
|
+
if (block.commands.length === 0) {
|
|
128
|
+
throw new Error("Attempts to create an empty block");
|
|
129
|
+
}
|
|
130
|
+
// If the first command of the new block is not a seed and the first command of the stream is not a seed either, prepend the root block
|
|
131
|
+
if ((this._blocks.length == 0 || this._blocks[0].commands[0].getType() !== CommandBlock_1.CommandType.Seed) &&
|
|
132
|
+
block.commands[0].getType() !== CommandBlock_1.CommandType.Seed) {
|
|
133
|
+
const root = tree?.getRoot();
|
|
134
|
+
if (!root || root.blocks.length === 0) {
|
|
135
|
+
throw new Error("Null or empty tree cannot be used to sign the new block");
|
|
161
136
|
}
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
137
|
+
stream = [root.blocks[0]].concat(this._blocks);
|
|
138
|
+
}
|
|
139
|
+
else {
|
|
140
|
+
stream = this._blocks;
|
|
141
|
+
}
|
|
142
|
+
if (block.commands[0].getType() === CommandBlock_1.CommandType.Derive) {
|
|
143
|
+
// Set the parent hash of the block to the root hash
|
|
144
|
+
const b = { ...block };
|
|
145
|
+
b.parent = (0, CommandBlock_1.hashCommandBlock)(stream[0]);
|
|
146
|
+
stream = stream.concat([b]);
|
|
147
|
+
}
|
|
148
|
+
else {
|
|
149
|
+
stream = stream.concat([block]);
|
|
150
|
+
}
|
|
151
|
+
const signedBlock = await issuer.sign(stream, tree || undefined);
|
|
152
|
+
return new CommandStream(this._blocks.concat([signedBlock]));
|
|
165
153
|
}
|
|
166
|
-
issue(
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
return this.push(block, device, tree);
|
|
171
|
-
});
|
|
154
|
+
async issue(device, commands, tree = null, parentHash = null) {
|
|
155
|
+
const lastBlockHash = this._blocks.length > 0 ? (0, CommandBlock_1.hashCommandBlock)(this._blocks[this._blocks.length - 1]) : null;
|
|
156
|
+
const block = (0, CommandBlock_1.createCommandBlock)(Device_1.ISSUER_PLACEHOLDER, commands, new Uint8Array(), parentHash || lastBlockHash);
|
|
157
|
+
return this.push(block, device, tree);
|
|
172
158
|
}
|
|
173
159
|
edit() {
|
|
174
160
|
return new CommandStreamIssuer(this);
|
|
175
161
|
}
|
|
176
|
-
getStreamPublicKey() {
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
throw new Error("Malformed CommandStream");
|
|
188
|
-
});
|
|
162
|
+
async getStreamPublicKey() {
|
|
163
|
+
// Group public must be the first command in the first block othwerwise it is malformed
|
|
164
|
+
if (this._blocks.length === 0 || this._blocks[0].commands.length === 0)
|
|
165
|
+
throw new Error("Empty CommandStream");
|
|
166
|
+
if (this._blocks[0].commands[0].getType() === CommandBlock_1.CommandType.Seed) {
|
|
167
|
+
return this._blocks[0].commands[0].groupKey;
|
|
168
|
+
}
|
|
169
|
+
if (this._blocks[0].commands[0].getType() === CommandBlock_1.CommandType.Derive) {
|
|
170
|
+
return this._blocks[0].commands[0].groupKey;
|
|
171
|
+
}
|
|
172
|
+
throw new Error("Malformed CommandStream");
|
|
189
173
|
}
|
|
190
174
|
get blocks() {
|
|
191
175
|
return this._blocks;
|
package/lib/CommandStream.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CommandStream.js","sourceRoot":"","sources":["../src/CommandStream.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"CommandStream.js","sourceRoot":"","sources":["../src/CommandStream.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,34 +1,24 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
-
});
|
|
10
|
-
};
|
|
11
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
3
|
exports.ResolvedCommandStream = void 0;
|
|
13
4
|
const CommandBlock_1 = require("./CommandBlock");
|
|
14
5
|
const Crypto_1 = require("./Crypto");
|
|
15
6
|
class ResolvedCommandStreamInternals {
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
this.derivationPath = [];
|
|
29
|
-
}
|
|
7
|
+
isCreated = false;
|
|
8
|
+
members = [];
|
|
9
|
+
membersData = [];
|
|
10
|
+
topic = null;
|
|
11
|
+
keys = new Map();
|
|
12
|
+
permission = new Map();
|
|
13
|
+
height = 0;
|
|
14
|
+
streamId = "";
|
|
15
|
+
hashes = [];
|
|
16
|
+
names = new Map();
|
|
17
|
+
groupPublicKey = new Uint8Array();
|
|
18
|
+
derivationPath = [];
|
|
30
19
|
}
|
|
31
20
|
class ResolvedCommandStream {
|
|
21
|
+
_internals;
|
|
32
22
|
constructor(internals) {
|
|
33
23
|
this._internals = internals;
|
|
34
24
|
}
|
|
@@ -181,40 +171,36 @@ class CommandStreamResolver {
|
|
|
181
171
|
}
|
|
182
172
|
return internals;
|
|
183
173
|
}
|
|
184
|
-
static resolveBlock(block, height, internals) {
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
if (height > 0 &&
|
|
209
|
-
Crypto_1.crypto.to_hex(block.parent) !== Crypto_1.crypto.to_hex(yield (0, CommandBlock_1.hashCommandBlock)(stream[height - 1]))) {
|
|
210
|
-
throw new Error("Command stream has been tampered with (invalid parent hash) at height " + height);
|
|
211
|
-
}
|
|
212
|
-
if (block.signature.length === 0)
|
|
213
|
-
break;
|
|
214
|
-
internals = yield CommandStreamResolver.resolveBlock(block, height, internals);
|
|
174
|
+
static async resolveBlock(block, height, internals) {
|
|
175
|
+
// Check signature
|
|
176
|
+
if ((await (0, CommandBlock_1.verifyCommandBlock)(block)) === false) {
|
|
177
|
+
throw new Error("Invalid block signature at height " + height);
|
|
178
|
+
}
|
|
179
|
+
// Check if issuer is part of the group
|
|
180
|
+
if (height > 0 && !exists(internals.members, block.issuer)) {
|
|
181
|
+
throw new Error("Issuer is not part of the group at height " + height);
|
|
182
|
+
}
|
|
183
|
+
const blockHash = Crypto_1.crypto.to_hex(await (0, CommandBlock_1.hashCommandBlock)(block));
|
|
184
|
+
for (const command of block.commands) {
|
|
185
|
+
internals = CommandStreamResolver.replayCommand(command, block, blockHash, height, internals);
|
|
186
|
+
}
|
|
187
|
+
internals.hashes.push(blockHash);
|
|
188
|
+
return internals;
|
|
189
|
+
}
|
|
190
|
+
static async resolve(stream) {
|
|
191
|
+
let internals = new ResolvedCommandStreamInternals();
|
|
192
|
+
for (let height = 0; height < stream.length; height++) {
|
|
193
|
+
internals.height = height;
|
|
194
|
+
const block = stream[height];
|
|
195
|
+
if (height > 0 &&
|
|
196
|
+
Crypto_1.crypto.to_hex(block.parent) !== Crypto_1.crypto.to_hex(await (0, CommandBlock_1.hashCommandBlock)(stream[height - 1]))) {
|
|
197
|
+
throw new Error("Command stream has been tampered with (invalid parent hash) at height " + height);
|
|
215
198
|
}
|
|
216
|
-
|
|
217
|
-
|
|
199
|
+
if (block.signature.length === 0)
|
|
200
|
+
break;
|
|
201
|
+
internals = await CommandStreamResolver.resolveBlock(block, height, internals);
|
|
202
|
+
}
|
|
203
|
+
return new ResolvedCommandStream(internals);
|
|
218
204
|
}
|
|
219
205
|
}
|
|
220
206
|
exports.default = CommandStreamResolver;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CommandStreamResolver.js","sourceRoot":"","sources":["../src/CommandStreamResolver.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"CommandStreamResolver.js","sourceRoot":"","sources":["../src/CommandStreamResolver.ts"],"names":[],"mappings":"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"}
|