@ledgerhq/hw-ledger-key-ring-protocol 0.2.1-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.
Files changed (225) hide show
  1. package/.eslintrc.js +33 -0
  2. package/.turbo/turbo-build.log +4 -0
  3. package/.unimportedrc.json +4 -0
  4. package/CHANGELOG.md +126 -0
  5. package/LICENSE.txt +21 -0
  6. package/README.md +3 -0
  7. package/jest.config.js +13 -0
  8. package/lib/ApduDevice.d.ts +99 -0
  9. package/lib/ApduDevice.d.ts.map +1 -0
  10. package/lib/ApduDevice.js +532 -0
  11. package/lib/ApduDevice.js.map +1 -0
  12. package/lib/BigEndian.d.ts +7 -0
  13. package/lib/BigEndian.d.ts.map +1 -0
  14. package/lib/BigEndian.js +26 -0
  15. package/lib/BigEndian.js.map +1 -0
  16. package/lib/CommandBlock.d.ts +114 -0
  17. package/lib/CommandBlock.d.ts.map +1 -0
  18. package/lib/CommandBlock.js +173 -0
  19. package/lib/CommandBlock.js.map +1 -0
  20. package/lib/CommandStream.d.ts +38 -0
  21. package/lib/CommandStream.d.ts.map +1 -0
  22. package/lib/CommandStream.js +197 -0
  23. package/lib/CommandStream.js.map +1 -0
  24. package/lib/CommandStreamDecoder.d.ts +15 -0
  25. package/lib/CommandStreamDecoder.d.ts.map +1 -0
  26. package/lib/CommandStreamDecoder.js +101 -0
  27. package/lib/CommandStreamDecoder.js.map +1 -0
  28. package/lib/CommandStreamEncoder.d.ts +16 -0
  29. package/lib/CommandStreamEncoder.d.ts.map +1 -0
  30. package/lib/CommandStreamEncoder.js +131 -0
  31. package/lib/CommandStreamEncoder.js.map +1 -0
  32. package/lib/CommandStreamJsonifier.d.ts +6 -0
  33. package/lib/CommandStreamJsonifier.d.ts.map +1 -0
  34. package/lib/CommandStreamJsonifier.js +75 -0
  35. package/lib/CommandStreamJsonifier.js.map +1 -0
  36. package/lib/CommandStreamResolver.d.ts +53 -0
  37. package/lib/CommandStreamResolver.d.ts.map +1 -0
  38. package/lib/CommandStreamResolver.js +221 -0
  39. package/lib/CommandStreamResolver.js.map +1 -0
  40. package/lib/Crypto.d.ts +38 -0
  41. package/lib/Crypto.d.ts.map +1 -0
  42. package/lib/Crypto.js +47 -0
  43. package/lib/Crypto.js.map +1 -0
  44. package/lib/Device.d.ts +43 -0
  45. package/lib/Device.d.ts.map +1 -0
  46. package/lib/Device.js +203 -0
  47. package/lib/Device.js.map +1 -0
  48. package/lib/IndexedTree.d.ts +13 -0
  49. package/lib/IndexedTree.d.ts.map +1 -0
  50. package/lib/IndexedTree.js +75 -0
  51. package/lib/IndexedTree.js.map +1 -0
  52. package/lib/NobleCrypto.d.ts +41 -0
  53. package/lib/NobleCrypto.d.ts.map +1 -0
  54. package/lib/NobleCrypto.js +298 -0
  55. package/lib/NobleCrypto.js.map +1 -0
  56. package/lib/PublicKey.d.ts +5 -0
  57. package/lib/PublicKey.d.ts.map +1 -0
  58. package/lib/PublicKey.js +10 -0
  59. package/lib/PublicKey.js.map +1 -0
  60. package/lib/SeedId.d.ts +80 -0
  61. package/lib/SeedId.d.ts.map +1 -0
  62. package/lib/SeedId.js +244 -0
  63. package/lib/SeedId.js.map +1 -0
  64. package/lib/StreamTree.d.ts +50 -0
  65. package/lib/StreamTree.d.ts.map +1 -0
  66. package/lib/StreamTree.js +169 -0
  67. package/lib/StreamTree.js.map +1 -0
  68. package/lib/StreamTreeCipher.d.ts +46 -0
  69. package/lib/StreamTreeCipher.d.ts.map +1 -0
  70. package/lib/StreamTreeCipher.js +179 -0
  71. package/lib/StreamTreeCipher.js.map +1 -0
  72. package/lib/__tests__/codec.d.ts +2 -0
  73. package/lib/__tests__/codec.d.ts.map +1 -0
  74. package/lib/__tests__/codec.js +108 -0
  75. package/lib/__tests__/codec.js.map +1 -0
  76. package/lib/__tests__/crypto.d.ts +2 -0
  77. package/lib/__tests__/crypto.d.ts.map +1 -0
  78. package/lib/__tests__/crypto.js +46 -0
  79. package/lib/__tests__/crypto.js.map +1 -0
  80. package/lib/__tests__/indexed_tree.d.ts +2 -0
  81. package/lib/__tests__/indexed_tree.d.ts.map +1 -0
  82. package/lib/__tests__/indexed_tree.js +45 -0
  83. package/lib/__tests__/indexed_tree.js.map +1 -0
  84. package/lib/__tests__/key_exchange.d.ts +2 -0
  85. package/lib/__tests__/key_exchange.d.ts.map +1 -0
  86. package/lib/__tests__/key_exchange.js +129 -0
  87. package/lib/__tests__/key_exchange.js.map +1 -0
  88. package/lib/__tests__/seedId.d.ts +2 -0
  89. package/lib/__tests__/seedId.d.ts.map +1 -0
  90. package/lib/__tests__/seedId.js +92 -0
  91. package/lib/__tests__/seedId.js.map +1 -0
  92. package/lib/__tests__/shared_object.d.ts +2 -0
  93. package/lib/__tests__/shared_object.d.ts.map +1 -0
  94. package/lib/__tests__/shared_object.js +78 -0
  95. package/lib/__tests__/shared_object.js.map +1 -0
  96. package/lib/index.d.ts +35 -0
  97. package/lib/index.d.ts.map +1 -0
  98. package/lib/index.js +81 -0
  99. package/lib/index.js.map +1 -0
  100. package/lib/tlv.d.ts +99 -0
  101. package/lib/tlv.d.ts.map +1 -0
  102. package/lib/tlv.js +150 -0
  103. package/lib/tlv.js.map +1 -0
  104. package/lib-es/ApduDevice.d.ts +99 -0
  105. package/lib-es/ApduDevice.d.ts.map +1 -0
  106. package/lib-es/ApduDevice.js +526 -0
  107. package/lib-es/ApduDevice.js.map +1 -0
  108. package/lib-es/BigEndian.d.ts +7 -0
  109. package/lib-es/BigEndian.d.ts.map +1 -0
  110. package/lib-es/BigEndian.js +23 -0
  111. package/lib-es/BigEndian.js.map +1 -0
  112. package/lib-es/CommandBlock.d.ts +114 -0
  113. package/lib-es/CommandBlock.d.ts.map +1 -0
  114. package/lib-es/CommandBlock.js +160 -0
  115. package/lib-es/CommandBlock.js.map +1 -0
  116. package/lib-es/CommandStream.d.ts +38 -0
  117. package/lib-es/CommandStream.d.ts.map +1 -0
  118. package/lib-es/CommandStream.js +189 -0
  119. package/lib-es/CommandStream.js.map +1 -0
  120. package/lib-es/CommandStreamDecoder.d.ts +15 -0
  121. package/lib-es/CommandStreamDecoder.d.ts.map +1 -0
  122. package/lib-es/CommandStreamDecoder.js +97 -0
  123. package/lib-es/CommandStreamDecoder.js.map +1 -0
  124. package/lib-es/CommandStreamEncoder.d.ts +16 -0
  125. package/lib-es/CommandStreamEncoder.d.ts.map +1 -0
  126. package/lib-es/CommandStreamEncoder.js +127 -0
  127. package/lib-es/CommandStreamEncoder.js.map +1 -0
  128. package/lib-es/CommandStreamJsonifier.d.ts +6 -0
  129. package/lib-es/CommandStreamJsonifier.d.ts.map +1 -0
  130. package/lib-es/CommandStreamJsonifier.js +72 -0
  131. package/lib-es/CommandStreamJsonifier.js.map +1 -0
  132. package/lib-es/CommandStreamResolver.d.ts +53 -0
  133. package/lib-es/CommandStreamResolver.d.ts.map +1 -0
  134. package/lib-es/CommandStreamResolver.js +216 -0
  135. package/lib-es/CommandStreamResolver.js.map +1 -0
  136. package/lib-es/Crypto.d.ts +38 -0
  137. package/lib-es/Crypto.d.ts.map +1 -0
  138. package/lib-es/Crypto.js +43 -0
  139. package/lib-es/Crypto.js.map +1 -0
  140. package/lib-es/Device.d.ts +43 -0
  141. package/lib-es/Device.d.ts.map +1 -0
  142. package/lib-es/Device.js +195 -0
  143. package/lib-es/Device.js.map +1 -0
  144. package/lib-es/IndexedTree.d.ts +13 -0
  145. package/lib-es/IndexedTree.d.ts.map +1 -0
  146. package/lib-es/IndexedTree.js +71 -0
  147. package/lib-es/IndexedTree.js.map +1 -0
  148. package/lib-es/NobleCrypto.d.ts +41 -0
  149. package/lib-es/NobleCrypto.d.ts.map +1 -0
  150. package/lib-es/NobleCrypto.js +267 -0
  151. package/lib-es/NobleCrypto.js.map +1 -0
  152. package/lib-es/PublicKey.d.ts +5 -0
  153. package/lib-es/PublicKey.d.ts.map +1 -0
  154. package/lib-es/PublicKey.js +6 -0
  155. package/lib-es/PublicKey.js.map +1 -0
  156. package/lib-es/SeedId.d.ts +80 -0
  157. package/lib-es/SeedId.d.ts.map +1 -0
  158. package/lib-es/SeedId.js +235 -0
  159. package/lib-es/SeedId.js.map +1 -0
  160. package/lib-es/StreamTree.d.ts +50 -0
  161. package/lib-es/StreamTree.d.ts.map +1 -0
  162. package/lib-es/StreamTree.js +165 -0
  163. package/lib-es/StreamTree.js.map +1 -0
  164. package/lib-es/StreamTreeCipher.d.ts +46 -0
  165. package/lib-es/StreamTreeCipher.d.ts.map +1 -0
  166. package/lib-es/StreamTreeCipher.js +175 -0
  167. package/lib-es/StreamTreeCipher.js.map +1 -0
  168. package/lib-es/__tests__/codec.d.ts +2 -0
  169. package/lib-es/__tests__/codec.d.ts.map +1 -0
  170. package/lib-es/__tests__/codec.js +106 -0
  171. package/lib-es/__tests__/codec.js.map +1 -0
  172. package/lib-es/__tests__/crypto.d.ts +2 -0
  173. package/lib-es/__tests__/crypto.d.ts.map +1 -0
  174. package/lib-es/__tests__/crypto.js +44 -0
  175. package/lib-es/__tests__/crypto.js.map +1 -0
  176. package/lib-es/__tests__/indexed_tree.d.ts +2 -0
  177. package/lib-es/__tests__/indexed_tree.d.ts.map +1 -0
  178. package/lib-es/__tests__/indexed_tree.js +43 -0
  179. package/lib-es/__tests__/indexed_tree.js.map +1 -0
  180. package/lib-es/__tests__/key_exchange.d.ts +2 -0
  181. package/lib-es/__tests__/key_exchange.d.ts.map +1 -0
  182. package/lib-es/__tests__/key_exchange.js +124 -0
  183. package/lib-es/__tests__/key_exchange.js.map +1 -0
  184. package/lib-es/__tests__/seedId.d.ts +2 -0
  185. package/lib-es/__tests__/seedId.d.ts.map +1 -0
  186. package/lib-es/__tests__/seedId.js +90 -0
  187. package/lib-es/__tests__/seedId.js.map +1 -0
  188. package/lib-es/__tests__/shared_object.d.ts +2 -0
  189. package/lib-es/__tests__/shared_object.d.ts.map +1 -0
  190. package/lib-es/__tests__/shared_object.js +76 -0
  191. package/lib-es/__tests__/shared_object.js.map +1 -0
  192. package/lib-es/index.d.ts +35 -0
  193. package/lib-es/index.d.ts.map +1 -0
  194. package/lib-es/index.js +32 -0
  195. package/lib-es/index.js.map +1 -0
  196. package/lib-es/tlv.d.ts +99 -0
  197. package/lib-es/tlv.d.ts.map +1 -0
  198. package/lib-es/tlv.js +144 -0
  199. package/lib-es/tlv.js.map +1 -0
  200. package/package.json +63 -0
  201. package/src/ApduDevice.ts +692 -0
  202. package/src/BigEndian.ts +25 -0
  203. package/src/CommandBlock.ts +247 -0
  204. package/src/CommandStream.ts +262 -0
  205. package/src/CommandStreamDecoder.ts +142 -0
  206. package/src/CommandStreamEncoder.ts +144 -0
  207. package/src/CommandStreamJsonifier.ts +82 -0
  208. package/src/CommandStreamResolver.ts +284 -0
  209. package/src/Crypto.ts +78 -0
  210. package/src/Device.ts +254 -0
  211. package/src/IndexedTree.ts +80 -0
  212. package/src/NobleCrypto.ts +294 -0
  213. package/src/PublicKey.ts +6 -0
  214. package/src/SeedId.ts +338 -0
  215. package/src/StreamTree.ts +212 -0
  216. package/src/StreamTreeCipher.ts +207 -0
  217. package/src/__tests__/codec.ts +146 -0
  218. package/src/__tests__/crypto.ts +44 -0
  219. package/src/__tests__/indexed_tree.ts +51 -0
  220. package/src/__tests__/key_exchange.ts +167 -0
  221. package/src/__tests__/seedId.ts +120 -0
  222. package/src/__tests__/shared_object.ts +118 -0
  223. package/src/index.ts +43 -0
  224. package/src/tlv.ts +210 -0
  225. package/tsconfig.json +14 -0
@@ -0,0 +1,101 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.CommandStreamDecoder = exports.TLVCommandStreamDecoder = void 0;
4
+ const CommandBlock_1 = require("./CommandBlock");
5
+ const tlv_1 = require("./tlv");
6
+ exports.TLVCommandStreamDecoder = {
7
+ // Read command from TLV
8
+ readCommand: function (tlv) {
9
+ switch (tlv.type) {
10
+ case CommandBlock_1.CommandType.Seed:
11
+ return exports.TLVCommandStreamDecoder.readSeedCommand(tlv.value);
12
+ case CommandBlock_1.CommandType.Derive:
13
+ return exports.TLVCommandStreamDecoder.readDeriveCommand(tlv.value);
14
+ case CommandBlock_1.CommandType.AddMember:
15
+ return exports.TLVCommandStreamDecoder.readAddMemberCommand(tlv.value);
16
+ case CommandBlock_1.CommandType.PublishKey:
17
+ return exports.TLVCommandStreamDecoder.readPublishKeyCommand(tlv.value);
18
+ case CommandBlock_1.CommandType.EditMember:
19
+ return exports.TLVCommandStreamDecoder.readEditMemberCommand(tlv.value);
20
+ case CommandBlock_1.CommandType.CloseStream:
21
+ return exports.TLVCommandStreamDecoder.readCloseStreamCommand(tlv.value);
22
+ default:
23
+ throw new Error("Unknown command type");
24
+ }
25
+ },
26
+ readSeedCommand: function (buffer) {
27
+ const readTopic = tlv_1.TLV.readNullOr(tlv_1.TLV.readTLV(buffer, 0), tlv_1.TLV.readBytes);
28
+ const readProtocolVersion = tlv_1.TLV.readVarInt(tlv_1.TLV.readTLV(buffer, readTopic.offset));
29
+ const readGroupKey = tlv_1.TLV.readPublicKey(tlv_1.TLV.readTLV(buffer, readProtocolVersion.offset));
30
+ const readIV = tlv_1.TLV.readBytes(tlv_1.TLV.readTLV(buffer, readGroupKey.offset));
31
+ const readEncryptedXpriv = tlv_1.TLV.readBytes(tlv_1.TLV.readTLV(buffer, readIV.offset));
32
+ const readEphemeralPublicKey = tlv_1.TLV.readPublicKey(tlv_1.TLV.readTLV(buffer, readEncryptedXpriv.offset));
33
+ return new CommandBlock_1.Seed(readTopic.value, readProtocolVersion.value, readGroupKey.value, readIV.value, readEncryptedXpriv.value, readEphemeralPublicKey.value);
34
+ },
35
+ readDeriveCommand: function (buffer) {
36
+ const readPath = tlv_1.TLV.readDerivationPath(tlv_1.TLV.readTLV(buffer, 0));
37
+ const readGroupKey = tlv_1.TLV.readPublicKey(tlv_1.TLV.readTLV(buffer, readPath.offset));
38
+ const readIV = tlv_1.TLV.readBytes(tlv_1.TLV.readTLV(buffer, readGroupKey.offset));
39
+ const readEncryptedXpriv = tlv_1.TLV.readBytes(tlv_1.TLV.readTLV(buffer, readIV.offset));
40
+ const readEphemeralPublicKey = tlv_1.TLV.readPublicKey(tlv_1.TLV.readTLV(buffer, readEncryptedXpriv.offset));
41
+ return new CommandBlock_1.Derive(readPath.value, readGroupKey.value, readIV.value, readEncryptedXpriv.value, readEphemeralPublicKey.value);
42
+ },
43
+ readAddMemberCommand: function (buffer) {
44
+ const readName = tlv_1.TLV.readString(tlv_1.TLV.readTLV(buffer, 0));
45
+ const pubkey = tlv_1.TLV.readPublicKey(tlv_1.TLV.readTLV(buffer, readName.offset));
46
+ const permissions = tlv_1.TLV.readVarInt(tlv_1.TLV.readTLV(buffer, pubkey.offset));
47
+ return new CommandBlock_1.AddMember(readName.value, pubkey.value, permissions.value);
48
+ },
49
+ readPublishKeyCommand: function (buffer) {
50
+ const IV = tlv_1.TLV.readBytes(tlv_1.TLV.readTLV(buffer, 0));
51
+ const encryptedXpriv = tlv_1.TLV.readBytes(tlv_1.TLV.readTLV(buffer, IV.offset));
52
+ const recipient = tlv_1.TLV.readPublicKey(tlv_1.TLV.readTLV(buffer, encryptedXpriv.offset));
53
+ const ephemeralPublicKey = tlv_1.TLV.readPublicKey(tlv_1.TLV.readTLV(buffer, recipient.offset));
54
+ return new CommandBlock_1.PublishKey(IV.value, encryptedXpriv.value, recipient.value, ephemeralPublicKey.value);
55
+ },
56
+ readCloseStreamCommand: function (buffer) {
57
+ buffer;
58
+ return new CommandBlock_1.CloseStream();
59
+ },
60
+ readEditMemberCommand: function (buffer) {
61
+ const member = tlv_1.TLV.readPublicKey(tlv_1.TLV.readTLV(buffer, 0));
62
+ const permissions = tlv_1.TLV.readNullOr(tlv_1.TLV.readTLV(buffer, member.offset), tlv_1.TLV.readVarInt);
63
+ const name = tlv_1.TLV.readNullOr(tlv_1.TLV.readTLV(buffer, permissions.offset), tlv_1.TLV.readString);
64
+ return new CommandBlock_1.EditMember(member.value, name.value, permissions.value);
65
+ },
66
+ };
67
+ function unpack(buffer) {
68
+ const stream = [];
69
+ let offset = 0;
70
+ while (offset < buffer.length) {
71
+ const version = tlv_1.TLV.readVarInt(tlv_1.TLV.readTLV(buffer, offset));
72
+ const parent = tlv_1.TLV.readHash(tlv_1.TLV.readTLV(buffer, version.offset));
73
+ const issuer = tlv_1.TLV.readPublicKey(tlv_1.TLV.readTLV(buffer, parent.offset));
74
+ const length = tlv_1.TLV.readVarInt(tlv_1.TLV.readTLV(buffer, issuer.offset));
75
+ offset = length.offset;
76
+ const commands = [];
77
+ for (let index = 0; index < length.value; index++) {
78
+ const commandBuffer = tlv_1.TLV.readTLV(buffer, offset);
79
+ const command = exports.TLVCommandStreamDecoder.readCommand(commandBuffer.tlv);
80
+ commands.push(command);
81
+ offset = commandBuffer.offset;
82
+ }
83
+ const signature = tlv_1.TLV.readSignature(tlv_1.TLV.readTLV(buffer, offset));
84
+ offset = signature.offset;
85
+ stream.push({
86
+ version: version.value,
87
+ parent: parent.value,
88
+ issuer: issuer.value,
89
+ commands,
90
+ signature: signature.value,
91
+ });
92
+ }
93
+ return stream;
94
+ }
95
+ class CommandStreamDecoder {
96
+ static decode(buffer) {
97
+ return unpack(buffer);
98
+ }
99
+ }
100
+ exports.CommandStreamDecoder = CommandStreamDecoder;
101
+ //# sourceMappingURL=CommandStreamDecoder.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CommandStreamDecoder.js","sourceRoot":"","sources":["../src/CommandStreamDecoder.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,16 @@
1
+ import { CommandBlock, Derive, Seed, AddMember, CloseStream, PublishKey, EditMember } from "./CommandBlock";
2
+ export declare const TLVCommandStreamEncoder: {
3
+ packSeed: (b: Seed) => Uint8Array;
4
+ packDerive: (b: Derive) => Uint8Array;
5
+ packAddMember: (b: AddMember) => Uint8Array;
6
+ packPublishKey: (b: PublishKey) => Uint8Array;
7
+ packCloseStream: (b: CloseStream) => Uint8Array;
8
+ packEditMember: (b: EditMember) => Uint8Array;
9
+ };
10
+ export declare class CommandStreamEncoder {
11
+ static encode(stream: CommandBlock[]): Uint8Array;
12
+ static encodeBlockHeader(block: CommandBlock): Uint8Array;
13
+ static encodeCommand(block: CommandBlock, index: number): Uint8Array;
14
+ static encodeSignature(block: CommandBlock): Uint8Array;
15
+ }
16
+ //# sourceMappingURL=CommandStreamEncoder.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CommandStreamEncoder.d.ts","sourceRoot":"","sources":["../src/CommandStreamEncoder.ts"],"names":[],"mappings":"AACA,OAAO,EACL,YAAY,EAGZ,MAAM,EACN,IAAI,EACJ,SAAS,EACT,WAAW,EACX,UAAU,EACV,UAAU,EACX,MAAM,gBAAgB,CAAC;AAExB,eAAO,MAAM,uBAAuB;kBACX,IAAI,KAAG,UAAU;oBAef,MAAM,KAAG,UAAU;uBAUhB,SAAS,KAAG,UAAU;wBAQrB,UAAU,KAAG,UAAU;yBAStB,WAAW,KAAG,UAAU;wBAKzB,UAAU,KAAG,UAAU;CAerD,CAAC;AA4BF,qBAAa,oBAAoB;WACjB,MAAM,CAAC,MAAM,EAAE,YAAY,EAAE,GAAG,UAAU;WAI1C,iBAAiB,CAAC,KAAK,EAAE,YAAY,GAAG,UAAU;WASlD,aAAa,CAAC,KAAK,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,GAAG,UAAU;WAS7D,eAAe,CAAC,KAAK,EAAE,YAAY,GAAG,UAAU;CAI/D"}
@@ -0,0 +1,131 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.CommandStreamEncoder = exports.TLVCommandStreamEncoder = void 0;
4
+ const tlv_1 = require("./tlv");
5
+ const CommandBlock_1 = require("./CommandBlock");
6
+ exports.TLVCommandStreamEncoder = {
7
+ packSeed: function (b) {
8
+ let object = new Uint8Array();
9
+ if (b.topic) {
10
+ object = tlv_1.TLV.pushBytes(object, b.topic);
11
+ }
12
+ else {
13
+ object = tlv_1.TLV.pushBytes(object, new Uint8Array(0));
14
+ }
15
+ object = tlv_1.TLV.pushInt16(object, b.protocolVersion);
16
+ object = tlv_1.TLV.pushPublicKey(object, b.groupKey);
17
+ object = tlv_1.TLV.pushBytes(object, b.initializationVector);
18
+ object = tlv_1.TLV.pushBytes(object, b.encryptedXpriv);
19
+ object = tlv_1.TLV.pushPublicKey(object, b.ephemeralPublicKey);
20
+ return object;
21
+ },
22
+ packDerive: function (b) {
23
+ let object = new Uint8Array();
24
+ object = tlv_1.TLV.pushDerivationPath(object, b.path);
25
+ object = tlv_1.TLV.pushPublicKey(object, b.groupKey);
26
+ object = tlv_1.TLV.pushBytes(object, b.initializationVector);
27
+ object = tlv_1.TLV.pushBytes(object, b.encryptedXpriv);
28
+ object = tlv_1.TLV.pushPublicKey(object, b.ephemeralPublicKey);
29
+ return object;
30
+ },
31
+ packAddMember: function (b) {
32
+ let object = new Uint8Array();
33
+ object = tlv_1.TLV.pushString(object, b.name);
34
+ object = tlv_1.TLV.pushPublicKey(object, b.publicKey);
35
+ object = tlv_1.TLV.pushInt32(object, b.permissions);
36
+ return object;
37
+ },
38
+ packPublishKey: function (b) {
39
+ let object = new Uint8Array();
40
+ object = tlv_1.TLV.pushBytes(object, b.initializationVector);
41
+ object = tlv_1.TLV.pushBytes(object, b.encryptedXpriv);
42
+ object = tlv_1.TLV.pushPublicKey(object, b.recipient);
43
+ object = tlv_1.TLV.pushPublicKey(object, b.ephemeralPublicKey);
44
+ return object;
45
+ },
46
+ packCloseStream: function (b) {
47
+ b;
48
+ return new Uint8Array();
49
+ },
50
+ packEditMember: function (b) {
51
+ let object = new Uint8Array();
52
+ object = tlv_1.TLV.pushPublicKey(object, b.member);
53
+ if (b.permissions) {
54
+ object = tlv_1.TLV.pushInt32(object, b.permissions);
55
+ }
56
+ else {
57
+ object = tlv_1.TLV.pushNull(object);
58
+ }
59
+ if (b.name) {
60
+ object = tlv_1.TLV.pushString(object, b.name);
61
+ }
62
+ else {
63
+ object = tlv_1.TLV.pushNull(object);
64
+ }
65
+ return object;
66
+ },
67
+ };
68
+ function packCommand(buffer, command) {
69
+ let object = new Uint8Array();
70
+ switch (command.getType()) {
71
+ case CommandBlock_1.CommandType.Seed:
72
+ object = exports.TLVCommandStreamEncoder.packSeed(command);
73
+ break;
74
+ case CommandBlock_1.CommandType.Derive:
75
+ object = exports.TLVCommandStreamEncoder.packDerive(command);
76
+ break;
77
+ case CommandBlock_1.CommandType.AddMember:
78
+ object = exports.TLVCommandStreamEncoder.packAddMember(command);
79
+ break;
80
+ case CommandBlock_1.CommandType.PublishKey:
81
+ object = exports.TLVCommandStreamEncoder.packPublishKey(command);
82
+ break;
83
+ case CommandBlock_1.CommandType.CloseStream:
84
+ object = exports.TLVCommandStreamEncoder.packCloseStream(command);
85
+ break;
86
+ case CommandBlock_1.CommandType.EditMember:
87
+ object = exports.TLVCommandStreamEncoder.packEditMember(command);
88
+ break;
89
+ }
90
+ buffer = tlv_1.TLV.pushTLV(buffer, command.getType(), object.length, object);
91
+ return buffer;
92
+ }
93
+ class CommandStreamEncoder {
94
+ static encode(stream) {
95
+ return pack(stream);
96
+ }
97
+ static encodeBlockHeader(block) {
98
+ let buffer = new Uint8Array();
99
+ buffer = tlv_1.TLV.pushByte(buffer, block.version);
100
+ buffer = tlv_1.TLV.pushHash(buffer, block.parent);
101
+ buffer = tlv_1.TLV.pushPublicKey(buffer, block.issuer);
102
+ buffer = tlv_1.TLV.pushByte(buffer, block.commands.length);
103
+ return buffer;
104
+ }
105
+ static encodeCommand(block, index) {
106
+ if (index >= block.commands.length || index < 0) {
107
+ throw new Error("Index out of range");
108
+ }
109
+ let buffer = new Uint8Array();
110
+ buffer = packCommand(buffer, block.commands[index]);
111
+ return buffer;
112
+ }
113
+ static encodeSignature(block) {
114
+ if (block.signature.length === 0)
115
+ return new Uint8Array();
116
+ return tlv_1.TLV.pushSignature(new Uint8Array(), block.signature);
117
+ }
118
+ }
119
+ exports.CommandStreamEncoder = CommandStreamEncoder;
120
+ function pack(stream) {
121
+ let buffer = new Uint8Array();
122
+ for (const block of stream) {
123
+ buffer = tlv_1.TLV.push(buffer, CommandStreamEncoder.encodeBlockHeader(block));
124
+ for (let index = 0; index < block.commands.length; index++) {
125
+ buffer = tlv_1.TLV.push(buffer, CommandStreamEncoder.encodeCommand(block, index));
126
+ }
127
+ buffer = tlv_1.TLV.push(buffer, CommandStreamEncoder.encodeSignature(block));
128
+ }
129
+ return buffer;
130
+ }
131
+ //# sourceMappingURL=CommandStreamEncoder.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CommandStreamEncoder.js","sourceRoot":"","sources":["../src/CommandStreamEncoder.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ import { CommandBlock } from "./CommandBlock";
2
+ export default class CommandStreamJsonifier {
3
+ private static jsonifyCommand;
4
+ static jsonify(stream: CommandBlock[]): object;
5
+ }
6
+ //# sourceMappingURL=CommandStreamJsonifier.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CommandStreamJsonifier.d.ts","sourceRoot":"","sources":["../src/CommandStreamJsonifier.ts"],"names":[],"mappings":"AACA,OAAO,EAEL,YAAY,EAOb,MAAM,gBAAgB,CAAC;AAKxB,MAAM,CAAC,OAAO,OAAO,sBAAsB;IACzC,OAAO,CAAC,MAAM,CAAC,cAAc;WAiDf,OAAO,CAAC,MAAM,EAAE,YAAY,EAAE,GAAG,MAAM;CAgBtD"}
@@ -0,0 +1,75 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const NobleCrypto_1 = require("./NobleCrypto");
4
+ const CommandBlock_1 = require("./CommandBlock");
5
+ const Crypto_1 = require("./Crypto");
6
+ const CommandStreamEncoder_1 = require("./CommandStreamEncoder");
7
+ const crypto_1 = require("crypto");
8
+ class CommandStreamJsonifier {
9
+ static jsonifyCommand(command) {
10
+ switch (command.getType()) {
11
+ case CommandBlock_1.CommandType.Seed:
12
+ return {
13
+ type: "Seed",
14
+ topic: (0, NobleCrypto_1.to_hex)(command.topic),
15
+ groupKey: (0, NobleCrypto_1.to_hex)(command.groupKey),
16
+ encryptedXpriv: (0, NobleCrypto_1.to_hex)(command.encryptedXpriv),
17
+ ephemeralPublicKey: (0, NobleCrypto_1.to_hex)(command.ephemeralPublicKey),
18
+ initializationVector: (0, NobleCrypto_1.to_hex)(command.initializationVector),
19
+ };
20
+ case CommandBlock_1.CommandType.AddMember:
21
+ return {
22
+ type: "AddMember",
23
+ name: command.name,
24
+ publicKey: (0, NobleCrypto_1.to_hex)(command.publicKey),
25
+ permissions: command.permissions,
26
+ };
27
+ case CommandBlock_1.CommandType.EditMember:
28
+ return {
29
+ type: "EditMember",
30
+ member: (0, NobleCrypto_1.to_hex)(command.member),
31
+ name: command.name,
32
+ permissions: command.permissions,
33
+ };
34
+ case CommandBlock_1.CommandType.Derive:
35
+ return {
36
+ type: "Derive",
37
+ path: Crypto_1.DerivationPath.toString(command.path),
38
+ groupKey: (0, NobleCrypto_1.to_hex)(command.groupKey),
39
+ encryptedXpriv: (0, NobleCrypto_1.to_hex)(command.encryptedXpriv),
40
+ ephemeralPublicKey: (0, NobleCrypto_1.to_hex)(command.ephemeralPublicKey),
41
+ initializationVector: (0, NobleCrypto_1.to_hex)(command.initializationVector),
42
+ };
43
+ case CommandBlock_1.CommandType.CloseStream:
44
+ return {
45
+ type: "CloseStream",
46
+ };
47
+ case CommandBlock_1.CommandType.PublishKey:
48
+ return {
49
+ type: "PublishKey",
50
+ encryptedXpriv: (0, NobleCrypto_1.to_hex)(command.encryptedXpriv),
51
+ initializationVector: (0, NobleCrypto_1.to_hex)(command.initializationVector),
52
+ ephemeralPublicKey: (0, NobleCrypto_1.to_hex)(command.ephemeralPublicKey),
53
+ recipient: (0, NobleCrypto_1.to_hex)(command.recipient),
54
+ };
55
+ }
56
+ }
57
+ static jsonify(stream) {
58
+ return stream.map(block => {
59
+ const b = CommandStreamEncoder_1.CommandStreamEncoder.encode([block]);
60
+ const h = (0, crypto_1.createHash)("sha256");
61
+ h.update(b);
62
+ return {
63
+ parent: (0, NobleCrypto_1.to_hex)(block.parent),
64
+ issuer: (0, NobleCrypto_1.to_hex)(block.issuer),
65
+ hash: h.digest().toString("hex"),
66
+ command: block.commands.map(command => {
67
+ return CommandStreamJsonifier.jsonifyCommand(command);
68
+ }),
69
+ signature: (0, NobleCrypto_1.to_hex)(block.signature),
70
+ };
71
+ });
72
+ }
73
+ }
74
+ exports.default = CommandStreamJsonifier;
75
+ //# sourceMappingURL=CommandStreamJsonifier.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CommandStreamJsonifier.js","sourceRoot":"","sources":["../src/CommandStreamJsonifier.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,53 @@
1
+ import { CommandBlock } from "./CommandBlock";
2
+ interface PublishedKey {
3
+ encryptedXpriv: Uint8Array;
4
+ ephemeralPublicKey: Uint8Array;
5
+ issuer: Uint8Array;
6
+ initialiationVector: Uint8Array;
7
+ }
8
+ type MemberData = {
9
+ id: string;
10
+ name: string;
11
+ permissions: number;
12
+ };
13
+ declare class ResolvedCommandStreamInternals {
14
+ isCreated: boolean;
15
+ members: Uint8Array[];
16
+ membersData: MemberData[];
17
+ topic: Uint8Array | null;
18
+ keys: Map<string, PublishedKey>;
19
+ permission: Map<string, number>;
20
+ height: number;
21
+ streamId: string;
22
+ hashes: string[];
23
+ names: Map<string, string>;
24
+ groupPublicKey: Uint8Array;
25
+ derivationPath: number[];
26
+ }
27
+ export declare class ResolvedCommandStream {
28
+ private _internals;
29
+ constructor(internals: ResolvedCommandStreamInternals);
30
+ isCreated(): boolean;
31
+ getMembers(): Uint8Array[];
32
+ getMembersData(): MemberData[];
33
+ getTopic(): Uint8Array | null;
34
+ isOwner(publicKey: Uint8Array): boolean;
35
+ isKeyCreator(publicKey: Uint8Array): boolean;
36
+ ownsKey(publicKey: Uint8Array): boolean;
37
+ isMemberAdder(publicKey: Uint8Array): boolean;
38
+ isMemberRemover(publicKey: Uint8Array): boolean;
39
+ keyCount(): number;
40
+ getEncryptedKey(publicKey: Uint8Array): PublishedKey | null;
41
+ getGroupPublicKey(): Uint8Array;
42
+ getStreamDerivationPath(): number[];
43
+ }
44
+ export default class CommandStreamResolver {
45
+ private static assertIssuerCanPublish;
46
+ private static assertIssuerCanAddMember;
47
+ private static assertStreamIsCreated;
48
+ private static replayCommand;
49
+ private static resolveBlock;
50
+ static resolve(stream: CommandBlock[]): Promise<ResolvedCommandStream>;
51
+ }
52
+ export {};
53
+ //# sourceMappingURL=CommandStreamResolver.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CommandStreamResolver.d.ts","sourceRoot":"","sources":["../src/CommandStreamResolver.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,YAAY,EAUb,MAAM,gBAAgB,CAAC;AAGxB,UAAU,YAAY;IACpB,cAAc,EAAE,UAAU,CAAC;IAC3B,kBAAkB,EAAE,UAAU,CAAC;IAC/B,MAAM,EAAE,UAAU,CAAC;IACnB,mBAAmB,EAAE,UAAU,CAAC;CACjC;AAED,KAAK,UAAU,GAAG;IAChB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;CACrB,CAAC;AAEF,cAAM,8BAA8B;IAC3B,SAAS,EAAE,OAAO,CAAS;IAC3B,OAAO,EAAE,UAAU,EAAE,CAAM;IAC3B,WAAW,EAAE,UAAU,EAAE,CAAM;IAC/B,KAAK,EAAE,UAAU,GAAG,IAAI,CAAQ;IAChC,IAAI,EAAE,GAAG,CAAC,MAAM,EAAE,YAAY,CAAC,CAAa;IAC5C,UAAU,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAa;IAC5C,MAAM,EAAE,MAAM,CAAK;IACnB,QAAQ,EAAE,MAAM,CAAM;IACtB,MAAM,EAAE,MAAM,EAAE,CAAM;IACtB,KAAK,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAa;IACvC,cAAc,EAAE,UAAU,CAAoB;IAC9C,cAAc,EAAE,MAAM,EAAE,CAAM;CACtC;AAED,qBAAa,qBAAqB;IAChC,OAAO,CAAC,UAAU,CAAiC;gBAEvC,SAAS,EAAE,8BAA8B;IAI9C,SAAS,IAAI,OAAO;IAIpB,UAAU,IAAI,UAAU,EAAE;IAI1B,cAAc,IAAI,UAAU,EAAE;IAI9B,QAAQ,IAAI,UAAU,GAAG,IAAI;IAI7B,OAAO,CAAC,SAAS,EAAE,UAAU,GAAG,OAAO;IAIvC,YAAY,CAAC,SAAS,EAAE,UAAU,GAAG,OAAO;IAO5C,OAAO,CAAC,SAAS,EAAE,UAAU,GAAG,OAAO;IAIvC,aAAa,CAAC,SAAS,EAAE,UAAU,GAAG,OAAO;IAO7C,eAAe,CAAC,SAAS,EAAE,UAAU,GAAG,OAAO;IAO/C,QAAQ,IAAI,MAAM;IAIlB,eAAe,CAAC,SAAS,EAAE,UAAU,GAAG,YAAY,GAAG,IAAI;IAM3D,iBAAiB,IAAI,UAAU;IAI/B,uBAAuB,IAAI,MAAM,EAAE;CAG3C;AAiBD,MAAM,CAAC,OAAO,OAAO,qBAAqB;IACxC,OAAO,CAAC,MAAM,CAAC,sBAAsB;IA6BrC,OAAO,CAAC,MAAM,CAAC,wBAAwB;IAiBvC,OAAO,CAAC,MAAM,CAAC,qBAAqB;IAMpC,OAAO,CAAC,MAAM,CAAC,aAAa;mBA6DP,YAAY;WAuBb,OAAO,CAAC,MAAM,EAAE,YAAY,EAAE,GAAG,OAAO,CAAC,qBAAqB,CAAC;CAkBpF"}
@@ -0,0 +1,221 @@
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
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.ResolvedCommandStream = void 0;
13
+ const CommandBlock_1 = require("./CommandBlock");
14
+ const Crypto_1 = require("./Crypto");
15
+ class ResolvedCommandStreamInternals {
16
+ constructor() {
17
+ this.isCreated = false;
18
+ this.members = [];
19
+ this.membersData = [];
20
+ this.topic = null;
21
+ this.keys = new Map();
22
+ this.permission = new Map();
23
+ this.height = 0;
24
+ this.streamId = "";
25
+ this.hashes = [];
26
+ this.names = new Map();
27
+ this.groupPublicKey = new Uint8Array();
28
+ this.derivationPath = [];
29
+ }
30
+ }
31
+ class ResolvedCommandStream {
32
+ constructor(internals) {
33
+ this._internals = internals;
34
+ }
35
+ isCreated() {
36
+ return this._internals.isCreated;
37
+ }
38
+ getMembers() {
39
+ return this._internals.members;
40
+ }
41
+ getMembersData() {
42
+ return this._internals.membersData;
43
+ }
44
+ getTopic() {
45
+ return this._internals.topic;
46
+ }
47
+ isOwner(publicKey) {
48
+ return this._internals.permission.get(Crypto_1.crypto.to_hex(publicKey)) === CommandBlock_1.Permissions.OWNER;
49
+ }
50
+ isKeyCreator(publicKey) {
51
+ return ((this._internals.permission.get(Crypto_1.crypto.to_hex(publicKey)) & CommandBlock_1.Permissions.KEY_CREATOR) ===
52
+ CommandBlock_1.Permissions.KEY_CREATOR);
53
+ }
54
+ ownsKey(publicKey) {
55
+ return this._internals.keys.get(Crypto_1.crypto.to_hex(publicKey)) !== undefined;
56
+ }
57
+ isMemberAdder(publicKey) {
58
+ return ((this._internals.permission.get(Crypto_1.crypto.to_hex(publicKey)) & CommandBlock_1.Permissions.ADD_MEMBER) ===
59
+ CommandBlock_1.Permissions.ADD_MEMBER);
60
+ }
61
+ isMemberRemover(publicKey) {
62
+ return ((this._internals.permission.get(Crypto_1.crypto.to_hex(publicKey)) & CommandBlock_1.Permissions.REMOVE_MEMBER) ===
63
+ CommandBlock_1.Permissions.REMOVE_MEMBER);
64
+ }
65
+ keyCount() {
66
+ return this._internals.keys.size;
67
+ }
68
+ getEncryptedKey(publicKey) {
69
+ const key = this._internals.keys.get(Crypto_1.crypto.to_hex(publicKey));
70
+ if (key)
71
+ return key;
72
+ return null;
73
+ }
74
+ getGroupPublicKey() {
75
+ return this._internals.groupPublicKey;
76
+ }
77
+ getStreamDerivationPath() {
78
+ return this._internals.derivationPath;
79
+ }
80
+ }
81
+ exports.ResolvedCommandStream = ResolvedCommandStream;
82
+ function exists(list, obj) {
83
+ for (const item of list) {
84
+ if (obj.length !== item.length) {
85
+ continue;
86
+ }
87
+ for (let i = 0; i < item.length; i++) {
88
+ if (item[i] !== obj[i]) {
89
+ continue;
90
+ }
91
+ }
92
+ return true;
93
+ }
94
+ return false;
95
+ }
96
+ class CommandStreamResolver {
97
+ static assertIssuerCanPublish(issuer, internals) {
98
+ if (!exists(internals.members, issuer)) {
99
+ throw new Error("Issuer is not a member of the group at height " + internals.height);
100
+ }
101
+ if ((internals.permission.get(Crypto_1.crypto.to_hex(issuer)) & 0x02) === CommandBlock_1.Permissions.KEY_READER) {
102
+ throw new Error("Issuer does not have permission to publish keys at height " + internals.height);
103
+ }
104
+ if (internals.keys.get(Crypto_1.crypto.to_hex(issuer)) === undefined &&
105
+ (internals.permission.get(Crypto_1.crypto.to_hex(issuer)) & CommandBlock_1.Permissions.KEY_CREATOR) !=
106
+ CommandBlock_1.Permissions.KEY_CREATOR) {
107
+ throw new Error("Issuer does not have a key to publish at height " + internals.height);
108
+ }
109
+ if (!internals.keys.has(Crypto_1.crypto.to_hex(issuer)) &&
110
+ (internals.permission.get(Crypto_1.crypto.to_hex(issuer)) & CommandBlock_1.Permissions.KEY_CREATOR) !==
111
+ CommandBlock_1.Permissions.KEY_CREATOR &&
112
+ internals.keys.keys.length > 0) {
113
+ throw new Error("Issuer is trying to publish a new key at height " + internals.height);
114
+ }
115
+ }
116
+ static assertIssuerCanAddMember(issuer, internals) {
117
+ if (!exists(internals.members, issuer)) {
118
+ throw new Error("Issuer is not a member of the group at height " + internals.height);
119
+ }
120
+ if ((internals.permission.get(Crypto_1.crypto.to_hex(issuer)) & CommandBlock_1.Permissions.ADD_MEMBER) !==
121
+ CommandBlock_1.Permissions.ADD_MEMBER) {
122
+ throw new Error("Issuer does not have permission to add members at height " + internals.height);
123
+ }
124
+ }
125
+ static assertStreamIsCreated(internals) {
126
+ if (internals.isCreated === false) {
127
+ throw new Error("The stream is not created at height " + internals.height);
128
+ }
129
+ }
130
+ static replayCommand(command, block, blockHash, height, internals) {
131
+ switch (command.getType()) {
132
+ case CommandBlock_1.CommandType.Seed:
133
+ internals.isCreated = true;
134
+ internals.topic = command.topic;
135
+ internals.members.push(block.issuer);
136
+ internals.permission.set(Crypto_1.crypto.to_hex(block.issuer), CommandBlock_1.Permissions.OWNER);
137
+ internals.streamId = blockHash;
138
+ internals.keys.set(Crypto_1.crypto.to_hex(block.issuer), {
139
+ encryptedXpriv: command.encryptedXpriv,
140
+ issuer: block.issuer,
141
+ ephemeralPublicKey: command.ephemeralPublicKey,
142
+ initialiationVector: command.initializationVector,
143
+ });
144
+ internals.groupPublicKey = command.groupKey;
145
+ break;
146
+ case CommandBlock_1.CommandType.Derive:
147
+ internals.isCreated = true;
148
+ internals.members.push(block.issuer);
149
+ internals.permission.set(Crypto_1.crypto.to_hex(block.issuer), CommandBlock_1.Permissions.OWNER);
150
+ internals.streamId = blockHash;
151
+ internals.keys.set(Crypto_1.crypto.to_hex(block.issuer), {
152
+ encryptedXpriv: command.encryptedXpriv,
153
+ ephemeralPublicKey: command.ephemeralPublicKey,
154
+ initialiationVector: command.initializationVector,
155
+ issuer: block.issuer,
156
+ });
157
+ internals.groupPublicKey = command.groupKey;
158
+ internals.derivationPath = command.path;
159
+ break;
160
+ case CommandBlock_1.CommandType.AddMember: {
161
+ this.assertStreamIsCreated(internals);
162
+ this.assertIssuerCanAddMember(block.issuer, internals);
163
+ const { publicKey, permissions, name } = command;
164
+ const id = Crypto_1.crypto.to_hex(publicKey);
165
+ internals.members.push(publicKey);
166
+ internals.permission.set(id, permissions);
167
+ internals.names.set(id, name);
168
+ internals.membersData.push({ id, name, permissions });
169
+ break;
170
+ }
171
+ case CommandBlock_1.CommandType.PublishKey:
172
+ this.assertStreamIsCreated(internals);
173
+ this.assertIssuerCanPublish(block.issuer, internals);
174
+ internals.keys.set(Crypto_1.crypto.to_hex(command.recipient), {
175
+ encryptedXpriv: command.encryptedXpriv,
176
+ ephemeralPublicKey: command.ephemeralPublicKey,
177
+ issuer: block.issuer,
178
+ initialiationVector: command.initializationVector,
179
+ });
180
+ break;
181
+ }
182
+ return internals;
183
+ }
184
+ static resolveBlock(block, height, internals) {
185
+ return __awaiter(this, void 0, void 0, function* () {
186
+ // Check signature
187
+ if ((yield (0, CommandBlock_1.verifyCommandBlock)(block)) === false) {
188
+ throw new Error("Invalid block signature at height " + height);
189
+ }
190
+ // Check if issuer is part of the group
191
+ if (height > 0 && !exists(internals.members, block.issuer)) {
192
+ throw new Error("Issuer is not part of the group at height " + height);
193
+ }
194
+ const blockHash = Crypto_1.crypto.to_hex(yield (0, CommandBlock_1.hashCommandBlock)(block));
195
+ for (const command of block.commands) {
196
+ internals = CommandStreamResolver.replayCommand(command, block, blockHash, height, internals);
197
+ }
198
+ internals.hashes.push(blockHash);
199
+ return internals;
200
+ });
201
+ }
202
+ static resolve(stream) {
203
+ return __awaiter(this, void 0, void 0, function* () {
204
+ let internals = new ResolvedCommandStreamInternals();
205
+ for (let height = 0; height < stream.length; height++) {
206
+ internals.height = height;
207
+ const block = stream[height];
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);
215
+ }
216
+ return new ResolvedCommandStream(internals);
217
+ });
218
+ }
219
+ }
220
+ exports.default = CommandStreamResolver;
221
+ //# sourceMappingURL=CommandStreamResolver.js.map