@lightprotocol/compressed-token 0.3.4 → 0.4.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/browser/index.cjs +229 -63
- package/dist/cjs/browser/index.cjs.map +1 -1
- package/dist/cjs/node/index.cjs +229 -63
- package/dist/cjs/node/index.cjs.map +1 -1
- package/dist/es/browser/index.js +230 -64
- package/dist/es/browser/index.js.map +1 -1
- package/dist/types/index.d.ts +234 -31
- package/package.json +5 -5
package/dist/es/browser/index.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { getIndexOrAdd, bn, padOutputStateMerkleTrees, useWallet, confirmConfig, defaultStaticAccountsStruct, toArray, LightSystemProgram, defaultTestStateTreeAccounts, sumUpLamports, validateSufficientBalance, validateSameOwner, dedupeSigner, buildAndSignTx, sendAndConfirmTx } from '@lightprotocol/stateless.js';
|
|
2
|
-
import { PublicKey,
|
|
2
|
+
import { PublicKey, SystemProgram, TransactionInstruction, Transaction, sendAndConfirmTransaction, Keypair, Connection, ComputeBudgetProgram } from '@solana/web3.js';
|
|
3
3
|
import { AnchorProvider, setProvider, Program } from '@coral-xyz/anchor';
|
|
4
4
|
|
|
5
5
|
const IDL = {
|
|
@@ -9,16 +9,17 @@ const IDL = {
|
|
|
9
9
|
{
|
|
10
10
|
name: 'createTokenPool',
|
|
11
11
|
docs: [
|
|
12
|
-
'This instruction
|
|
13
|
-
'token
|
|
14
|
-
'
|
|
15
|
-
'
|
|
12
|
+
'This instruction creates a token pool for a given mint. Every spl mint',
|
|
13
|
+
'can have one token pool. When a token is compressed the tokens are',
|
|
14
|
+
'transferrred to the token pool, and their compressed equivalent is',
|
|
15
|
+
'minted into a Merkle tree.',
|
|
16
16
|
],
|
|
17
17
|
accounts: [
|
|
18
18
|
{
|
|
19
19
|
name: 'feePayer',
|
|
20
20
|
isMut: true,
|
|
21
21
|
isSigner: true,
|
|
22
|
+
docs: ['UNCHECKED: only pays fees.'],
|
|
22
23
|
},
|
|
23
24
|
{
|
|
24
25
|
name: 'tokenPoolPda',
|
|
@@ -54,13 +55,17 @@ const IDL = {
|
|
|
54
55
|
'Mints tokens from an spl token mint to a list of compressed accounts.',
|
|
55
56
|
'Minted tokens are transferred to a pool account owned by the compressed',
|
|
56
57
|
'token program. The instruction creates one compressed output account for',
|
|
57
|
-
'every amount and pubkey input pair
|
|
58
|
+
'every amount and pubkey input pair. A constant amount of lamports can be',
|
|
59
|
+
'transferred to each output account to enable. A use case to add lamports',
|
|
60
|
+
'to a compressed token account is to prevent spam. This is the only way',
|
|
61
|
+
'to add lamports to a compressed token account.',
|
|
58
62
|
],
|
|
59
63
|
accounts: [
|
|
60
64
|
{
|
|
61
65
|
name: 'feePayer',
|
|
62
66
|
isMut: true,
|
|
63
67
|
isSigner: true,
|
|
68
|
+
docs: ['UNCHECKED: only pays fees.'],
|
|
64
69
|
},
|
|
65
70
|
{
|
|
66
71
|
name: 'authority',
|
|
@@ -81,6 +86,9 @@ const IDL = {
|
|
|
81
86
|
name: 'tokenPoolPda',
|
|
82
87
|
isMut: true,
|
|
83
88
|
isSigner: false,
|
|
89
|
+
docs: [
|
|
90
|
+
'account to a token account of a different mint will fail',
|
|
91
|
+
],
|
|
84
92
|
},
|
|
85
93
|
{
|
|
86
94
|
name: 'tokenProgram',
|
|
@@ -101,6 +109,7 @@ const IDL = {
|
|
|
101
109
|
name: 'noopProgram',
|
|
102
110
|
isMut: false,
|
|
103
111
|
isSigner: false,
|
|
112
|
+
docs: ['programs'],
|
|
104
113
|
},
|
|
105
114
|
{
|
|
106
115
|
name: 'accountCompressionAuthority',
|
|
@@ -127,6 +136,12 @@ const IDL = {
|
|
|
127
136
|
isMut: false,
|
|
128
137
|
isSigner: false,
|
|
129
138
|
},
|
|
139
|
+
{
|
|
140
|
+
name: 'solPoolPda',
|
|
141
|
+
isMut: true,
|
|
142
|
+
isSigner: false,
|
|
143
|
+
isOptional: true,
|
|
144
|
+
},
|
|
130
145
|
],
|
|
131
146
|
args: [
|
|
132
147
|
{
|
|
@@ -141,20 +156,42 @@ const IDL = {
|
|
|
141
156
|
vec: 'u64',
|
|
142
157
|
},
|
|
143
158
|
},
|
|
159
|
+
{
|
|
160
|
+
name: 'lamports',
|
|
161
|
+
type: {
|
|
162
|
+
option: 'u64',
|
|
163
|
+
},
|
|
164
|
+
},
|
|
144
165
|
],
|
|
145
166
|
},
|
|
146
167
|
{
|
|
147
168
|
name: 'transfer',
|
|
169
|
+
docs: [
|
|
170
|
+
'Transfers compressed tokens from one account to another. All accounts',
|
|
171
|
+
'must be of the same mint. Additional spl tokens can be compressed or',
|
|
172
|
+
'decompressed. In one transaction only compression or decompression is',
|
|
173
|
+
'possible. Lamports can be transferred alongside tokens. If output token',
|
|
174
|
+
'accounts specify less lamports than inputs the remaining lamports are',
|
|
175
|
+
'transferred to an output compressed account. Signer must be owner or',
|
|
176
|
+
'delegate. If a delegated token account is transferred the delegate is',
|
|
177
|
+
'not preserved.',
|
|
178
|
+
],
|
|
148
179
|
accounts: [
|
|
149
180
|
{
|
|
150
181
|
name: 'feePayer',
|
|
151
182
|
isMut: true,
|
|
152
183
|
isSigner: true,
|
|
184
|
+
docs: ['UNCHECKED: only pays fees.'],
|
|
153
185
|
},
|
|
154
186
|
{
|
|
155
187
|
name: 'authority',
|
|
156
188
|
isMut: false,
|
|
157
189
|
isSigner: true,
|
|
190
|
+
docs: [
|
|
191
|
+
'Authority is verified through proof since both owner and delegate',
|
|
192
|
+
'are included in the token data hash, which is a public input to the',
|
|
193
|
+
'validity proof.',
|
|
194
|
+
],
|
|
158
195
|
},
|
|
159
196
|
{
|
|
160
197
|
name: 'cpiAuthorityPda',
|
|
@@ -190,6 +227,10 @@ const IDL = {
|
|
|
190
227
|
name: 'selfProgram',
|
|
191
228
|
isMut: false,
|
|
192
229
|
isSigner: false,
|
|
230
|
+
docs: [
|
|
231
|
+
'(different program) checked in light system program to derive',
|
|
232
|
+
'cpi_authority_pda and check that this program is the signer of the cpi.',
|
|
233
|
+
],
|
|
193
234
|
},
|
|
194
235
|
{
|
|
195
236
|
name: 'tokenPoolPda',
|
|
@@ -224,16 +265,30 @@ const IDL = {
|
|
|
224
265
|
},
|
|
225
266
|
{
|
|
226
267
|
name: 'approve',
|
|
268
|
+
docs: [
|
|
269
|
+
'Delegates an amount to a delegate. A compressed token account is either',
|
|
270
|
+
'completely delegated or not. Prior delegates are not preserved. Cannot',
|
|
271
|
+
'be called by a delegate.',
|
|
272
|
+
'The instruction creates two output accounts:',
|
|
273
|
+
'1. one account with delegated amount',
|
|
274
|
+
'2. one account with remaining(change) amount',
|
|
275
|
+
],
|
|
227
276
|
accounts: [
|
|
228
277
|
{
|
|
229
278
|
name: 'feePayer',
|
|
230
279
|
isMut: true,
|
|
231
280
|
isSigner: true,
|
|
281
|
+
docs: ['UNCHECKED: only pays fees.'],
|
|
232
282
|
},
|
|
233
283
|
{
|
|
234
284
|
name: 'authority',
|
|
235
285
|
isMut: false,
|
|
236
286
|
isSigner: true,
|
|
287
|
+
docs: [
|
|
288
|
+
'Authority is verified through proof since both owner and delegate',
|
|
289
|
+
'are included in the token data hash, which is a public input to the',
|
|
290
|
+
'validity proof.',
|
|
291
|
+
],
|
|
237
292
|
},
|
|
238
293
|
{
|
|
239
294
|
name: 'cpiAuthorityPda',
|
|
@@ -269,6 +324,10 @@ const IDL = {
|
|
|
269
324
|
name: 'selfProgram',
|
|
270
325
|
isMut: false,
|
|
271
326
|
isSigner: false,
|
|
327
|
+
docs: [
|
|
328
|
+
'(different program) checked in light system program to derive',
|
|
329
|
+
'cpi_authority_pda and check that this program is the signer of the cpi.',
|
|
330
|
+
],
|
|
272
331
|
},
|
|
273
332
|
{
|
|
274
333
|
name: 'systemProgram',
|
|
@@ -285,16 +344,26 @@ const IDL = {
|
|
|
285
344
|
},
|
|
286
345
|
{
|
|
287
346
|
name: 'revoke',
|
|
347
|
+
docs: [
|
|
348
|
+
'Revokes a delegation. The instruction merges all inputs into one output',
|
|
349
|
+
'account. Cannot be called by a delegate. Delegates are not preserved.',
|
|
350
|
+
],
|
|
288
351
|
accounts: [
|
|
289
352
|
{
|
|
290
353
|
name: 'feePayer',
|
|
291
354
|
isMut: true,
|
|
292
355
|
isSigner: true,
|
|
356
|
+
docs: ['UNCHECKED: only pays fees.'],
|
|
293
357
|
},
|
|
294
358
|
{
|
|
295
359
|
name: 'authority',
|
|
296
360
|
isMut: false,
|
|
297
361
|
isSigner: true,
|
|
362
|
+
docs: [
|
|
363
|
+
'Authority is verified through proof since both owner and delegate',
|
|
364
|
+
'are included in the token data hash, which is a public input to the',
|
|
365
|
+
'validity proof.',
|
|
366
|
+
],
|
|
298
367
|
},
|
|
299
368
|
{
|
|
300
369
|
name: 'cpiAuthorityPda',
|
|
@@ -330,6 +399,10 @@ const IDL = {
|
|
|
330
399
|
name: 'selfProgram',
|
|
331
400
|
isMut: false,
|
|
332
401
|
isSigner: false,
|
|
402
|
+
docs: [
|
|
403
|
+
'(different program) checked in light system program to derive',
|
|
404
|
+
'cpi_authority_pda and check that this program is the signer of the cpi.',
|
|
405
|
+
],
|
|
333
406
|
},
|
|
334
407
|
{
|
|
335
408
|
name: 'systemProgram',
|
|
@@ -346,11 +419,16 @@ const IDL = {
|
|
|
346
419
|
},
|
|
347
420
|
{
|
|
348
421
|
name: 'freeze',
|
|
422
|
+
docs: [
|
|
423
|
+
'Freezes compressed token accounts. Inputs must not be frozen. Creates as',
|
|
424
|
+
'many outputs as inputs. Balances and delegates are preserved.',
|
|
425
|
+
],
|
|
349
426
|
accounts: [
|
|
350
427
|
{
|
|
351
428
|
name: 'feePayer',
|
|
352
429
|
isMut: true,
|
|
353
430
|
isSigner: true,
|
|
431
|
+
docs: ['UNCHECKED: only pays fees.'],
|
|
354
432
|
},
|
|
355
433
|
{
|
|
356
434
|
name: 'authority',
|
|
@@ -391,6 +469,10 @@ const IDL = {
|
|
|
391
469
|
name: 'selfProgram',
|
|
392
470
|
isMut: false,
|
|
393
471
|
isSigner: false,
|
|
472
|
+
docs: [
|
|
473
|
+
'(different program) checked in light system program to derive',
|
|
474
|
+
'cpi_authority_pda and check that this program is the signer of the cpi.',
|
|
475
|
+
],
|
|
394
476
|
},
|
|
395
477
|
{
|
|
396
478
|
name: 'systemProgram',
|
|
@@ -412,11 +494,16 @@ const IDL = {
|
|
|
412
494
|
},
|
|
413
495
|
{
|
|
414
496
|
name: 'thaw',
|
|
497
|
+
docs: [
|
|
498
|
+
'Thaws frozen compressed token accounts. Inputs must be frozen. Creates',
|
|
499
|
+
'as many outputs as inputs. Balances and delegates are preserved.',
|
|
500
|
+
],
|
|
415
501
|
accounts: [
|
|
416
502
|
{
|
|
417
503
|
name: 'feePayer',
|
|
418
504
|
isMut: true,
|
|
419
505
|
isSigner: true,
|
|
506
|
+
docs: ['UNCHECKED: only pays fees.'],
|
|
420
507
|
},
|
|
421
508
|
{
|
|
422
509
|
name: 'authority',
|
|
@@ -457,6 +544,10 @@ const IDL = {
|
|
|
457
544
|
name: 'selfProgram',
|
|
458
545
|
isMut: false,
|
|
459
546
|
isSigner: false,
|
|
547
|
+
docs: [
|
|
548
|
+
'(different program) checked in light system program to derive',
|
|
549
|
+
'cpi_authority_pda and check that this program is the signer of the cpi.',
|
|
550
|
+
],
|
|
460
551
|
},
|
|
461
552
|
{
|
|
462
553
|
name: 'systemProgram',
|
|
@@ -478,22 +569,48 @@ const IDL = {
|
|
|
478
569
|
},
|
|
479
570
|
{
|
|
480
571
|
name: 'burn',
|
|
572
|
+
docs: [
|
|
573
|
+
'Burns compressed tokens and spl tokens from the pool account. Delegates',
|
|
574
|
+
'can burn tokens. The output compressed token account remains delegated.',
|
|
575
|
+
'Creates one output compressed token account.',
|
|
576
|
+
],
|
|
481
577
|
accounts: [
|
|
482
578
|
{
|
|
483
579
|
name: 'feePayer',
|
|
484
580
|
isMut: true,
|
|
485
581
|
isSigner: true,
|
|
582
|
+
docs: ['UNCHECKED: only pays fees.'],
|
|
486
583
|
},
|
|
487
584
|
{
|
|
488
585
|
name: 'authority',
|
|
489
586
|
isMut: false,
|
|
490
587
|
isSigner: true,
|
|
588
|
+
docs: [
|
|
589
|
+
'Authority is verified through proof since both owner and delegate',
|
|
590
|
+
'are included in the token data hash, which is a public input to the',
|
|
591
|
+
'validity proof.',
|
|
592
|
+
],
|
|
491
593
|
},
|
|
492
594
|
{
|
|
493
595
|
name: 'cpiAuthorityPda',
|
|
494
596
|
isMut: false,
|
|
495
597
|
isSigner: false,
|
|
496
598
|
},
|
|
599
|
+
{
|
|
600
|
+
name: 'mint',
|
|
601
|
+
isMut: true,
|
|
602
|
+
isSigner: false,
|
|
603
|
+
},
|
|
604
|
+
{
|
|
605
|
+
name: 'tokenPoolPda',
|
|
606
|
+
isMut: true,
|
|
607
|
+
isSigner: false,
|
|
608
|
+
},
|
|
609
|
+
{
|
|
610
|
+
name: 'tokenProgram',
|
|
611
|
+
isMut: false,
|
|
612
|
+
isSigner: false,
|
|
613
|
+
},
|
|
497
614
|
{
|
|
498
615
|
name: 'lightSystemProgram',
|
|
499
616
|
isMut: false,
|
|
@@ -549,11 +666,17 @@ const IDL = {
|
|
|
549
666
|
name: 'feePayer',
|
|
550
667
|
isMut: true,
|
|
551
668
|
isSigner: true,
|
|
669
|
+
docs: ['UNCHECKED: only pays fees.'],
|
|
552
670
|
},
|
|
553
671
|
{
|
|
554
672
|
name: 'authority',
|
|
555
673
|
isMut: false,
|
|
556
674
|
isSigner: true,
|
|
675
|
+
docs: [
|
|
676
|
+
'Authority is verified through proof since both owner and delegate',
|
|
677
|
+
'are included in the token data hash, which is a public input to the',
|
|
678
|
+
'validity proof.',
|
|
679
|
+
],
|
|
557
680
|
},
|
|
558
681
|
{
|
|
559
682
|
name: 'cpiAuthorityPda',
|
|
@@ -589,6 +712,10 @@ const IDL = {
|
|
|
589
712
|
name: 'selfProgram',
|
|
590
713
|
isMut: false,
|
|
591
714
|
isSigner: false,
|
|
715
|
+
docs: [
|
|
716
|
+
'(different program) checked in light system program to derive',
|
|
717
|
+
'cpi_authority_pda and check that this program is the signer of the cpi.',
|
|
718
|
+
],
|
|
592
719
|
},
|
|
593
720
|
{
|
|
594
721
|
name: 'tokenPoolPda',
|
|
@@ -630,24 +757,6 @@ const IDL = {
|
|
|
630
757
|
],
|
|
631
758
|
},
|
|
632
759
|
],
|
|
633
|
-
accounts: [
|
|
634
|
-
{
|
|
635
|
-
name: 'RegisteredProgram',
|
|
636
|
-
type: {
|
|
637
|
-
kind: 'struct',
|
|
638
|
-
fields: [
|
|
639
|
-
{
|
|
640
|
-
name: 'registeredProgramId',
|
|
641
|
-
type: 'publicKey',
|
|
642
|
-
},
|
|
643
|
-
{
|
|
644
|
-
name: 'groupAuthorityPda',
|
|
645
|
-
type: 'publicKey',
|
|
646
|
-
},
|
|
647
|
-
],
|
|
648
|
-
},
|
|
649
|
-
},
|
|
650
|
-
],
|
|
651
760
|
types: [
|
|
652
761
|
{
|
|
653
762
|
name: 'AccessMetadata',
|
|
@@ -662,7 +771,7 @@ const IDL = {
|
|
|
662
771
|
{
|
|
663
772
|
name: 'programOwner',
|
|
664
773
|
docs: [
|
|
665
|
-
'
|
|
774
|
+
'Program owner of the Merkle tree. This will be used for program owned Merkle trees.',
|
|
666
775
|
],
|
|
667
776
|
type: 'publicKey',
|
|
668
777
|
},
|
|
@@ -816,9 +925,9 @@ const IDL = {
|
|
|
816
925
|
{
|
|
817
926
|
name: 'delegatedTransfer',
|
|
818
927
|
docs: [
|
|
819
|
-
'
|
|
928
|
+
'Is required if the signer is delegate,',
|
|
929
|
+
'-> delegate is authority account,',
|
|
820
930
|
'owner = Some(owner) is the owner of the token account.',
|
|
821
|
-
'Is set if the signer is delegate',
|
|
822
931
|
],
|
|
823
932
|
type: {
|
|
824
933
|
option: {
|
|
@@ -860,11 +969,20 @@ const IDL = {
|
|
|
860
969
|
},
|
|
861
970
|
},
|
|
862
971
|
},
|
|
972
|
+
{
|
|
973
|
+
name: 'lamportsChangeAccountMerkleTreeIndex',
|
|
974
|
+
type: {
|
|
975
|
+
option: 'u8',
|
|
976
|
+
},
|
|
977
|
+
},
|
|
863
978
|
],
|
|
864
979
|
},
|
|
865
980
|
},
|
|
866
981
|
{
|
|
867
982
|
name: 'DelegatedTransfer',
|
|
983
|
+
docs: [
|
|
984
|
+
'Struct to provide the owner when the delegate is signer of the transaction.',
|
|
985
|
+
],
|
|
868
986
|
type: {
|
|
869
987
|
kind: 'struct',
|
|
870
988
|
fields: [
|
|
@@ -874,7 +992,15 @@ const IDL = {
|
|
|
874
992
|
},
|
|
875
993
|
{
|
|
876
994
|
name: 'delegateChangeAccountIndex',
|
|
877
|
-
|
|
995
|
+
docs: [
|
|
996
|
+
'Index of change compressed account in output compressed accounts. In',
|
|
997
|
+
"case that the delegate didn't spend the complete delegated compressed",
|
|
998
|
+
'account balance the change compressed account will be delegated to her',
|
|
999
|
+
'as well.',
|
|
1000
|
+
],
|
|
1001
|
+
type: {
|
|
1002
|
+
option: 'u8',
|
|
1003
|
+
},
|
|
878
1004
|
},
|
|
879
1005
|
],
|
|
880
1006
|
},
|
|
@@ -910,6 +1036,15 @@ const IDL = {
|
|
|
910
1036
|
option: 'u64',
|
|
911
1037
|
},
|
|
912
1038
|
},
|
|
1039
|
+
{
|
|
1040
|
+
name: 'tlv',
|
|
1041
|
+
docs: [
|
|
1042
|
+
'Placeholder for TokenExtension tlv data (unimplemented)',
|
|
1043
|
+
],
|
|
1044
|
+
type: {
|
|
1045
|
+
option: 'bytes',
|
|
1046
|
+
},
|
|
1047
|
+
},
|
|
913
1048
|
],
|
|
914
1049
|
},
|
|
915
1050
|
},
|
|
@@ -1171,6 +1306,18 @@ const IDL = {
|
|
|
1171
1306
|
name: 'leafIndex',
|
|
1172
1307
|
type: 'u32',
|
|
1173
1308
|
},
|
|
1309
|
+
{
|
|
1310
|
+
name: 'queueIndex',
|
|
1311
|
+
docs: [
|
|
1312
|
+
'Index of leaf in queue. Placeholder of batched Merkle tree updates',
|
|
1313
|
+
'currently unimplemented.',
|
|
1314
|
+
],
|
|
1315
|
+
type: {
|
|
1316
|
+
option: {
|
|
1317
|
+
defined: 'QueueIndex',
|
|
1318
|
+
},
|
|
1319
|
+
},
|
|
1320
|
+
},
|
|
1174
1321
|
],
|
|
1175
1322
|
},
|
|
1176
1323
|
},
|
|
@@ -1197,6 +1344,15 @@ const IDL = {
|
|
|
1197
1344
|
name: 'merkleTreeIndex',
|
|
1198
1345
|
type: 'u8',
|
|
1199
1346
|
},
|
|
1347
|
+
{
|
|
1348
|
+
name: 'tlv',
|
|
1349
|
+
docs: [
|
|
1350
|
+
'Placeholder for TokenExtension tlv data (unimplemented)',
|
|
1351
|
+
],
|
|
1352
|
+
type: {
|
|
1353
|
+
option: 'bytes',
|
|
1354
|
+
},
|
|
1355
|
+
},
|
|
1200
1356
|
],
|
|
1201
1357
|
},
|
|
1202
1358
|
},
|
|
@@ -1274,6 +1430,24 @@ const IDL = {
|
|
|
1274
1430
|
],
|
|
1275
1431
|
},
|
|
1276
1432
|
},
|
|
1433
|
+
{
|
|
1434
|
+
name: 'QueueIndex',
|
|
1435
|
+
type: {
|
|
1436
|
+
kind: 'struct',
|
|
1437
|
+
fields: [
|
|
1438
|
+
{
|
|
1439
|
+
name: 'queueId',
|
|
1440
|
+
docs: ['Id of queue in queue account.'],
|
|
1441
|
+
type: 'u8',
|
|
1442
|
+
},
|
|
1443
|
+
{
|
|
1444
|
+
name: 'index',
|
|
1445
|
+
docs: ['Index of compressed account hash in queue.'],
|
|
1446
|
+
type: 'u16',
|
|
1447
|
+
},
|
|
1448
|
+
],
|
|
1449
|
+
},
|
|
1450
|
+
},
|
|
1277
1451
|
{
|
|
1278
1452
|
name: 'RolloverMetadata',
|
|
1279
1453
|
type: {
|
|
@@ -1360,6 +1534,15 @@ const IDL = {
|
|
|
1360
1534
|
defined: 'AccountState',
|
|
1361
1535
|
},
|
|
1362
1536
|
},
|
|
1537
|
+
{
|
|
1538
|
+
name: 'tlv',
|
|
1539
|
+
docs: [
|
|
1540
|
+
'Placeholder for TokenExtension tlv data (unimplemented)',
|
|
1541
|
+
],
|
|
1542
|
+
type: {
|
|
1543
|
+
option: 'bytes',
|
|
1544
|
+
},
|
|
1545
|
+
},
|
|
1363
1546
|
],
|
|
1364
1547
|
},
|
|
1365
1548
|
},
|
|
@@ -1414,11 +1597,13 @@ function packCompressedTokenAccounts(params) {
|
|
|
1414
1597
|
merkleTreePubkeyIndex,
|
|
1415
1598
|
nullifierQueuePubkeyIndex,
|
|
1416
1599
|
leafIndex: account.compressedAccount.leafIndex,
|
|
1600
|
+
queueIndex: null,
|
|
1417
1601
|
},
|
|
1418
1602
|
rootIndex: rootIndices[index],
|
|
1419
1603
|
lamports: account.compressedAccount.lamports.eq(bn(0))
|
|
1420
1604
|
? null
|
|
1421
1605
|
: account.compressedAccount.lamports,
|
|
1606
|
+
tlv: null,
|
|
1422
1607
|
});
|
|
1423
1608
|
});
|
|
1424
1609
|
/// pack output state trees
|
|
@@ -1433,6 +1618,7 @@ function packCompressedTokenAccounts(params) {
|
|
|
1433
1618
|
? null
|
|
1434
1619
|
: tokenTransferOutputs[index].lamports,
|
|
1435
1620
|
merkleTreeIndex,
|
|
1621
|
+
tlv: null,
|
|
1436
1622
|
});
|
|
1437
1623
|
});
|
|
1438
1624
|
// to meta
|
|
@@ -6005,33 +6191,6 @@ function addSigners(keys, ownerOrAuthority, multiSigners) {
|
|
|
6005
6191
|
return keys;
|
|
6006
6192
|
}
|
|
6007
6193
|
|
|
6008
|
-
/** TODO: docs */
|
|
6009
|
-
const approveInstructionData = struct([u8('instruction'), u64('amount')]);
|
|
6010
|
-
/**
|
|
6011
|
-
* Construct an Approve instruction
|
|
6012
|
-
*
|
|
6013
|
-
* @param account Account to set the delegate for
|
|
6014
|
-
* @param delegate Account authorized to transfer tokens from the account
|
|
6015
|
-
* @param owner Owner of the account
|
|
6016
|
-
* @param amount Maximum number of tokens the delegate may transfer
|
|
6017
|
-
* @param multiSigners Signing accounts if `owner` is a multisig
|
|
6018
|
-
* @param programId SPL Token program account
|
|
6019
|
-
*
|
|
6020
|
-
* @return Instruction to add to a transaction
|
|
6021
|
-
*/
|
|
6022
|
-
function createApproveInstruction(account, delegate, owner, amount, multiSigners = [], programId = TOKEN_PROGRAM_ID) {
|
|
6023
|
-
const keys = addSigners([
|
|
6024
|
-
{ pubkey: account, isSigner: false, isWritable: true },
|
|
6025
|
-
{ pubkey: delegate, isSigner: false, isWritable: false },
|
|
6026
|
-
], owner, multiSigners);
|
|
6027
|
-
const data = Buffer.alloc(approveInstructionData.span);
|
|
6028
|
-
approveInstructionData.encode({
|
|
6029
|
-
instruction: TokenInstruction.Approve,
|
|
6030
|
-
amount: BigInt(amount),
|
|
6031
|
-
}, data);
|
|
6032
|
-
return new TransactionInstruction({ keys, programId, data });
|
|
6033
|
-
}
|
|
6034
|
-
|
|
6035
6194
|
var AccountType;
|
|
6036
6195
|
(function (AccountType) {
|
|
6037
6196
|
AccountType[AccountType["Uninitialized"] = 0] = "Uninitialized";
|
|
@@ -6355,6 +6514,7 @@ function createTransferOutputState(inputCompressedTokenAccounts, toAddress, amou
|
|
|
6355
6514
|
owner: toAddress,
|
|
6356
6515
|
amount,
|
|
6357
6516
|
lamports: inputLamports,
|
|
6517
|
+
tlv: null,
|
|
6358
6518
|
},
|
|
6359
6519
|
];
|
|
6360
6520
|
}
|
|
@@ -6366,11 +6526,13 @@ function createTransferOutputState(inputCompressedTokenAccounts, toAddress, amou
|
|
|
6366
6526
|
owner: inputCompressedTokenAccounts[0].parsed.owner,
|
|
6367
6527
|
amount: changeAmount,
|
|
6368
6528
|
lamports: inputLamports,
|
|
6529
|
+
tlv: null,
|
|
6369
6530
|
},
|
|
6370
6531
|
{
|
|
6371
6532
|
owner: toAddress,
|
|
6372
6533
|
amount,
|
|
6373
6534
|
lamports: bn(0),
|
|
6535
|
+
tlv: null,
|
|
6374
6536
|
},
|
|
6375
6537
|
];
|
|
6376
6538
|
return outputCompressedAccounts;
|
|
@@ -6399,6 +6561,7 @@ function createDecompressOutputState(inputCompressedTokenAccounts, amount) {
|
|
|
6399
6561
|
owner: inputCompressedTokenAccounts[0].parsed.owner,
|
|
6400
6562
|
amount: changeAmount,
|
|
6401
6563
|
lamports: inputLamports,
|
|
6564
|
+
tlv: null,
|
|
6402
6565
|
},
|
|
6403
6566
|
];
|
|
6404
6567
|
return tokenTransferOutputs;
|
|
@@ -6497,7 +6660,7 @@ class CompressedTokenProgram {
|
|
|
6497
6660
|
const amounts = toArray(amount).map(amount => bn(amount));
|
|
6498
6661
|
const toPubkeys = toArray(toPubkey);
|
|
6499
6662
|
const instruction = await this.program.methods
|
|
6500
|
-
.mintTo(toPubkeys, amounts)
|
|
6663
|
+
.mintTo(toPubkeys, amounts, null)
|
|
6501
6664
|
.accounts({
|
|
6502
6665
|
feePayer,
|
|
6503
6666
|
authority,
|
|
@@ -6512,6 +6675,7 @@ class CompressedTokenProgram {
|
|
|
6512
6675
|
accountCompressionProgram: systemKeys.accountCompressionProgram,
|
|
6513
6676
|
merkleTree: merkleTree ?? defaultTestStateTreeAccounts().merkleTree,
|
|
6514
6677
|
selfProgram: this.programId,
|
|
6678
|
+
solPoolPda: null,
|
|
6515
6679
|
})
|
|
6516
6680
|
.instruction();
|
|
6517
6681
|
return instruction;
|
|
@@ -6526,7 +6690,7 @@ class CompressedTokenProgram {
|
|
|
6526
6690
|
/// 1. Mint to existing ATA of mintAuthority.
|
|
6527
6691
|
const splMintToInstruction = createMintToInstruction(mint, authorityTokenAccount, authority, amount);
|
|
6528
6692
|
/// 2. Compress from mint authority ATA to recipient compressed account
|
|
6529
|
-
const
|
|
6693
|
+
const compressInstruction = await this.compress({
|
|
6530
6694
|
payer: feePayer,
|
|
6531
6695
|
owner: authority,
|
|
6532
6696
|
source: authorityTokenAccount,
|
|
@@ -6535,7 +6699,7 @@ class CompressedTokenProgram {
|
|
|
6535
6699
|
amount: params.amount,
|
|
6536
6700
|
outputStateTree: merkleTree,
|
|
6537
6701
|
});
|
|
6538
|
-
return [splMintToInstruction,
|
|
6702
|
+
return [splMintToInstruction, compressInstruction];
|
|
6539
6703
|
}
|
|
6540
6704
|
/**
|
|
6541
6705
|
* Construct transfer instruction for compressed tokens
|
|
@@ -6559,6 +6723,7 @@ class CompressedTokenProgram {
|
|
|
6559
6723
|
compressOrDecompressAmount: null,
|
|
6560
6724
|
isCompress: false,
|
|
6561
6725
|
cpiContext: null,
|
|
6726
|
+
lamportsChangeAccountMerkleTreeIndex: null,
|
|
6562
6727
|
};
|
|
6563
6728
|
const encodedData = this.program.coder.types.encode('CompressedTokenInstructionDataTransfer', data);
|
|
6564
6729
|
const { accountCompressionAuthority, noopProgram, registeredProgramPda, accountCompressionProgram, } = defaultStaticAccountsStruct();
|
|
@@ -6583,8 +6748,8 @@ class CompressedTokenProgram {
|
|
|
6583
6748
|
return instruction;
|
|
6584
6749
|
}
|
|
6585
6750
|
/**
|
|
6586
|
-
* Construct
|
|
6587
|
-
* @returns
|
|
6751
|
+
* Construct compress instruction
|
|
6752
|
+
* @returns compressInstruction
|
|
6588
6753
|
*/
|
|
6589
6754
|
static async compress(params) {
|
|
6590
6755
|
const { payer, owner, source, toAddress, mint, outputStateTree } = params;
|
|
@@ -6594,6 +6759,7 @@ class CompressedTokenProgram {
|
|
|
6594
6759
|
owner: toAddress,
|
|
6595
6760
|
amount,
|
|
6596
6761
|
lamports: bn(0),
|
|
6762
|
+
tlv: null,
|
|
6597
6763
|
},
|
|
6598
6764
|
];
|
|
6599
6765
|
const { inputTokenDataWithContext, packedOutputTokenData, remainingAccountMetas, } = packCompressedTokenAccounts({
|
|
@@ -6611,10 +6777,10 @@ class CompressedTokenProgram {
|
|
|
6611
6777
|
compressOrDecompressAmount: amount,
|
|
6612
6778
|
isCompress: true,
|
|
6613
6779
|
cpiContext: null,
|
|
6780
|
+
lamportsChangeAccountMerkleTreeIndex: null,
|
|
6614
6781
|
};
|
|
6615
6782
|
const encodedData = this.program.coder.types.encode('CompressedTokenInstructionDataTransfer', data);
|
|
6616
6783
|
const { accountCompressionAuthority, noopProgram, registeredProgramPda, accountCompressionProgram, } = defaultStaticAccountsStruct();
|
|
6617
|
-
const approveInstruction = createApproveInstruction(source, this.deriveCpiAuthorityPda, owner, BigInt(amount.toString()));
|
|
6618
6784
|
const instruction = await this.program.methods
|
|
6619
6785
|
.transfer(encodedData)
|
|
6620
6786
|
.accounts({
|
|
@@ -6633,7 +6799,7 @@ class CompressedTokenProgram {
|
|
|
6633
6799
|
})
|
|
6634
6800
|
.remainingAccounts(remainingAccountMetas)
|
|
6635
6801
|
.instruction();
|
|
6636
|
-
return
|
|
6802
|
+
return instruction;
|
|
6637
6803
|
}
|
|
6638
6804
|
/**
|
|
6639
6805
|
* Construct decompress instruction
|
|
@@ -6659,6 +6825,7 @@ class CompressedTokenProgram {
|
|
|
6659
6825
|
compressOrDecompressAmount: amount,
|
|
6660
6826
|
isCompress: false,
|
|
6661
6827
|
cpiContext: null,
|
|
6828
|
+
lamportsChangeAccountMerkleTreeIndex: null,
|
|
6662
6829
|
};
|
|
6663
6830
|
const encodedData = this.program.coder.types.encode('CompressedTokenInstructionDataTransfer', data);
|
|
6664
6831
|
const { accountCompressionAuthority, noopProgram, registeredProgramPda, accountCompressionProgram, } = defaultStaticAccountsStruct();
|
|
@@ -6740,7 +6907,7 @@ async function approveAndMintTo(rpc, payer, mint, destination, authority, amount
|
|
|
6740
6907
|
*/
|
|
6741
6908
|
async function compress(rpc, payer, mint, amount, owner, sourceTokenAccount, toAddress, merkleTree, confirmOptions) {
|
|
6742
6909
|
amount = bn(amount);
|
|
6743
|
-
const
|
|
6910
|
+
const compressIx = await CompressedTokenProgram.compress({
|
|
6744
6911
|
payer: payer.publicKey,
|
|
6745
6912
|
owner: owner.publicKey,
|
|
6746
6913
|
source: sourceTokenAccount,
|
|
@@ -6755,7 +6922,6 @@ async function compress(rpc, payer, mint, amount, owner, sourceTokenAccount, toA
|
|
|
6755
6922
|
ComputeBudgetProgram.setComputeUnitLimit({
|
|
6756
6923
|
units: 1_000_000,
|
|
6757
6924
|
}),
|
|
6758
|
-
approveIx,
|
|
6759
6925
|
compressIx,
|
|
6760
6926
|
], payer, blockhashCtx.blockhash, additionalSigners);
|
|
6761
6927
|
const txId = await sendAndConfirmTx(rpc, signedTx, confirmOptions, blockhashCtx);
|