@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,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,127 @@
1
+ import { TLV } from "./tlv";
2
+ import { CommandType, } from "./CommandBlock";
3
+ export const TLVCommandStreamEncoder = {
4
+ packSeed: function (b) {
5
+ let object = new Uint8Array();
6
+ if (b.topic) {
7
+ object = TLV.pushBytes(object, b.topic);
8
+ }
9
+ else {
10
+ object = TLV.pushBytes(object, new Uint8Array(0));
11
+ }
12
+ object = TLV.pushInt16(object, b.protocolVersion);
13
+ object = TLV.pushPublicKey(object, b.groupKey);
14
+ object = TLV.pushBytes(object, b.initializationVector);
15
+ object = TLV.pushBytes(object, b.encryptedXpriv);
16
+ object = TLV.pushPublicKey(object, b.ephemeralPublicKey);
17
+ return object;
18
+ },
19
+ packDerive: function (b) {
20
+ let object = new Uint8Array();
21
+ object = TLV.pushDerivationPath(object, b.path);
22
+ object = TLV.pushPublicKey(object, b.groupKey);
23
+ object = TLV.pushBytes(object, b.initializationVector);
24
+ object = TLV.pushBytes(object, b.encryptedXpriv);
25
+ object = TLV.pushPublicKey(object, b.ephemeralPublicKey);
26
+ return object;
27
+ },
28
+ packAddMember: function (b) {
29
+ let object = new Uint8Array();
30
+ object = TLV.pushString(object, b.name);
31
+ object = TLV.pushPublicKey(object, b.publicKey);
32
+ object = TLV.pushInt32(object, b.permissions);
33
+ return object;
34
+ },
35
+ packPublishKey: function (b) {
36
+ let object = new Uint8Array();
37
+ object = TLV.pushBytes(object, b.initializationVector);
38
+ object = TLV.pushBytes(object, b.encryptedXpriv);
39
+ object = TLV.pushPublicKey(object, b.recipient);
40
+ object = TLV.pushPublicKey(object, b.ephemeralPublicKey);
41
+ return object;
42
+ },
43
+ packCloseStream: function (b) {
44
+ b;
45
+ return new Uint8Array();
46
+ },
47
+ packEditMember: function (b) {
48
+ let object = new Uint8Array();
49
+ object = TLV.pushPublicKey(object, b.member);
50
+ if (b.permissions) {
51
+ object = TLV.pushInt32(object, b.permissions);
52
+ }
53
+ else {
54
+ object = TLV.pushNull(object);
55
+ }
56
+ if (b.name) {
57
+ object = TLV.pushString(object, b.name);
58
+ }
59
+ else {
60
+ object = TLV.pushNull(object);
61
+ }
62
+ return object;
63
+ },
64
+ };
65
+ function packCommand(buffer, command) {
66
+ let object = new Uint8Array();
67
+ switch (command.getType()) {
68
+ case CommandType.Seed:
69
+ object = TLVCommandStreamEncoder.packSeed(command);
70
+ break;
71
+ case CommandType.Derive:
72
+ object = TLVCommandStreamEncoder.packDerive(command);
73
+ break;
74
+ case CommandType.AddMember:
75
+ object = TLVCommandStreamEncoder.packAddMember(command);
76
+ break;
77
+ case CommandType.PublishKey:
78
+ object = TLVCommandStreamEncoder.packPublishKey(command);
79
+ break;
80
+ case CommandType.CloseStream:
81
+ object = TLVCommandStreamEncoder.packCloseStream(command);
82
+ break;
83
+ case CommandType.EditMember:
84
+ object = TLVCommandStreamEncoder.packEditMember(command);
85
+ break;
86
+ }
87
+ buffer = TLV.pushTLV(buffer, command.getType(), object.length, object);
88
+ return buffer;
89
+ }
90
+ export class CommandStreamEncoder {
91
+ static encode(stream) {
92
+ return pack(stream);
93
+ }
94
+ static encodeBlockHeader(block) {
95
+ let buffer = new Uint8Array();
96
+ buffer = TLV.pushByte(buffer, block.version);
97
+ buffer = TLV.pushHash(buffer, block.parent);
98
+ buffer = TLV.pushPublicKey(buffer, block.issuer);
99
+ buffer = TLV.pushByte(buffer, block.commands.length);
100
+ return buffer;
101
+ }
102
+ static encodeCommand(block, index) {
103
+ if (index >= block.commands.length || index < 0) {
104
+ throw new Error("Index out of range");
105
+ }
106
+ let buffer = new Uint8Array();
107
+ buffer = packCommand(buffer, block.commands[index]);
108
+ return buffer;
109
+ }
110
+ static encodeSignature(block) {
111
+ if (block.signature.length === 0)
112
+ return new Uint8Array();
113
+ return TLV.pushSignature(new Uint8Array(), block.signature);
114
+ }
115
+ }
116
+ function pack(stream) {
117
+ let buffer = new Uint8Array();
118
+ for (const block of stream) {
119
+ buffer = TLV.push(buffer, CommandStreamEncoder.encodeBlockHeader(block));
120
+ for (let index = 0; index < block.commands.length; index++) {
121
+ buffer = TLV.push(buffer, CommandStreamEncoder.encodeCommand(block, index));
122
+ }
123
+ buffer = TLV.push(buffer, CommandStreamEncoder.encodeSignature(block));
124
+ }
125
+ return buffer;
126
+ }
127
+ //# 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,72 @@
1
+ import { to_hex } from "./NobleCrypto";
2
+ import { CommandType, } from "./CommandBlock";
3
+ import { DerivationPath } from "./Crypto";
4
+ import { CommandStreamEncoder } from "./CommandStreamEncoder";
5
+ import { createHash } from "crypto";
6
+ export default class CommandStreamJsonifier {
7
+ static jsonifyCommand(command) {
8
+ switch (command.getType()) {
9
+ case CommandType.Seed:
10
+ return {
11
+ type: "Seed",
12
+ topic: to_hex(command.topic),
13
+ groupKey: to_hex(command.groupKey),
14
+ encryptedXpriv: to_hex(command.encryptedXpriv),
15
+ ephemeralPublicKey: to_hex(command.ephemeralPublicKey),
16
+ initializationVector: to_hex(command.initializationVector),
17
+ };
18
+ case CommandType.AddMember:
19
+ return {
20
+ type: "AddMember",
21
+ name: command.name,
22
+ publicKey: to_hex(command.publicKey),
23
+ permissions: command.permissions,
24
+ };
25
+ case CommandType.EditMember:
26
+ return {
27
+ type: "EditMember",
28
+ member: to_hex(command.member),
29
+ name: command.name,
30
+ permissions: command.permissions,
31
+ };
32
+ case CommandType.Derive:
33
+ return {
34
+ type: "Derive",
35
+ path: DerivationPath.toString(command.path),
36
+ groupKey: to_hex(command.groupKey),
37
+ encryptedXpriv: to_hex(command.encryptedXpriv),
38
+ ephemeralPublicKey: to_hex(command.ephemeralPublicKey),
39
+ initializationVector: to_hex(command.initializationVector),
40
+ };
41
+ case CommandType.CloseStream:
42
+ return {
43
+ type: "CloseStream",
44
+ };
45
+ case CommandType.PublishKey:
46
+ return {
47
+ type: "PublishKey",
48
+ encryptedXpriv: to_hex(command.encryptedXpriv),
49
+ initializationVector: to_hex(command.initializationVector),
50
+ ephemeralPublicKey: to_hex(command.ephemeralPublicKey),
51
+ recipient: to_hex(command.recipient),
52
+ };
53
+ }
54
+ }
55
+ static jsonify(stream) {
56
+ return stream.map(block => {
57
+ const b = CommandStreamEncoder.encode([block]);
58
+ const h = createHash("sha256");
59
+ h.update(b);
60
+ return {
61
+ parent: to_hex(block.parent),
62
+ issuer: to_hex(block.issuer),
63
+ hash: h.digest().toString("hex"),
64
+ command: block.commands.map(command => {
65
+ return CommandStreamJsonifier.jsonifyCommand(command);
66
+ }),
67
+ signature: to_hex(block.signature),
68
+ };
69
+ });
70
+ }
71
+ }
72
+ //# 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,216 @@
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
+ import { verifyCommandBlock, CommandType, hashCommandBlock, Permissions, } from "./CommandBlock";
11
+ import { crypto } from "./Crypto";
12
+ class ResolvedCommandStreamInternals {
13
+ constructor() {
14
+ this.isCreated = false;
15
+ this.members = [];
16
+ this.membersData = [];
17
+ this.topic = null;
18
+ this.keys = new Map();
19
+ this.permission = new Map();
20
+ this.height = 0;
21
+ this.streamId = "";
22
+ this.hashes = [];
23
+ this.names = new Map();
24
+ this.groupPublicKey = new Uint8Array();
25
+ this.derivationPath = [];
26
+ }
27
+ }
28
+ export class ResolvedCommandStream {
29
+ constructor(internals) {
30
+ this._internals = internals;
31
+ }
32
+ isCreated() {
33
+ return this._internals.isCreated;
34
+ }
35
+ getMembers() {
36
+ return this._internals.members;
37
+ }
38
+ getMembersData() {
39
+ return this._internals.membersData;
40
+ }
41
+ getTopic() {
42
+ return this._internals.topic;
43
+ }
44
+ isOwner(publicKey) {
45
+ return this._internals.permission.get(crypto.to_hex(publicKey)) === Permissions.OWNER;
46
+ }
47
+ isKeyCreator(publicKey) {
48
+ return ((this._internals.permission.get(crypto.to_hex(publicKey)) & Permissions.KEY_CREATOR) ===
49
+ Permissions.KEY_CREATOR);
50
+ }
51
+ ownsKey(publicKey) {
52
+ return this._internals.keys.get(crypto.to_hex(publicKey)) !== undefined;
53
+ }
54
+ isMemberAdder(publicKey) {
55
+ return ((this._internals.permission.get(crypto.to_hex(publicKey)) & Permissions.ADD_MEMBER) ===
56
+ Permissions.ADD_MEMBER);
57
+ }
58
+ isMemberRemover(publicKey) {
59
+ return ((this._internals.permission.get(crypto.to_hex(publicKey)) & Permissions.REMOVE_MEMBER) ===
60
+ Permissions.REMOVE_MEMBER);
61
+ }
62
+ keyCount() {
63
+ return this._internals.keys.size;
64
+ }
65
+ getEncryptedKey(publicKey) {
66
+ const key = this._internals.keys.get(crypto.to_hex(publicKey));
67
+ if (key)
68
+ return key;
69
+ return null;
70
+ }
71
+ getGroupPublicKey() {
72
+ return this._internals.groupPublicKey;
73
+ }
74
+ getStreamDerivationPath() {
75
+ return this._internals.derivationPath;
76
+ }
77
+ }
78
+ function exists(list, obj) {
79
+ for (const item of list) {
80
+ if (obj.length !== item.length) {
81
+ continue;
82
+ }
83
+ for (let i = 0; i < item.length; i++) {
84
+ if (item[i] !== obj[i]) {
85
+ continue;
86
+ }
87
+ }
88
+ return true;
89
+ }
90
+ return false;
91
+ }
92
+ export default class CommandStreamResolver {
93
+ static assertIssuerCanPublish(issuer, internals) {
94
+ if (!exists(internals.members, issuer)) {
95
+ throw new Error("Issuer is not a member of the group at height " + internals.height);
96
+ }
97
+ if ((internals.permission.get(crypto.to_hex(issuer)) & 0x02) === Permissions.KEY_READER) {
98
+ throw new Error("Issuer does not have permission to publish keys at height " + internals.height);
99
+ }
100
+ if (internals.keys.get(crypto.to_hex(issuer)) === undefined &&
101
+ (internals.permission.get(crypto.to_hex(issuer)) & Permissions.KEY_CREATOR) !=
102
+ Permissions.KEY_CREATOR) {
103
+ throw new Error("Issuer does not have a key to publish at height " + internals.height);
104
+ }
105
+ if (!internals.keys.has(crypto.to_hex(issuer)) &&
106
+ (internals.permission.get(crypto.to_hex(issuer)) & Permissions.KEY_CREATOR) !==
107
+ Permissions.KEY_CREATOR &&
108
+ internals.keys.keys.length > 0) {
109
+ throw new Error("Issuer is trying to publish a new key at height " + internals.height);
110
+ }
111
+ }
112
+ static assertIssuerCanAddMember(issuer, internals) {
113
+ if (!exists(internals.members, issuer)) {
114
+ throw new Error("Issuer is not a member of the group at height " + internals.height);
115
+ }
116
+ if ((internals.permission.get(crypto.to_hex(issuer)) & Permissions.ADD_MEMBER) !==
117
+ Permissions.ADD_MEMBER) {
118
+ throw new Error("Issuer does not have permission to add members at height " + internals.height);
119
+ }
120
+ }
121
+ static assertStreamIsCreated(internals) {
122
+ if (internals.isCreated === false) {
123
+ throw new Error("The stream is not created at height " + internals.height);
124
+ }
125
+ }
126
+ static replayCommand(command, block, blockHash, height, internals) {
127
+ switch (command.getType()) {
128
+ case CommandType.Seed:
129
+ internals.isCreated = true;
130
+ internals.topic = command.topic;
131
+ internals.members.push(block.issuer);
132
+ internals.permission.set(crypto.to_hex(block.issuer), Permissions.OWNER);
133
+ internals.streamId = blockHash;
134
+ internals.keys.set(crypto.to_hex(block.issuer), {
135
+ encryptedXpriv: command.encryptedXpriv,
136
+ issuer: block.issuer,
137
+ ephemeralPublicKey: command.ephemeralPublicKey,
138
+ initialiationVector: command.initializationVector,
139
+ });
140
+ internals.groupPublicKey = command.groupKey;
141
+ break;
142
+ case CommandType.Derive:
143
+ internals.isCreated = true;
144
+ internals.members.push(block.issuer);
145
+ internals.permission.set(crypto.to_hex(block.issuer), Permissions.OWNER);
146
+ internals.streamId = blockHash;
147
+ internals.keys.set(crypto.to_hex(block.issuer), {
148
+ encryptedXpriv: command.encryptedXpriv,
149
+ ephemeralPublicKey: command.ephemeralPublicKey,
150
+ initialiationVector: command.initializationVector,
151
+ issuer: block.issuer,
152
+ });
153
+ internals.groupPublicKey = command.groupKey;
154
+ internals.derivationPath = command.path;
155
+ break;
156
+ case CommandType.AddMember: {
157
+ this.assertStreamIsCreated(internals);
158
+ this.assertIssuerCanAddMember(block.issuer, internals);
159
+ const { publicKey, permissions, name } = command;
160
+ const id = crypto.to_hex(publicKey);
161
+ internals.members.push(publicKey);
162
+ internals.permission.set(id, permissions);
163
+ internals.names.set(id, name);
164
+ internals.membersData.push({ id, name, permissions });
165
+ break;
166
+ }
167
+ case CommandType.PublishKey:
168
+ this.assertStreamIsCreated(internals);
169
+ this.assertIssuerCanPublish(block.issuer, internals);
170
+ internals.keys.set(crypto.to_hex(command.recipient), {
171
+ encryptedXpriv: command.encryptedXpriv,
172
+ ephemeralPublicKey: command.ephemeralPublicKey,
173
+ issuer: block.issuer,
174
+ initialiationVector: command.initializationVector,
175
+ });
176
+ break;
177
+ }
178
+ return internals;
179
+ }
180
+ static resolveBlock(block, height, internals) {
181
+ return __awaiter(this, void 0, void 0, function* () {
182
+ // Check signature
183
+ if ((yield verifyCommandBlock(block)) === false) {
184
+ throw new Error("Invalid block signature at height " + height);
185
+ }
186
+ // Check if issuer is part of the group
187
+ if (height > 0 && !exists(internals.members, block.issuer)) {
188
+ throw new Error("Issuer is not part of the group at height " + height);
189
+ }
190
+ const blockHash = crypto.to_hex(yield hashCommandBlock(block));
191
+ for (const command of block.commands) {
192
+ internals = CommandStreamResolver.replayCommand(command, block, blockHash, height, internals);
193
+ }
194
+ internals.hashes.push(blockHash);
195
+ return internals;
196
+ });
197
+ }
198
+ static resolve(stream) {
199
+ return __awaiter(this, void 0, void 0, function* () {
200
+ let internals = new ResolvedCommandStreamInternals();
201
+ for (let height = 0; height < stream.length; height++) {
202
+ internals.height = height;
203
+ const block = stream[height];
204
+ if (height > 0 &&
205
+ crypto.to_hex(block.parent) !== crypto.to_hex(yield hashCommandBlock(stream[height - 1]))) {
206
+ throw new Error("Command stream has been tampered with (invalid parent hash) at height " + height);
207
+ }
208
+ if (block.signature.length === 0)
209
+ break;
210
+ internals = yield CommandStreamResolver.resolveBlock(block, height, internals);
211
+ }
212
+ return new ResolvedCommandStream(internals);
213
+ });
214
+ }
215
+ }
216
+ //# sourceMappingURL=CommandStreamResolver.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CommandStreamResolver.js","sourceRoot":"","sources":["../src/CommandStreamResolver.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,38 @@
1
+ import { NobleCryptoSecp256k1 } from "./NobleCrypto";
2
+ export interface KeyPair {
3
+ publicKey: Uint8Array;
4
+ privateKey: Uint8Array;
5
+ }
6
+ export interface KeyPairWithChainCode extends KeyPair {
7
+ chainCode: Uint8Array;
8
+ }
9
+ /**
10
+ *
11
+ */
12
+ export interface Crypto {
13
+ randomKeypair(): Promise<KeyPair>;
14
+ keypairFromSecretKey(secretKey: Uint8Array): Promise<KeyPair>;
15
+ sign(message: Uint8Array, keyPair: KeyPair): Promise<Uint8Array>;
16
+ verify(message: Uint8Array, signature: Uint8Array, publicKey: Uint8Array): Promise<boolean>;
17
+ encrypt(secret: Uint8Array, nonce: Uint8Array, message: Uint8Array): Promise<Uint8Array>;
18
+ decrypt(secret: Uint8Array, nonce: Uint8Array, ciphertext: Uint8Array): Promise<Uint8Array>;
19
+ randomBytes(size: number): Promise<Uint8Array>;
20
+ ecdh(keyPair: KeyPair, publicKey: Uint8Array): Promise<Uint8Array>;
21
+ hash(message: Uint8Array): Promise<Uint8Array>;
22
+ computeSymmetricKey(privateKey: Uint8Array, extra: Uint8Array): Promise<Uint8Array>;
23
+ from_hex(hex: string): Uint8Array;
24
+ to_hex(bytes?: Uint8Array): string;
25
+ derivePrivate(xpriv: Uint8Array, path: number[]): Promise<KeyPairWithChainCode>;
26
+ }
27
+ export declare class DerivationPath {
28
+ private constructor();
29
+ static hardenedIndex(index: number): number;
30
+ static reverseHardenedIndex(index: number): number;
31
+ static toIndexArray(path: string | number[]): number[];
32
+ static toString(path: number[] | string): string;
33
+ }
34
+ /**
35
+ *
36
+ */
37
+ export declare const crypto: NobleCryptoSecp256k1;
38
+ //# sourceMappingURL=Crypto.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Crypto.d.ts","sourceRoot":"","sources":["../src/Crypto.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,eAAe,CAAC;AAErD,MAAM,WAAW,OAAO;IACtB,SAAS,EAAE,UAAU,CAAC;IACtB,UAAU,EAAE,UAAU,CAAC;CACxB;AAED,MAAM,WAAW,oBAAqB,SAAQ,OAAO;IACnD,SAAS,EAAE,UAAU,CAAC;CACvB;AAED;;GAEG;AACH,MAAM,WAAW,MAAM;IACrB,aAAa,IAAI,OAAO,CAAC,OAAO,CAAC,CAAC;IAClC,oBAAoB,CAAC,SAAS,EAAE,UAAU,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;IAC9D,IAAI,CAAC,OAAO,EAAE,UAAU,EAAE,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,UAAU,CAAC,CAAC;IACjE,MAAM,CAAC,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,UAAU,EAAE,SAAS,EAAE,UAAU,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;IAC5F,OAAO,CAAC,MAAM,EAAE,UAAU,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC,CAAC;IACzF,OAAO,CAAC,MAAM,EAAE,UAAU,EAAE,KAAK,EAAE,UAAU,EAAE,UAAU,EAAE,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC,CAAC;IAC5F,WAAW,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC,CAAC;IAC/C,IAAI,CAAC,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC,CAAC;IACnE,IAAI,CAAC,OAAO,EAAE,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC,CAAC;IAC/C,mBAAmB,CAAC,UAAU,EAAE,UAAU,EAAE,KAAK,EAAE,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC,CAAC;IACpF,QAAQ,CAAC,GAAG,EAAE,MAAM,GAAG,UAAU,CAAC;IAClC,MAAM,CAAC,KAAK,CAAC,EAAE,UAAU,GAAG,MAAM,CAAC;IACnC,aAAa,CAAC,KAAK,EAAE,UAAU,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,oBAAoB,CAAC,CAAC;CACjF;AAED,qBAAa,cAAc;IACzB,OAAO;IAEP,MAAM,CAAC,aAAa,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM;IAI3C,MAAM,CAAC,oBAAoB,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM;IAIlD,MAAM,CAAC,YAAY,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,EAAE,GAAG,MAAM,EAAE;IAetD,MAAM,CAAC,QAAQ,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,MAAM,GAAG,MAAM;CAgBjD;AAED;;GAEG;AACH,eAAO,MAAM,MAAM,sBAA6B,CAAC"}
@@ -0,0 +1,43 @@
1
+ import { NobleCryptoSecp256k1 } from "./NobleCrypto";
2
+ export class DerivationPath {
3
+ constructor() { }
4
+ static hardenedIndex(index) {
5
+ return index + 0x80000000;
6
+ }
7
+ static reverseHardenedIndex(index) {
8
+ return index - 0x80000000;
9
+ }
10
+ static toIndexArray(path) {
11
+ if (Array.isArray(path)) {
12
+ return path;
13
+ }
14
+ if (path.startsWith("m/")) {
15
+ path = path.substring(2);
16
+ }
17
+ return path.split("/").map(s => {
18
+ if (s.endsWith("'") || s.endsWith("h")) {
19
+ return parseInt(s.substring(0, s.length - 1)) + 0x80000000;
20
+ }
21
+ return parseInt(s);
22
+ });
23
+ }
24
+ static toString(path) {
25
+ if (typeof path === "string") {
26
+ return path;
27
+ }
28
+ return ("m/" +
29
+ path
30
+ .map(s => {
31
+ if (s >= 0x80000000) {
32
+ return s - 0x80000000 + "'";
33
+ }
34
+ return s;
35
+ })
36
+ .join("/"));
37
+ }
38
+ }
39
+ /**
40
+ *
41
+ */
42
+ export const crypto = new NobleCryptoSecp256k1();
43
+ //# sourceMappingURL=Crypto.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Crypto.js","sourceRoot":"","sources":["../src/Crypto.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,eAAe,CAAC;AA8BrD,MAAM,OAAO,cAAc;IACzB,gBAAuB,CAAC;IAExB,MAAM,CAAC,aAAa,CAAC,KAAa;QAChC,OAAO,KAAK,GAAG,UAAU,CAAC;IAC5B,CAAC;IAED,MAAM,CAAC,oBAAoB,CAAC,KAAa;QACvC,OAAO,KAAK,GAAG,UAAU,CAAC;IAC5B,CAAC;IAED,MAAM,CAAC,YAAY,CAAC,IAAuB;QACzC,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC;YACxB,OAAO,IAAI,CAAC;QACd,CAAC;QACD,IAAI,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;YAC1B,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;QAC3B,CAAC;QACD,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;YAC7B,IAAI,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;gBACvC,OAAO,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC;YAC7D,CAAC;YACD,OAAO,QAAQ,CAAC,CAAC,CAAC,CAAC;QACrB,CAAC,CAAC,CAAC;IACL,CAAC;IAED,MAAM,CAAC,QAAQ,CAAC,IAAuB;QACrC,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE,CAAC;YAC7B,OAAO,IAAI,CAAC;QACd,CAAC;QACD,OAAO,CACL,IAAI;YACJ,IAAI;iBACD,GAAG,CAAC,CAAC,CAAC,EAAE;gBACP,IAAI,CAAC,IAAI,UAAU,EAAE,CAAC;oBACpB,OAAO,CAAC,GAAG,UAAU,GAAG,GAAG,CAAC;gBAC9B,CAAC;gBACD,OAAO,CAAC,CAAC;YACX,CAAC,CAAC;iBACD,IAAI,CAAC,GAAG,CAAC,CACb,CAAC;IACJ,CAAC;CACF;AAED;;GAEG;AACH,MAAM,CAAC,MAAM,MAAM,GAAG,IAAI,oBAAoB,EAAE,CAAC"}