@bitgo-beta/sdk-coin-xtz 1.4.3-alpha.401 → 1.4.3-alpha.403

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 (71) hide show
  1. package/dist/src/index.d.ts +5 -0
  2. package/dist/src/index.d.ts.map +1 -0
  3. package/dist/src/index.js +44 -0
  4. package/dist/src/lib/address.d.ts +8 -0
  5. package/dist/src/lib/address.d.ts.map +1 -0
  6. package/dist/src/lib/address.js +10 -0
  7. package/dist/src/lib/iface.d.ts +148 -0
  8. package/dist/src/lib/iface.d.ts.map +1 -0
  9. package/dist/src/lib/iface.js +3 -0
  10. package/dist/src/lib/index.d.ts +10 -0
  11. package/dist/src/lib/index.d.ts.map +1 -0
  12. package/dist/src/lib/index.js +51 -0
  13. package/dist/src/lib/keyPair.d.ts +40 -0
  14. package/dist/src/lib/keyPair.d.ts.map +1 -0
  15. package/dist/src/lib/keyPair.js +149 -0
  16. package/dist/src/lib/multisigUtils.d.ts +134 -0
  17. package/dist/src/lib/multisigUtils.d.ts.map +1 -0
  18. package/dist/src/lib/multisigUtils.js +1193 -0
  19. package/dist/src/lib/transaction.d.ts +119 -0
  20. package/dist/src/lib/transaction.d.ts.map +1 -0
  21. package/dist/src/lib/transaction.js +329 -0
  22. package/dist/src/lib/transactionBuilder.d.ts +171 -0
  23. package/dist/src/lib/transactionBuilder.d.ts.map +1 -0
  24. package/dist/src/lib/transactionBuilder.js +453 -0
  25. package/dist/src/lib/transferBuilder.d.ts +24 -0
  26. package/dist/src/lib/transferBuilder.d.ts.map +1 -0
  27. package/dist/src/lib/transferBuilder.js +64 -0
  28. package/dist/src/lib/utils.d.ts +280 -0
  29. package/dist/src/lib/utils.d.ts.map +1 -0
  30. package/dist/src/lib/utils.js +492 -0
  31. package/dist/src/register.d.ts +3 -0
  32. package/dist/src/register.d.ts.map +1 -0
  33. package/dist/src/register.js +11 -0
  34. package/dist/src/txtz.d.ts +13 -0
  35. package/dist/src/txtz.d.ts.map +1 -0
  36. package/dist/src/txtz.js +14 -0
  37. package/dist/src/xtz.d.ts +125 -0
  38. package/dist/src/xtz.d.ts.map +1 -0
  39. package/dist/src/xtz.js +409 -0
  40. package/dist/test/fixtures.d.ts +571 -0
  41. package/dist/test/fixtures.d.ts.map +1 -0
  42. package/dist/test/fixtures.js +656 -0
  43. package/dist/test/resources.d.ts +451 -0
  44. package/dist/test/resources.d.ts.map +1 -0
  45. package/dist/test/resources.js +349 -0
  46. package/dist/test/unit/keyPair.d.ts +2 -0
  47. package/dist/test/unit/keyPair.d.ts.map +1 -0
  48. package/dist/test/unit/keyPair.js +142 -0
  49. package/dist/test/unit/offlineTransactionBuilder.d.ts +2 -0
  50. package/dist/test/unit/offlineTransactionBuilder.d.ts.map +1 -0
  51. package/dist/test/unit/offlineTransactionBuilder.js +291 -0
  52. package/dist/test/unit/transaction.d.ts +2 -0
  53. package/dist/test/unit/transaction.d.ts.map +1 -0
  54. package/dist/test/unit/transaction.js +98 -0
  55. package/dist/test/unit/transactionBuilder.d.ts +2 -0
  56. package/dist/test/unit/transactionBuilder.d.ts.map +1 -0
  57. package/dist/test/unit/transactionBuilder.js +656 -0
  58. package/dist/test/unit/transferBuilder.d.ts +2 -0
  59. package/dist/test/unit/transferBuilder.d.ts.map +1 -0
  60. package/dist/test/unit/transferBuilder.js +82 -0
  61. package/dist/test/unit/util.d.ts +2 -0
  62. package/dist/test/unit/util.d.ts.map +1 -0
  63. package/dist/test/unit/util.js +198 -0
  64. package/dist/test/unit/xtz.d.ts +2 -0
  65. package/dist/test/unit/xtz.d.ts.map +1 -0
  66. package/dist/test/unit/xtz.js +192 -0
  67. package/dist/tsconfig.tsbuildinfo +1 -0
  68. package/package.json +10 -7
  69. package/.eslintignore +0 -5
  70. package/.mocharc.yml +0 -8
  71. package/CHANGELOG.md +0 -784
@@ -0,0 +1,349 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.parsedTransaction = exports.validDataToSign = exports.signedSerializedOriginationTransaction = exports.unsignedSerializedOriginationTransaction = exports.emptyUnsignedSerializedOriginationTransaction = exports.defaultDataToSign = exports.defaultKeyPairFromPub = exports.defaultKeyPairFromPrv = void 0;
4
+ const src_1 = require("../src");
5
+ exports.defaultKeyPairFromPrv = new src_1.XtzLib.KeyPair({
6
+ prv: 'xprv9s21ZrQH143K3D8TXfvAJgHVfTEeQNW5Ys9wZtnUZkqPzFzSjbEJrWC1vZ4GnXCvR7rQL2UFX3RSuYeU9MrERm1XBvACow7c36vnz5iYyj2',
7
+ });
8
+ exports.defaultKeyPairFromPub = new src_1.XtzLib.KeyPair({
9
+ pub: 'xpub661MyMwAqRbcFhCvdhTAfpEEDV58oqDvv65YNHC686NNs4KbH8YZQJWVmrfbve7aAVHzxw8bKFxA7MLeDK6BbLfkE3bqkvHLPgaGHHtYGeY',
10
+ });
11
+ exports.defaultDataToSign = '0507070a000000160196369c90625575ba44594b23794832a9337f7a2d0007070000050502000000320320053d036d0743035d0a00000015006b5ddaef3fb5d7c151cfb36fbe43a7a066777394031e0743036a0001034f034d031b';
12
+ exports.emptyUnsignedSerializedOriginationTransaction = 'ad0cce1d666f0fb7861d89d53faf0de01039c5f24170937d773ae9cd42c68f63';
13
+ exports.unsignedSerializedOriginationTransaction = 'ba7a04fab1a3f77eda96b551947dd343e165d1b91b6f9f806648b63e57c88cc86d006b5ddaef3fb5d7c151cfb36fbe43a7a0667773949c25f48f07b389028c0ac0843d0000000381020000037c05000764046c000000082564656661756c740865086504620000000825636f756e7465720864085e036c055f036d0000000a256f7065726174696f6e086504620000000a257468726573686f6c64065f035c00000005256b6579730000000c256368616e67655f6b657973000000073a616374696f6e000000083a7061796c6f6164065f0563036700000005257369677300000005256d61696e0501076504620000000f2573746f7265645f636f756e746572076504620000000a257468726573686f6c64065f035c00000005256b657973050202000002a30200000012020000000d03210316051f02000000020317072e02000000080320053d036d034202000002780743036a00000313020000001e020000000403190325072c020000000002000000090200000004034f0327034c0321051f0200000002034c051f02000000560200000012020000000d03210316051f020000000203170321034903540342030c051f020000002c020000001e0200000019032104160000000840636f756e746572051f02000000020317051f0200000002034c034c02000000250200000020032104160000000f4073746f7265645f636f756e746572051f02000000020317051f0200000002034c020000001e020000000403190325072c020000000002000000090200000004034f0327051f0200000002034c02000000290200000024032104160000000a407468726573686f6c64051f020000000b041700000005406b657973051f02000000ba084303620000000000064076616c6964034c055202000000a1051f0200000002034c034c072d020000007f020000007a072f0200000004034c0320020000006a034c051f0200000061034c071f00020200000010020000000b051f02000000020321034c020000002f020000000f071f00020200000002032105700003051f02000000020318034c072c02000000020320020000000203270743036200010412000000064076616c696402000000090200000004034f0327034c020000001e020000000403190332072c020000000002000000090200000004034f0327072d02000000090200000004034f032702000000000320051f02000000310200000012020000000d03210316051f0200000002031707430362000104120000000c406e65775f636f756e7465720342072e0200000004034f03260200000011051f02000000020316034c0342053d036d0342000000c1070700000707000202000000b401000000377370706b375a574238646955325457656878646b57435632445446766e3168507a34714c6a6944336e4a516f7a4b6e6f53456e5343386201000000377370706b375a71394b5074776b7a6b6741736861346a5532394334334d63675032736b4b3536746a64374b4a6a68636d4836415a43314601000000377370706b3764327a747a62724c644261544237797a6157526b506663574773724e514e4a646b42453962435453537a656b4c4e7a707666';
14
+ exports.signedSerializedOriginationTransaction = 'ba7a04fab1a3f77eda96b551947dd343e165d1b91b6f9f806648b63e57c88cc86d006b5ddaef3fb5d7c151cfb36fbe43a7a0667773949c25f48f07b389028c0ac0843d0000000381020000037c05000764046c000000082564656661756c740865086504620000000825636f756e7465720864085e036c055f036d0000000a256f7065726174696f6e086504620000000a257468726573686f6c64065f035c00000005256b6579730000000c256368616e67655f6b657973000000073a616374696f6e000000083a7061796c6f6164065f0563036700000005257369677300000005256d61696e0501076504620000000f2573746f7265645f636f756e746572076504620000000a257468726573686f6c64065f035c00000005256b657973050202000002a30200000012020000000d03210316051f02000000020317072e02000000080320053d036d034202000002780743036a00000313020000001e020000000403190325072c020000000002000000090200000004034f0327034c0321051f0200000002034c051f02000000560200000012020000000d03210316051f020000000203170321034903540342030c051f020000002c020000001e0200000019032104160000000840636f756e746572051f02000000020317051f0200000002034c034c02000000250200000020032104160000000f4073746f7265645f636f756e746572051f02000000020317051f0200000002034c020000001e020000000403190325072c020000000002000000090200000004034f0327051f0200000002034c02000000290200000024032104160000000a407468726573686f6c64051f020000000b041700000005406b657973051f02000000ba084303620000000000064076616c6964034c055202000000a1051f0200000002034c034c072d020000007f020000007a072f0200000004034c0320020000006a034c051f0200000061034c071f00020200000010020000000b051f02000000020321034c020000002f020000000f071f00020200000002032105700003051f02000000020318034c072c02000000020320020000000203270743036200010412000000064076616c696402000000090200000004034f0327034c020000001e020000000403190332072c020000000002000000090200000004034f0327072d02000000090200000004034f032702000000000320051f02000000310200000012020000000d03210316051f0200000002031707430362000104120000000c406e65775f636f756e7465720342072e0200000004034f03260200000011051f02000000020316034c0342053d036d0342000000c1070700000707000202000000b401000000377370706b375a574238646955325457656878646b57435632445446766e3168507a34714c6a6944336e4a516f7a4b6e6f53456e5343386201000000377370706b375a71394b5074776b7a6b6741736861346a5532394334334d63675032736b4b3536746a64374b4a6a68636d4836415a43314601000000377370706b3764327a747a62724c644261544237797a6157526b506663574773724e514e4a646b42453962435453537a656b4c4e7a707666a319a0ac5c5c949dcf4a49452e0bd13cf3e05903379784317a821d2f323f677c84acef4a3c1d68e2b216df9ca225d426cf23c3c2f57c19e95063fbd4b30b620b';
15
+ exports.validDataToSign = {
16
+ data: {
17
+ prim: 'Pair',
18
+ args: [
19
+ { string: 'KT1NH2M23xovhw7uwWVuoGTYxykeCcVfSqhL' },
20
+ {
21
+ prim: 'Pair',
22
+ args: [
23
+ { int: '0' },
24
+ {
25
+ prim: 'Left',
26
+ args: [
27
+ [
28
+ { prim: 'DROP' },
29
+ { prim: 'NIL', args: [{ prim: 'operation' }] },
30
+ { prim: 'PUSH', args: [{ prim: 'key_hash' }, { string: 'tz2PtJ9zgEgFVTRqy6GXsst54tH3ksEnYvvS' }] },
31
+ { prim: 'IMPLICIT_ACCOUNT' },
32
+ { prim: 'PUSH', args: [{ prim: 'mutez' }, { int: '100' }] },
33
+ { prim: 'UNIT' },
34
+ { prim: 'TRANSFER_TOKENS' },
35
+ { prim: 'CONS' },
36
+ ],
37
+ ],
38
+ },
39
+ ],
40
+ },
41
+ ],
42
+ },
43
+ type: {
44
+ prim: 'pair',
45
+ args: [
46
+ { prim: 'address' },
47
+ {
48
+ prim: 'pair',
49
+ args: [
50
+ { prim: 'nat', annots: ['%counter'] },
51
+ {
52
+ prim: 'or',
53
+ args: [
54
+ {
55
+ prim: 'lambda',
56
+ args: [{ prim: 'unit' }, { prim: 'list', args: [{ prim: 'operation' }] }],
57
+ annots: ['%operation'],
58
+ },
59
+ {
60
+ prim: 'pair',
61
+ args: [
62
+ { prim: 'nat', annots: ['%threshold'] },
63
+ { prim: 'list', args: [{ prim: 'key' }], annots: ['%keys'] },
64
+ ],
65
+ annots: ['%change_keys'],
66
+ },
67
+ ],
68
+ annots: [':action'],
69
+ },
70
+ ],
71
+ annots: [':payload'],
72
+ },
73
+ ],
74
+ },
75
+ };
76
+ exports.parsedTransaction = {
77
+ branch: 'BM8QdZ92VyaH1s5nwAF9rUXjiPZ3g3Nsn6oYbdKqj2RgHxvWXVS',
78
+ contents: [
79
+ {
80
+ kind: 'origination',
81
+ source: 'tz1VRjRpVKnv16AVprFH1tkDn4TDfVqA893A',
82
+ fee: '4764',
83
+ counter: '116724',
84
+ gas_limit: '33971',
85
+ storage_limit: '1292',
86
+ balance: '1000000',
87
+ script: {
88
+ code: [
89
+ {
90
+ prim: 'parameter',
91
+ args: [
92
+ {
93
+ prim: 'or',
94
+ args: [
95
+ { prim: 'unit', annots: ['%default'] },
96
+ {
97
+ prim: 'pair',
98
+ args: [
99
+ {
100
+ prim: 'pair',
101
+ args: [
102
+ { prim: 'nat', annots: ['%counter'] },
103
+ {
104
+ prim: 'or',
105
+ args: [
106
+ {
107
+ prim: 'lambda',
108
+ args: [{ prim: 'unit' }, { prim: 'list', args: [{ prim: 'operation' }] }],
109
+ annots: ['%operation'],
110
+ },
111
+ {
112
+ prim: 'pair',
113
+ args: [
114
+ { prim: 'nat', annots: ['%threshold'] },
115
+ { prim: 'list', args: [{ prim: 'key' }], annots: ['%keys'] },
116
+ ],
117
+ annots: ['%change_keys'],
118
+ },
119
+ ],
120
+ annots: [':action'],
121
+ },
122
+ ],
123
+ annots: [':payload'],
124
+ },
125
+ { prim: 'list', args: [{ prim: 'option', args: [{ prim: 'signature' }] }], annots: ['%sigs'] },
126
+ ],
127
+ annots: ['%main'],
128
+ },
129
+ ],
130
+ },
131
+ ],
132
+ },
133
+ {
134
+ prim: 'storage',
135
+ args: [
136
+ {
137
+ prim: 'pair',
138
+ args: [
139
+ { prim: 'nat', annots: ['%stored_counter'] },
140
+ {
141
+ prim: 'pair',
142
+ args: [
143
+ { prim: 'nat', annots: ['%threshold'] },
144
+ { prim: 'list', args: [{ prim: 'key' }], annots: ['%keys'] },
145
+ ],
146
+ },
147
+ ],
148
+ },
149
+ ],
150
+ },
151
+ {
152
+ prim: 'code',
153
+ args: [
154
+ [
155
+ [[{ prim: 'DUP' }, { prim: 'CAR' }, { prim: 'DIP', args: [[{ prim: 'CDR' }]] }]],
156
+ {
157
+ prim: 'IF_LEFT',
158
+ args: [
159
+ [{ prim: 'DROP' }, { prim: 'NIL', args: [{ prim: 'operation' }] }, { prim: 'PAIR' }],
160
+ [
161
+ { prim: 'PUSH', args: [{ prim: 'mutez' }, { int: '0' }] },
162
+ { prim: 'AMOUNT' },
163
+ [
164
+ [{ prim: 'COMPARE' }, { prim: 'EQ' }],
165
+ { prim: 'IF', args: [[], [[{ prim: 'UNIT' }, { prim: 'FAILWITH' }]]] },
166
+ ],
167
+ { prim: 'SWAP' },
168
+ { prim: 'DUP' },
169
+ { prim: 'DIP', args: [[{ prim: 'SWAP' }]] },
170
+ {
171
+ prim: 'DIP',
172
+ args: [
173
+ [
174
+ [[{ prim: 'DUP' }, { prim: 'CAR' }, { prim: 'DIP', args: [[{ prim: 'CDR' }]] }]],
175
+ { prim: 'DUP' },
176
+ { prim: 'SELF' },
177
+ { prim: 'ADDRESS' },
178
+ { prim: 'PAIR' },
179
+ { prim: 'PACK' },
180
+ {
181
+ prim: 'DIP',
182
+ args: [
183
+ [
184
+ [
185
+ [
186
+ { prim: 'DUP' },
187
+ { prim: 'CAR', annots: ['@counter'] },
188
+ { prim: 'DIP', args: [[{ prim: 'CDR' }]] },
189
+ ],
190
+ ],
191
+ { prim: 'DIP', args: [[{ prim: 'SWAP' }]] },
192
+ ],
193
+ ],
194
+ },
195
+ { prim: 'SWAP' },
196
+ ],
197
+ ],
198
+ },
199
+ [
200
+ [
201
+ { prim: 'DUP' },
202
+ { prim: 'CAR', annots: ['@stored_counter'] },
203
+ { prim: 'DIP', args: [[{ prim: 'CDR' }]] },
204
+ ],
205
+ ],
206
+ { prim: 'DIP', args: [[{ prim: 'SWAP' }]] },
207
+ [
208
+ [{ prim: 'COMPARE' }, { prim: 'EQ' }],
209
+ { prim: 'IF', args: [[], [[{ prim: 'UNIT' }, { prim: 'FAILWITH' }]]] },
210
+ ],
211
+ { prim: 'DIP', args: [[{ prim: 'SWAP' }]] },
212
+ [
213
+ [
214
+ { prim: 'DUP' },
215
+ { prim: 'CAR', annots: ['@threshold'] },
216
+ { prim: 'DIP', args: [[{ prim: 'CDR', annots: ['@keys'] }]] },
217
+ ],
218
+ ],
219
+ {
220
+ prim: 'DIP',
221
+ args: [
222
+ [
223
+ { prim: 'PUSH', args: [{ prim: 'nat' }, { int: '0' }], annots: ['@valid'] },
224
+ { prim: 'SWAP' },
225
+ {
226
+ prim: 'ITER',
227
+ args: [
228
+ [
229
+ { prim: 'DIP', args: [[{ prim: 'SWAP' }]] },
230
+ { prim: 'SWAP' },
231
+ {
232
+ prim: 'IF_CONS',
233
+ args: [
234
+ [
235
+ [
236
+ {
237
+ prim: 'IF_NONE',
238
+ args: [
239
+ [{ prim: 'SWAP' }, { prim: 'DROP' }],
240
+ [
241
+ { prim: 'SWAP' },
242
+ {
243
+ prim: 'DIP',
244
+ args: [
245
+ [
246
+ { prim: 'SWAP' },
247
+ {
248
+ prim: 'DIP',
249
+ args: [
250
+ { int: '2' },
251
+ [
252
+ [
253
+ { prim: 'DIP', args: [[{ prim: 'DUP' }]] },
254
+ { prim: 'SWAP' },
255
+ ],
256
+ ],
257
+ ],
258
+ },
259
+ [
260
+ [
261
+ { prim: 'DIP', args: [{ int: '2' }, [{ prim: 'DUP' }]] },
262
+ { prim: 'DIG', args: [{ int: '3' }] },
263
+ ],
264
+ { prim: 'DIP', args: [[{ prim: 'CHECK_SIGNATURE' }]] },
265
+ { prim: 'SWAP' },
266
+ {
267
+ prim: 'IF',
268
+ args: [[{ prim: 'DROP' }], [{ prim: 'FAILWITH' }]],
269
+ },
270
+ ],
271
+ { prim: 'PUSH', args: [{ prim: 'nat' }, { int: '1' }] },
272
+ { prim: 'ADD', annots: ['@valid'] },
273
+ ],
274
+ ],
275
+ },
276
+ ],
277
+ ],
278
+ },
279
+ ],
280
+ ],
281
+ [[{ prim: 'UNIT' }, { prim: 'FAILWITH' }]],
282
+ ],
283
+ },
284
+ { prim: 'SWAP' },
285
+ ],
286
+ ],
287
+ },
288
+ ],
289
+ ],
290
+ },
291
+ [
292
+ [{ prim: 'COMPARE' }, { prim: 'LE' }],
293
+ { prim: 'IF', args: [[], [[{ prim: 'UNIT' }, { prim: 'FAILWITH' }]]] },
294
+ ],
295
+ { prim: 'IF_CONS', args: [[[{ prim: 'UNIT' }, { prim: 'FAILWITH' }]], []] },
296
+ { prim: 'DROP' },
297
+ {
298
+ prim: 'DIP',
299
+ args: [
300
+ [
301
+ [[{ prim: 'DUP' }, { prim: 'CAR' }, { prim: 'DIP', args: [[{ prim: 'CDR' }]] }]],
302
+ { prim: 'PUSH', args: [{ prim: 'nat' }, { int: '1' }] },
303
+ { prim: 'ADD', annots: ['@new_counter'] },
304
+ { prim: 'PAIR' },
305
+ ],
306
+ ],
307
+ },
308
+ {
309
+ prim: 'IF_LEFT',
310
+ args: [
311
+ [{ prim: 'UNIT' }, { prim: 'EXEC' }],
312
+ [
313
+ { prim: 'DIP', args: [[{ prim: 'CAR' }]] },
314
+ { prim: 'SWAP' },
315
+ { prim: 'PAIR' },
316
+ { prim: 'NIL', args: [{ prim: 'operation' }] },
317
+ ],
318
+ ],
319
+ },
320
+ { prim: 'PAIR' },
321
+ ],
322
+ ],
323
+ },
324
+ ],
325
+ ],
326
+ },
327
+ ],
328
+ storage: {
329
+ prim: 'Pair',
330
+ args: [
331
+ { int: '0' },
332
+ {
333
+ prim: 'Pair',
334
+ args: [
335
+ { int: '2' },
336
+ [
337
+ { string: 'sppk7ZWB8diU2TWehxdkWCV2DTFvn1hPz4qLjiD3nJQozKnoSEnSC8b' },
338
+ { string: 'sppk7Zq9KPtwkzkgAsha4jU29C43McgP2skK56tjd7KJjhcmH6AZC1F' },
339
+ { string: 'sppk7d2ztzbrLdBaTB7yzaWRkPfcWGsrNQNJdkBE9bCTSSzekLNzpvf' },
340
+ ],
341
+ ],
342
+ },
343
+ ],
344
+ },
345
+ },
346
+ },
347
+ ],
348
+ };
349
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resources.js","sourceRoot":"","sources":["../../test/resources.ts"],"names":[],"mappings":"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","sourcesContent":["import { XtzLib } from '../src';\n\nexport const defaultKeyPairFromPrv = new XtzLib.KeyPair({\n  prv: 'xprv9s21ZrQH143K3D8TXfvAJgHVfTEeQNW5Ys9wZtnUZkqPzFzSjbEJrWC1vZ4GnXCvR7rQL2UFX3RSuYeU9MrERm1XBvACow7c36vnz5iYyj2',\n});\n\nexport const defaultKeyPairFromPub = new XtzLib.KeyPair({\n  pub: 'xpub661MyMwAqRbcFhCvdhTAfpEEDV58oqDvv65YNHC686NNs4KbH8YZQJWVmrfbve7aAVHzxw8bKFxA7MLeDK6BbLfkE3bqkvHLPgaGHHtYGeY',\n});\nexport const defaultDataToSign =\n  '0507070a000000160196369c90625575ba44594b23794832a9337f7a2d0007070000050502000000320320053d036d0743035d0a00000015006b5ddaef3fb5d7c151cfb36fbe43a7a066777394031e0743036a0001034f034d031b';\n\nexport const emptyUnsignedSerializedOriginationTransaction =\n  'ad0cce1d666f0fb7861d89d53faf0de01039c5f24170937d773ae9cd42c68f63';\n\nexport const unsignedSerializedOriginationTransaction =\n  'ba7a04fab1a3f77eda96b551947dd343e165d1b91b6f9f806648b63e57c88cc86d006b5ddaef3fb5d7c151cfb36fbe43a7a0667773949c25f48f07b389028c0ac0843d0000000381020000037c05000764046c000000082564656661756c740865086504620000000825636f756e7465720864085e036c055f036d0000000a256f7065726174696f6e086504620000000a257468726573686f6c64065f035c00000005256b6579730000000c256368616e67655f6b657973000000073a616374696f6e000000083a7061796c6f6164065f0563036700000005257369677300000005256d61696e0501076504620000000f2573746f7265645f636f756e746572076504620000000a257468726573686f6c64065f035c00000005256b657973050202000002a30200000012020000000d03210316051f02000000020317072e02000000080320053d036d034202000002780743036a00000313020000001e020000000403190325072c020000000002000000090200000004034f0327034c0321051f0200000002034c051f02000000560200000012020000000d03210316051f020000000203170321034903540342030c051f020000002c020000001e0200000019032104160000000840636f756e746572051f02000000020317051f0200000002034c034c02000000250200000020032104160000000f4073746f7265645f636f756e746572051f02000000020317051f0200000002034c020000001e020000000403190325072c020000000002000000090200000004034f0327051f0200000002034c02000000290200000024032104160000000a407468726573686f6c64051f020000000b041700000005406b657973051f02000000ba084303620000000000064076616c6964034c055202000000a1051f0200000002034c034c072d020000007f020000007a072f0200000004034c0320020000006a034c051f0200000061034c071f00020200000010020000000b051f02000000020321034c020000002f020000000f071f00020200000002032105700003051f02000000020318034c072c02000000020320020000000203270743036200010412000000064076616c696402000000090200000004034f0327034c020000001e020000000403190332072c020000000002000000090200000004034f0327072d02000000090200000004034f032702000000000320051f02000000310200000012020000000d03210316051f0200000002031707430362000104120000000c406e65775f636f756e7465720342072e0200000004034f03260200000011051f02000000020316034c0342053d036d0342000000c1070700000707000202000000b401000000377370706b375a574238646955325457656878646b57435632445446766e3168507a34714c6a6944336e4a516f7a4b6e6f53456e5343386201000000377370706b375a71394b5074776b7a6b6741736861346a5532394334334d63675032736b4b3536746a64374b4a6a68636d4836415a43314601000000377370706b3764327a747a62724c644261544237797a6157526b506663574773724e514e4a646b42453962435453537a656b4c4e7a707666';\n\nexport const signedSerializedOriginationTransaction =\n  'ba7a04fab1a3f77eda96b551947dd343e165d1b91b6f9f806648b63e57c88cc86d006b5ddaef3fb5d7c151cfb36fbe43a7a0667773949c25f48f07b389028c0ac0843d0000000381020000037c05000764046c000000082564656661756c740865086504620000000825636f756e7465720864085e036c055f036d0000000a256f7065726174696f6e086504620000000a257468726573686f6c64065f035c00000005256b6579730000000c256368616e67655f6b657973000000073a616374696f6e000000083a7061796c6f6164065f0563036700000005257369677300000005256d61696e0501076504620000000f2573746f7265645f636f756e746572076504620000000a257468726573686f6c64065f035c00000005256b657973050202000002a30200000012020000000d03210316051f02000000020317072e02000000080320053d036d034202000002780743036a00000313020000001e020000000403190325072c020000000002000000090200000004034f0327034c0321051f0200000002034c051f02000000560200000012020000000d03210316051f020000000203170321034903540342030c051f020000002c020000001e0200000019032104160000000840636f756e746572051f02000000020317051f0200000002034c034c02000000250200000020032104160000000f4073746f7265645f636f756e746572051f02000000020317051f0200000002034c020000001e020000000403190325072c020000000002000000090200000004034f0327051f0200000002034c02000000290200000024032104160000000a407468726573686f6c64051f020000000b041700000005406b657973051f02000000ba084303620000000000064076616c6964034c055202000000a1051f0200000002034c034c072d020000007f020000007a072f0200000004034c0320020000006a034c051f0200000061034c071f00020200000010020000000b051f02000000020321034c020000002f020000000f071f00020200000002032105700003051f02000000020318034c072c02000000020320020000000203270743036200010412000000064076616c696402000000090200000004034f0327034c020000001e020000000403190332072c020000000002000000090200000004034f0327072d02000000090200000004034f032702000000000320051f02000000310200000012020000000d03210316051f0200000002031707430362000104120000000c406e65775f636f756e7465720342072e0200000004034f03260200000011051f02000000020316034c0342053d036d0342000000c1070700000707000202000000b401000000377370706b375a574238646955325457656878646b57435632445446766e3168507a34714c6a6944336e4a516f7a4b6e6f53456e5343386201000000377370706b375a71394b5074776b7a6b6741736861346a5532394334334d63675032736b4b3536746a64374b4a6a68636d4836415a43314601000000377370706b3764327a747a62724c644261544237797a6157526b506663574773724e514e4a646b42453962435453537a656b4c4e7a707666a319a0ac5c5c949dcf4a49452e0bd13cf3e05903379784317a821d2f323f677c84acef4a3c1d68e2b216df9ca225d426cf23c3c2f57c19e95063fbd4b30b620b';\n\nexport const validDataToSign = {\n  data: {\n    prim: 'Pair',\n    args: [\n      { string: 'KT1NH2M23xovhw7uwWVuoGTYxykeCcVfSqhL' },\n      {\n        prim: 'Pair',\n        args: [\n          { int: '0' },\n          {\n            prim: 'Left',\n            args: [\n              [\n                { prim: 'DROP' },\n                { prim: 'NIL', args: [{ prim: 'operation' }] },\n                { prim: 'PUSH', args: [{ prim: 'key_hash' }, { string: 'tz2PtJ9zgEgFVTRqy6GXsst54tH3ksEnYvvS' }] },\n                { prim: 'IMPLICIT_ACCOUNT' },\n                { prim: 'PUSH', args: [{ prim: 'mutez' }, { int: '100' }] },\n                { prim: 'UNIT' },\n                { prim: 'TRANSFER_TOKENS' },\n                { prim: 'CONS' },\n              ],\n            ],\n          },\n        ],\n      },\n    ],\n  },\n  type: {\n    prim: 'pair',\n    args: [\n      { prim: 'address' },\n      {\n        prim: 'pair',\n        args: [\n          { prim: 'nat', annots: ['%counter'] },\n          {\n            prim: 'or',\n            args: [\n              {\n                prim: 'lambda',\n                args: [{ prim: 'unit' }, { prim: 'list', args: [{ prim: 'operation' }] }],\n                annots: ['%operation'],\n              },\n              {\n                prim: 'pair',\n                args: [\n                  { prim: 'nat', annots: ['%threshold'] },\n                  { prim: 'list', args: [{ prim: 'key' }], annots: ['%keys'] },\n                ],\n                annots: ['%change_keys'],\n              },\n            ],\n            annots: [':action'],\n          },\n        ],\n        annots: [':payload'],\n      },\n    ],\n  },\n};\n\nexport const parsedTransaction = {\n  branch: 'BM8QdZ92VyaH1s5nwAF9rUXjiPZ3g3Nsn6oYbdKqj2RgHxvWXVS',\n  contents: [\n    {\n      kind: 'origination',\n      source: 'tz1VRjRpVKnv16AVprFH1tkDn4TDfVqA893A',\n      fee: '4764',\n      counter: '116724',\n      gas_limit: '33971',\n      storage_limit: '1292',\n      balance: '1000000',\n      script: {\n        code: [\n          {\n            prim: 'parameter',\n            args: [\n              {\n                prim: 'or',\n                args: [\n                  { prim: 'unit', annots: ['%default'] },\n                  {\n                    prim: 'pair',\n                    args: [\n                      {\n                        prim: 'pair',\n                        args: [\n                          { prim: 'nat', annots: ['%counter'] },\n                          {\n                            prim: 'or',\n                            args: [\n                              {\n                                prim: 'lambda',\n                                args: [{ prim: 'unit' }, { prim: 'list', args: [{ prim: 'operation' }] }],\n                                annots: ['%operation'],\n                              },\n                              {\n                                prim: 'pair',\n                                args: [\n                                  { prim: 'nat', annots: ['%threshold'] },\n                                  { prim: 'list', args: [{ prim: 'key' }], annots: ['%keys'] },\n                                ],\n                                annots: ['%change_keys'],\n                              },\n                            ],\n                            annots: [':action'],\n                          },\n                        ],\n                        annots: [':payload'],\n                      },\n                      { prim: 'list', args: [{ prim: 'option', args: [{ prim: 'signature' }] }], annots: ['%sigs'] },\n                    ],\n                    annots: ['%main'],\n                  },\n                ],\n              },\n            ],\n          },\n          {\n            prim: 'storage',\n            args: [\n              {\n                prim: 'pair',\n                args: [\n                  { prim: 'nat', annots: ['%stored_counter'] },\n                  {\n                    prim: 'pair',\n                    args: [\n                      { prim: 'nat', annots: ['%threshold'] },\n                      { prim: 'list', args: [{ prim: 'key' }], annots: ['%keys'] },\n                    ],\n                  },\n                ],\n              },\n            ],\n          },\n          {\n            prim: 'code',\n            args: [\n              [\n                [[{ prim: 'DUP' }, { prim: 'CAR' }, { prim: 'DIP', args: [[{ prim: 'CDR' }]] }]],\n                {\n                  prim: 'IF_LEFT',\n                  args: [\n                    [{ prim: 'DROP' }, { prim: 'NIL', args: [{ prim: 'operation' }] }, { prim: 'PAIR' }],\n                    [\n                      { prim: 'PUSH', args: [{ prim: 'mutez' }, { int: '0' }] },\n                      { prim: 'AMOUNT' },\n                      [\n                        [{ prim: 'COMPARE' }, { prim: 'EQ' }],\n                        { prim: 'IF', args: [[], [[{ prim: 'UNIT' }, { prim: 'FAILWITH' }]]] },\n                      ],\n                      { prim: 'SWAP' },\n                      { prim: 'DUP' },\n                      { prim: 'DIP', args: [[{ prim: 'SWAP' }]] },\n                      {\n                        prim: 'DIP',\n                        args: [\n                          [\n                            [[{ prim: 'DUP' }, { prim: 'CAR' }, { prim: 'DIP', args: [[{ prim: 'CDR' }]] }]],\n                            { prim: 'DUP' },\n                            { prim: 'SELF' },\n                            { prim: 'ADDRESS' },\n                            { prim: 'PAIR' },\n                            { prim: 'PACK' },\n                            {\n                              prim: 'DIP',\n                              args: [\n                                [\n                                  [\n                                    [\n                                      { prim: 'DUP' },\n                                      { prim: 'CAR', annots: ['@counter'] },\n                                      { prim: 'DIP', args: [[{ prim: 'CDR' }]] },\n                                    ],\n                                  ],\n                                  { prim: 'DIP', args: [[{ prim: 'SWAP' }]] },\n                                ],\n                              ],\n                            },\n                            { prim: 'SWAP' },\n                          ],\n                        ],\n                      },\n                      [\n                        [\n                          { prim: 'DUP' },\n                          { prim: 'CAR', annots: ['@stored_counter'] },\n                          { prim: 'DIP', args: [[{ prim: 'CDR' }]] },\n                        ],\n                      ],\n                      { prim: 'DIP', args: [[{ prim: 'SWAP' }]] },\n                      [\n                        [{ prim: 'COMPARE' }, { prim: 'EQ' }],\n                        { prim: 'IF', args: [[], [[{ prim: 'UNIT' }, { prim: 'FAILWITH' }]]] },\n                      ],\n                      { prim: 'DIP', args: [[{ prim: 'SWAP' }]] },\n                      [\n                        [\n                          { prim: 'DUP' },\n                          { prim: 'CAR', annots: ['@threshold'] },\n                          { prim: 'DIP', args: [[{ prim: 'CDR', annots: ['@keys'] }]] },\n                        ],\n                      ],\n                      {\n                        prim: 'DIP',\n                        args: [\n                          [\n                            { prim: 'PUSH', args: [{ prim: 'nat' }, { int: '0' }], annots: ['@valid'] },\n                            { prim: 'SWAP' },\n                            {\n                              prim: 'ITER',\n                              args: [\n                                [\n                                  { prim: 'DIP', args: [[{ prim: 'SWAP' }]] },\n                                  { prim: 'SWAP' },\n                                  {\n                                    prim: 'IF_CONS',\n                                    args: [\n                                      [\n                                        [\n                                          {\n                                            prim: 'IF_NONE',\n                                            args: [\n                                              [{ prim: 'SWAP' }, { prim: 'DROP' }],\n                                              [\n                                                { prim: 'SWAP' },\n                                                {\n                                                  prim: 'DIP',\n                                                  args: [\n                                                    [\n                                                      { prim: 'SWAP' },\n                                                      {\n                                                        prim: 'DIP',\n                                                        args: [\n                                                          { int: '2' },\n                                                          [\n                                                            [\n                                                              { prim: 'DIP', args: [[{ prim: 'DUP' }]] },\n                                                              { prim: 'SWAP' },\n                                                            ],\n                                                          ],\n                                                        ],\n                                                      },\n                                                      [\n                                                        [\n                                                          { prim: 'DIP', args: [{ int: '2' }, [{ prim: 'DUP' }]] },\n                                                          { prim: 'DIG', args: [{ int: '3' }] },\n                                                        ],\n                                                        { prim: 'DIP', args: [[{ prim: 'CHECK_SIGNATURE' }]] },\n                                                        { prim: 'SWAP' },\n                                                        {\n                                                          prim: 'IF',\n                                                          args: [[{ prim: 'DROP' }], [{ prim: 'FAILWITH' }]],\n                                                        },\n                                                      ],\n                                                      { prim: 'PUSH', args: [{ prim: 'nat' }, { int: '1' }] },\n                                                      { prim: 'ADD', annots: ['@valid'] },\n                                                    ],\n                                                  ],\n                                                },\n                                              ],\n                                            ],\n                                          },\n                                        ],\n                                      ],\n                                      [[{ prim: 'UNIT' }, { prim: 'FAILWITH' }]],\n                                    ],\n                                  },\n                                  { prim: 'SWAP' },\n                                ],\n                              ],\n                            },\n                          ],\n                        ],\n                      },\n                      [\n                        [{ prim: 'COMPARE' }, { prim: 'LE' }],\n                        { prim: 'IF', args: [[], [[{ prim: 'UNIT' }, { prim: 'FAILWITH' }]]] },\n                      ],\n                      { prim: 'IF_CONS', args: [[[{ prim: 'UNIT' }, { prim: 'FAILWITH' }]], []] },\n                      { prim: 'DROP' },\n                      {\n                        prim: 'DIP',\n                        args: [\n                          [\n                            [[{ prim: 'DUP' }, { prim: 'CAR' }, { prim: 'DIP', args: [[{ prim: 'CDR' }]] }]],\n                            { prim: 'PUSH', args: [{ prim: 'nat' }, { int: '1' }] },\n                            { prim: 'ADD', annots: ['@new_counter'] },\n                            { prim: 'PAIR' },\n                          ],\n                        ],\n                      },\n                      {\n                        prim: 'IF_LEFT',\n                        args: [\n                          [{ prim: 'UNIT' }, { prim: 'EXEC' }],\n                          [\n                            { prim: 'DIP', args: [[{ prim: 'CAR' }]] },\n                            { prim: 'SWAP' },\n                            { prim: 'PAIR' },\n                            { prim: 'NIL', args: [{ prim: 'operation' }] },\n                          ],\n                        ],\n                      },\n                      { prim: 'PAIR' },\n                    ],\n                  ],\n                },\n              ],\n            ],\n          },\n        ],\n        storage: {\n          prim: 'Pair',\n          args: [\n            { int: '0' },\n            {\n              prim: 'Pair',\n              args: [\n                { int: '2' },\n                [\n                  { string: 'sppk7ZWB8diU2TWehxdkWCV2DTFvn1hPz4qLjiD3nJQozKnoSEnSC8b' },\n                  { string: 'sppk7Zq9KPtwkzkgAsha4jU29C43McgP2skK56tjd7KJjhcmH6AZC1F' },\n                  { string: 'sppk7d2ztzbrLdBaTB7yzaWRkPfcWGsrNQNJdkBE9bCTSSzekLNzpvf' },\n                ],\n              ],\n            },\n          ],\n        },\n      },\n    },\n  ],\n};\n"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=keyPair.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"keyPair.d.ts","sourceRoot":"","sources":["../../../test/unit/keyPair.ts"],"names":[],"mappings":""}
@@ -0,0 +1,142 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const assert_1 = __importDefault(require("assert"));
7
+ const should_1 = __importDefault(require("should"));
8
+ const src_1 = require("../../src");
9
+ describe('Xtz KeyPair', function () {
10
+ const defaultSeed = { seed: Buffer.alloc(32) };
11
+ describe('should create a KeyPair', function () {
12
+ it('from an xpub', () => {
13
+ const source = {
14
+ pub: 'xpub661MyMwAqRbcFhCvdhTAfpEEDV58oqDvv65YNHC686NNs4KbH8YZQJWVmrfbve7aAVHzxw8bKFxA7MLeDK6BbLfkE3bqkvHLPgaGHHtYGeY',
15
+ };
16
+ const keyPair = new src_1.XtzLib.KeyPair(source);
17
+ const defaultKeys = keyPair.getKeys();
18
+ should_1.default.not.exist(defaultKeys.prv);
19
+ defaultKeys.pub.should.equal('sppk7csjXKT4wvUNCPMfAgZMNuvSjzW4Y2ZAKZEdvyEPtYagE6pCwkw');
20
+ const extendedKeys = keyPair.getExtendedKeys();
21
+ should_1.default.not.exist(extendedKeys.xprv);
22
+ extendedKeys.xpub.should.equal('xpub661MyMwAqRbcFhCvdhTAfpEEDV58oqDvv65YNHC686NNs4KbH8YZQJWVmrfbve7aAVHzxw8bKFxA7MLeDK6BbLfkE3bqkvHLPgaGHHtYGeY');
23
+ });
24
+ it('from an xprv', () => {
25
+ const source = {
26
+ prv: 'xprv9s21ZrQH143K3D8TXfvAJgHVfTEeQNW5Ys9wZtnUZkqPzFzSjbEJrWC1vZ4GnXCvR7rQL2UFX3RSuYeU9MrERm1XBvACow7c36vnz5iYyj2',
27
+ };
28
+ const keyPair = new src_1.XtzLib.KeyPair(source);
29
+ const defaultKeys = keyPair.getKeys();
30
+ defaultKeys.prv.should.equal('spsk2R6ek35CtfJMt2XHPWgFcf1wUGLK2fKbU3f4hWZNABo1YrrqP7');
31
+ defaultKeys.pub.should.equal('sppk7csjXKT4wvUNCPMfAgZMNuvSjzW4Y2ZAKZEdvyEPtYagE6pCwkw');
32
+ const extendedKeys = keyPair.getExtendedKeys();
33
+ extendedKeys.xprv.should.equal('xprv9s21ZrQH143K3D8TXfvAJgHVfTEeQNW5Ys9wZtnUZkqPzFzSjbEJrWC1vZ4GnXCvR7rQL2UFX3RSuYeU9MrERm1XBvACow7c36vnz5iYyj2');
34
+ extendedKeys.xpub.should.equal('xpub661MyMwAqRbcFhCvdhTAfpEEDV58oqDvv65YNHC686NNs4KbH8YZQJWVmrfbve7aAVHzxw8bKFxA7MLeDK6BbLfkE3bqkvHLPgaGHHtYGeY');
35
+ });
36
+ it('from an uncompressed public key', () => {
37
+ const source = {
38
+ pub: '04D63D9FD9FD772A989C5B90EDB37716406356E98273E5F98FE07652247A3A827503E948A2FDBF74A981D4E0054F10EDA7042C2D469F44473D3C7791E0E326E355',
39
+ };
40
+ const keyPair = new src_1.XtzLib.KeyPair(source);
41
+ const defaultKeys = keyPair.getKeys();
42
+ should_1.default.not.exist(defaultKeys.prv);
43
+ defaultKeys.pub.should.equal('sppk7csjXKT4wvUNCPMfAgZMNuvSjzW4Y2ZAKZEdvyEPtYagE6pCwkw');
44
+ assert_1.default.throws(() => keyPair.getExtendedKeys());
45
+ });
46
+ it('from a compressed public key', () => {
47
+ const source = {
48
+ pub: '03D63D9FD9FD772A989C5B90EDB37716406356E98273E5F98FE07652247A3A8275',
49
+ };
50
+ const keyPair = new src_1.XtzLib.KeyPair(source);
51
+ const defaultKeys = keyPair.getKeys();
52
+ should_1.default.not.exist(defaultKeys.prv);
53
+ defaultKeys.pub.should.equal('sppk7csjXKT4wvUNCPMfAgZMNuvSjzW4Y2ZAKZEdvyEPtYagE6pCwkw');
54
+ assert_1.default.throws(() => keyPair.getExtendedKeys());
55
+ });
56
+ it('from a Tezos public key', () => {
57
+ const source = {
58
+ pub: 'sppk7csjXKT4wvUNCPMfAgZMNuvSjzW4Y2ZAKZEdvyEPtYagE6pCwkw',
59
+ };
60
+ const keyPair = new src_1.XtzLib.KeyPair(source);
61
+ const defaultKeys = keyPair.getKeys();
62
+ should_1.default.not.exist(defaultKeys.prv);
63
+ defaultKeys.pub.should.equal('sppk7csjXKT4wvUNCPMfAgZMNuvSjzW4Y2ZAKZEdvyEPtYagE6pCwkw');
64
+ assert_1.default.throws(() => keyPair.getExtendedKeys());
65
+ });
66
+ it('from a raw private key', () => {
67
+ const source = {
68
+ prv: '82A34E3867EA7EA4E67E27865D500AE84E98D07AB1BAB06526F0A5A5FDCC3EBA',
69
+ };
70
+ const keyPair = new src_1.XtzLib.KeyPair(source);
71
+ const defaultKeys = keyPair.getKeys();
72
+ defaultKeys.prv.should.equal('spsk2R6ek35CtfJMt2XHPWgFcf1wUGLK2fKbU3f4hWZNABo1YrrqP7');
73
+ defaultKeys.pub.should.equal('sppk7csjXKT4wvUNCPMfAgZMNuvSjzW4Y2ZAKZEdvyEPtYagE6pCwkw');
74
+ assert_1.default.throws(() => keyPair.getExtendedKeys());
75
+ });
76
+ it('from a Tezos private key', () => {
77
+ const source = {
78
+ prv: 'spsk2cbiVsAvpGKmau9XcMscL3NRwjkyT575N5AyAofcoj41x6g6TL',
79
+ };
80
+ const keyPair = new src_1.XtzLib.KeyPair(source);
81
+ const defaultKeys = keyPair.getKeys();
82
+ defaultKeys.prv.should.equal('spsk2cbiVsAvpGKmau9XcMscL3NRwjkyT575N5AyAofcoj41x6g6TL');
83
+ defaultKeys.pub.should.equal('sppk7ZWB8diU2TWehxdkWCV2DTFvn1hPz4qLjiD3nJQozKnoSEnSC8b');
84
+ keyPair.getAddress().should.equal('tz2P2E8EgHaLA6A17rH3pE9T2tx6DA7D4siW');
85
+ assert_1.default.throws(() => keyPair.getExtendedKeys());
86
+ });
87
+ });
88
+ describe('should fail to create a KeyPair', function () {
89
+ it('from an invalid seed', () => {
90
+ const seed = { seed: Buffer.alloc(8) }; // Seed should be at least 128 bits (16 bytes, not 8)
91
+ assert_1.default.throws(() => new src_1.XtzLib.KeyPair(seed));
92
+ });
93
+ it('from an invalid public key', () => {
94
+ const source = {
95
+ pub: '01D63D',
96
+ };
97
+ assert_1.default.throws(() => new src_1.XtzLib.KeyPair(source));
98
+ });
99
+ it('from an invalid private key', () => {
100
+ const source = {
101
+ prv: '82A34E',
102
+ };
103
+ assert_1.default.throws(() => new src_1.XtzLib.KeyPair(source));
104
+ });
105
+ });
106
+ describe('getAddress', function () {
107
+ it('should get an address', () => {
108
+ const keyPair = new src_1.XtzLib.KeyPair(defaultSeed);
109
+ const address = keyPair.getAddress();
110
+ address.should.equal('tz2PtJ9zgEgFVTRqy6GXsst54tH3ksEnYvvS');
111
+ });
112
+ });
113
+ describe('getKeys', function () {
114
+ it('should get private and public keys in the protocol default format', () => {
115
+ const keyPair = new src_1.XtzLib.KeyPair(defaultSeed);
116
+ const { prv, pub } = keyPair.getKeys();
117
+ prv.should.equal('spsk2R6ek35CtfJMt2XHPWgFcf1wUGLK2fKbU3f4hWZNABo1YrrqP7');
118
+ pub.should.equal('sppk7csjXKT4wvUNCPMfAgZMNuvSjzW4Y2ZAKZEdvyEPtYagE6pCwkw');
119
+ });
120
+ it('should get private and public keys for a random seed', () => {
121
+ const keyPair = new src_1.XtzLib.KeyPair();
122
+ const { prv, pub } = keyPair.getKeys();
123
+ should_1.default.exist(prv);
124
+ should_1.default.exist(pub);
125
+ });
126
+ });
127
+ describe('getExtendedKeys', function () {
128
+ it('should get the keys in extended format', () => {
129
+ const keyPair = new src_1.XtzLib.KeyPair(defaultSeed);
130
+ const { xprv, xpub } = keyPair.getExtendedKeys();
131
+ xprv.should.equal('xprv9s21ZrQH143K3D8TXfvAJgHVfTEeQNW5Ys9wZtnUZkqPzFzSjbEJrWC1vZ4GnXCvR7rQL2UFX3RSuYeU9MrERm1XBvACow7c36vnz5iYyj2');
132
+ xpub.should.equal('xpub661MyMwAqRbcFhCvdhTAfpEEDV58oqDvv65YNHC686NNs4KbH8YZQJWVmrfbve7aAVHzxw8bKFxA7MLeDK6BbLfkE3bqkvHLPgaGHHtYGeY');
133
+ });
134
+ it('should get the keys in extended format for a random seed', () => {
135
+ const keyPair = new src_1.XtzLib.KeyPair();
136
+ const { xprv, xpub } = keyPair.getExtendedKeys();
137
+ should_1.default.exist(xprv);
138
+ should_1.default.exist(xpub);
139
+ });
140
+ });
141
+ });
142
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"keyPair.js","sourceRoot":"","sources":["../../../test/unit/keyPair.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\nimport should from 'should';\n\nimport { XtzLib } from '../../src';\n\ndescribe('Xtz KeyPair', function () {\n  const defaultSeed = { seed: Buffer.alloc(32) };\n\n  describe('should create a KeyPair', function () {\n    it('from an xpub', () => {\n      const source = {\n        pub: 'xpub661MyMwAqRbcFhCvdhTAfpEEDV58oqDvv65YNHC686NNs4KbH8YZQJWVmrfbve7aAVHzxw8bKFxA7MLeDK6BbLfkE3bqkvHLPgaGHHtYGeY',\n      };\n      const keyPair = new XtzLib.KeyPair(source);\n      const defaultKeys = keyPair.getKeys();\n      should.not.exist(defaultKeys.prv);\n      defaultKeys.pub.should.equal('sppk7csjXKT4wvUNCPMfAgZMNuvSjzW4Y2ZAKZEdvyEPtYagE6pCwkw');\n\n      const extendedKeys = keyPair.getExtendedKeys();\n      should.not.exist(extendedKeys.xprv);\n      extendedKeys.xpub.should.equal(\n        'xpub661MyMwAqRbcFhCvdhTAfpEEDV58oqDvv65YNHC686NNs4KbH8YZQJWVmrfbve7aAVHzxw8bKFxA7MLeDK6BbLfkE3bqkvHLPgaGHHtYGeY'\n      );\n    });\n\n    it('from an xprv', () => {\n      const source = {\n        prv: 'xprv9s21ZrQH143K3D8TXfvAJgHVfTEeQNW5Ys9wZtnUZkqPzFzSjbEJrWC1vZ4GnXCvR7rQL2UFX3RSuYeU9MrERm1XBvACow7c36vnz5iYyj2',\n      };\n      const keyPair = new XtzLib.KeyPair(source);\n      const defaultKeys = keyPair.getKeys();\n      defaultKeys.prv!.should.equal('spsk2R6ek35CtfJMt2XHPWgFcf1wUGLK2fKbU3f4hWZNABo1YrrqP7');\n      defaultKeys.pub.should.equal('sppk7csjXKT4wvUNCPMfAgZMNuvSjzW4Y2ZAKZEdvyEPtYagE6pCwkw');\n\n      const extendedKeys = keyPair.getExtendedKeys();\n      extendedKeys.xprv!.should.equal(\n        'xprv9s21ZrQH143K3D8TXfvAJgHVfTEeQNW5Ys9wZtnUZkqPzFzSjbEJrWC1vZ4GnXCvR7rQL2UFX3RSuYeU9MrERm1XBvACow7c36vnz5iYyj2'\n      );\n      extendedKeys.xpub.should.equal(\n        'xpub661MyMwAqRbcFhCvdhTAfpEEDV58oqDvv65YNHC686NNs4KbH8YZQJWVmrfbve7aAVHzxw8bKFxA7MLeDK6BbLfkE3bqkvHLPgaGHHtYGeY'\n      );\n    });\n\n    it('from an uncompressed public key', () => {\n      const source = {\n        pub: '04D63D9FD9FD772A989C5B90EDB37716406356E98273E5F98FE07652247A3A827503E948A2FDBF74A981D4E0054F10EDA7042C2D469F44473D3C7791E0E326E355',\n      };\n      const keyPair = new XtzLib.KeyPair(source);\n      const defaultKeys = keyPair.getKeys();\n      should.not.exist(defaultKeys.prv);\n      defaultKeys.pub.should.equal('sppk7csjXKT4wvUNCPMfAgZMNuvSjzW4Y2ZAKZEdvyEPtYagE6pCwkw');\n\n      assert.throws(() => keyPair.getExtendedKeys());\n    });\n\n    it('from a compressed public key', () => {\n      const source = {\n        pub: '03D63D9FD9FD772A989C5B90EDB37716406356E98273E5F98FE07652247A3A8275',\n      };\n      const keyPair = new XtzLib.KeyPair(source);\n      const defaultKeys = keyPair.getKeys();\n      should.not.exist(defaultKeys.prv);\n      defaultKeys.pub.should.equal('sppk7csjXKT4wvUNCPMfAgZMNuvSjzW4Y2ZAKZEdvyEPtYagE6pCwkw');\n\n      assert.throws(() => keyPair.getExtendedKeys());\n    });\n\n    it('from a Tezos public key', () => {\n      const source = {\n        pub: 'sppk7csjXKT4wvUNCPMfAgZMNuvSjzW4Y2ZAKZEdvyEPtYagE6pCwkw',\n      };\n      const keyPair = new XtzLib.KeyPair(source);\n      const defaultKeys = keyPair.getKeys();\n      should.not.exist(defaultKeys.prv);\n      defaultKeys.pub.should.equal('sppk7csjXKT4wvUNCPMfAgZMNuvSjzW4Y2ZAKZEdvyEPtYagE6pCwkw');\n\n      assert.throws(() => keyPair.getExtendedKeys());\n    });\n\n    it('from a raw private key', () => {\n      const source = {\n        prv: '82A34E3867EA7EA4E67E27865D500AE84E98D07AB1BAB06526F0A5A5FDCC3EBA',\n      };\n      const keyPair = new XtzLib.KeyPair(source);\n      const defaultKeys = keyPair.getKeys();\n      defaultKeys.prv!.should.equal('spsk2R6ek35CtfJMt2XHPWgFcf1wUGLK2fKbU3f4hWZNABo1YrrqP7');\n      defaultKeys.pub.should.equal('sppk7csjXKT4wvUNCPMfAgZMNuvSjzW4Y2ZAKZEdvyEPtYagE6pCwkw');\n\n      assert.throws(() => keyPair.getExtendedKeys());\n    });\n\n    it('from a Tezos private key', () => {\n      const source = {\n        prv: 'spsk2cbiVsAvpGKmau9XcMscL3NRwjkyT575N5AyAofcoj41x6g6TL',\n      };\n      const keyPair = new XtzLib.KeyPair(source);\n      const defaultKeys = keyPair.getKeys();\n      defaultKeys.prv!.should.equal('spsk2cbiVsAvpGKmau9XcMscL3NRwjkyT575N5AyAofcoj41x6g6TL');\n      defaultKeys.pub.should.equal('sppk7ZWB8diU2TWehxdkWCV2DTFvn1hPz4qLjiD3nJQozKnoSEnSC8b');\n      keyPair.getAddress().should.equal('tz2P2E8EgHaLA6A17rH3pE9T2tx6DA7D4siW');\n\n      assert.throws(() => keyPair.getExtendedKeys());\n    });\n  });\n\n  describe('should fail to create a KeyPair', function () {\n    it('from an invalid seed', () => {\n      const seed = { seed: Buffer.alloc(8) }; //  Seed should be at least 128 bits (16 bytes, not 8)\n      assert.throws(() => new XtzLib.KeyPair(seed));\n    });\n\n    it('from an invalid public key', () => {\n      const source = {\n        pub: '01D63D',\n      };\n      assert.throws(() => new XtzLib.KeyPair(source));\n    });\n\n    it('from an invalid private key', () => {\n      const source = {\n        prv: '82A34E',\n      };\n      assert.throws(() => new XtzLib.KeyPair(source));\n    });\n  });\n\n  describe('getAddress', function () {\n    it('should get an address', () => {\n      const keyPair = new XtzLib.KeyPair(defaultSeed);\n      const address = keyPair.getAddress();\n      address.should.equal('tz2PtJ9zgEgFVTRqy6GXsst54tH3ksEnYvvS');\n    });\n  });\n\n  describe('getKeys', function () {\n    it('should get private and public keys in the protocol default format', () => {\n      const keyPair = new XtzLib.KeyPair(defaultSeed);\n      const { prv, pub } = keyPair.getKeys();\n      prv!.should.equal('spsk2R6ek35CtfJMt2XHPWgFcf1wUGLK2fKbU3f4hWZNABo1YrrqP7');\n      pub.should.equal('sppk7csjXKT4wvUNCPMfAgZMNuvSjzW4Y2ZAKZEdvyEPtYagE6pCwkw');\n    });\n\n    it('should get private and public keys for a random seed', () => {\n      const keyPair = new XtzLib.KeyPair();\n      const { prv, pub } = keyPair.getKeys();\n      should.exist(prv);\n      should.exist(pub);\n    });\n  });\n\n  describe('getExtendedKeys', function () {\n    it('should get the keys in extended format', () => {\n      const keyPair = new XtzLib.KeyPair(defaultSeed);\n      const { xprv, xpub } = keyPair.getExtendedKeys();\n      xprv!.should.equal(\n        'xprv9s21ZrQH143K3D8TXfvAJgHVfTEeQNW5Ys9wZtnUZkqPzFzSjbEJrWC1vZ4GnXCvR7rQL2UFX3RSuYeU9MrERm1XBvACow7c36vnz5iYyj2'\n      );\n      xpub.should.equal(\n        'xpub661MyMwAqRbcFhCvdhTAfpEEDV58oqDvv65YNHC686NNs4KbH8YZQJWVmrfbve7aAVHzxw8bKFxA7MLeDK6BbLfkE3bqkvHLPgaGHHtYGeY'\n      );\n    });\n\n    it('should get the keys in extended format  for a random seed', () => {\n      const keyPair = new XtzLib.KeyPair();\n      const { xprv, xpub } = keyPair.getExtendedKeys();\n      should.exist(xprv);\n      should.exist(xpub);\n    });\n  });\n});\n"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=offlineTransactionBuilder.d.ts.map