arc200-client 1.0.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/index.js ADDED
@@ -0,0 +1,735 @@
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __export = (target, all) => {
9
+ for (var name in all)
10
+ __defProp(target, name, { get: all[name], enumerable: true });
11
+ };
12
+ var __copyProps = (to, from, except, desc) => {
13
+ if (from && typeof from === "object" || typeof from === "function") {
14
+ for (let key of __getOwnPropNames(from))
15
+ if (!__hasOwnProp.call(to, key) && key !== except)
16
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
+ }
18
+ return to;
19
+ };
20
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
+ // If the importer is in node compatibility mode or this is not an ESM
22
+ // file that has been converted to a CommonJS file using a Babel-
23
+ // compatible transform (i.e. "__esModule" has not been set), then set
24
+ // "default" to the CommonJS "module.exports" for node compatibility.
25
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
+ mod
27
+ ));
28
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
+
30
+ // src/index.ts
31
+ var src_exports = {};
32
+ __export(src_exports, {
33
+ getArc200Client: () => getArc200Client_default
34
+ });
35
+ module.exports = __toCommonJS(src_exports);
36
+
37
+ // contracts/clients/Arc200Client.ts
38
+ var algokit = __toESM(require("@algorandfoundation/algokit-utils"));
39
+ var import_algosdk = require("algosdk");
40
+ var APP_SPEC = {
41
+ "hints": {
42
+ "arc200_name()string": {
43
+ "call_config": {
44
+ "no_op": "CALL"
45
+ }
46
+ },
47
+ "arc200_symbol()string": {
48
+ "call_config": {
49
+ "no_op": "CALL"
50
+ }
51
+ },
52
+ "arc200_decimals()uint8": {
53
+ "call_config": {
54
+ "no_op": "CALL"
55
+ }
56
+ },
57
+ "arc200_totalSupply()uint256": {
58
+ "call_config": {
59
+ "no_op": "CALL"
60
+ }
61
+ },
62
+ "arc200_balanceOf(address)uint256": {
63
+ "call_config": {
64
+ "no_op": "CALL"
65
+ }
66
+ },
67
+ "arc200_transfer(address,uint256)bool": {
68
+ "call_config": {
69
+ "no_op": "CALL"
70
+ }
71
+ },
72
+ "arc200_transferFrom(address,address,uint256)bool": {
73
+ "call_config": {
74
+ "no_op": "CALL"
75
+ }
76
+ },
77
+ "arc200_approve(address,uint256)bool": {
78
+ "call_config": {
79
+ "no_op": "CALL"
80
+ }
81
+ },
82
+ "arc200_allowance(address,address)uint256": {
83
+ "call_config": {
84
+ "no_op": "CALL"
85
+ }
86
+ },
87
+ "createApplication()void": {
88
+ "call_config": {
89
+ "no_op": "CREATE"
90
+ }
91
+ }
92
+ },
93
+ "bare_call_config": {
94
+ "no_op": "NEVER",
95
+ "opt_in": "NEVER",
96
+ "close_out": "NEVER",
97
+ "update_application": "NEVER",
98
+ "delete_application": "NEVER"
99
+ },
100
+ "schema": {
101
+ "local": {
102
+ "declared": {},
103
+ "reserved": {}
104
+ },
105
+ "global": {
106
+ "declared": {},
107
+ "reserved": {}
108
+ }
109
+ },
110
+ "state": {
111
+ "global": {
112
+ "num_byte_slices": 0,
113
+ "num_uints": 0
114
+ },
115
+ "local": {
116
+ "num_byte_slices": 0,
117
+ "num_uints": 0
118
+ }
119
+ },
120
+ "source": {
121
+ "approval": "#pragma version 10

// This TEAL was generated by TEALScript v0.84.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
int 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	err

// arc200_name()string
*abi_route_arc200_name:
	// The ABI return prefix
	byte 0x151f7c75

	// execute arc200_name()string
	callsub arc200_name
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// arc200_name(): string[32]
//
// Returns the name of the token
//
// @returns The name of the token
arc200_name:
	proto 0 1

	// contracts\arc200.algo.ts:15
	// return 'Arc200';
	byte 0x417263323030 // "Arc200"
	retsub

// arc200_symbol()string
*abi_route_arc200_symbol:
	// The ABI return prefix
	byte 0x151f7c75

	// execute arc200_symbol()string
	callsub arc200_symbol
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// arc200_symbol(): string[8]
//
// Returns the symbol of the token
//
// @returns The symbol of the token
arc200_symbol:
	proto 0 1

	// contracts\arc200.algo.ts:25
	// return 'Arc200';
	byte 0x417263323030 // "Arc200"
	retsub

// arc200_decimals()uint8
*abi_route_arc200_decimals:
	// The ABI return prefix
	byte 0x151f7c75

	// execute arc200_decimals()uint8
	callsub arc200_decimals
	itob
	dup
	bitlen
	int 8
	<=
	assert
	extract 7 1
	concat
	log
	int 1
	return

// arc200_decimals(): uint8
//
// Returns the decimals of the token
//
// @returns The decimals of the token
arc200_decimals:
	proto 0 1

	// contracts\arc200.algo.ts:35
	// return 6 as uint8;
	int 6
	retsub

// arc200_totalSupply()uint256
*abi_route_arc200_totalSupply:
	// The ABI return prefix
	byte 0x151f7c75

	// execute arc200_totalSupply()uint256
	callsub arc200_totalSupply
	dup
	bitlen
	int 256
	<=
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// arc200_totalSupply(): uint256
//
// Returns the total supply of the token
//
// @returns The total supply of the token
arc200_totalSupply:
	proto 0 1

	// contracts\arc200.algo.ts:45
	// return 1_000_000_000_000_000 as uint256;
	byte 0x00000000000000000000000000000000000000000000000000038d7ea4c68000
	retsub

// arc200_balanceOf(address)uint256
*abi_route_arc200_balanceOf:
	// The ABI return prefix
	byte 0x151f7c75

	// owner: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==
	assert

	// execute arc200_balanceOf(address)uint256
	callsub arc200_balanceOf
	dup
	bitlen
	int 256
	<=
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// arc200_balanceOf(owner: Address): uint256
//
// Returns the current balance of the owner of the token
//
// @param owner The address of the owner of the token
// @returns The current balance of the holder of the token
arc200_balanceOf:
	proto 1 1

	// contracts\arc200.algo.ts:56
	// return 0 as uint256;
	byte 0x0000000000000000000000000000000000000000000000000000000000000000
	retsub

// arc200_transfer(address,uint256)bool
*abi_route_arc200_transfer:
	// The ABI return prefix
	byte 0x151f7c75

	// value: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==
	assert

	// to: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==
	assert

	// execute arc200_transfer(address,uint256)bool
	callsub arc200_transfer
	byte 0x00
	int 0
	uncover 2
	setbit
	concat
	log
	int 1
	return

// arc200_transfer(to: Address, value: uint256): boolean
//
// Transfers tokens
//
// @param to The destination of the transfer
// @param value Amount of tokens to transfer
// @returns Success
arc200_transfer:
	proto 2 1

	// contracts\arc200.algo.ts:67
	// return false;
	int 0
	retsub

// arc200_transferFrom(address,address,uint256)bool
*abi_route_arc200_transferFrom:
	// The ABI return prefix
	byte 0x151f7c75

	// value: uint256
	txna ApplicationArgs 3
	dup
	len
	int 32
	==
	assert

	// to: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==
	assert

	// from: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==
	assert

	// execute arc200_transferFrom(address,address,uint256)bool
	callsub arc200_transferFrom
	byte 0x00
	int 0
	uncover 2
	setbit
	concat
	log
	int 1
	return

// arc200_transferFrom(from: Address, to: Address, value: uint256): boolean
//
// Transfers tokens from source to destination as approved spender
//
// @param from The source of the transfer
// @param to The destination of the transfer
// @param value Amount of tokens to transfer
// @returns Success
arc200_transferFrom:
	proto 3 1

	// contracts\arc200.algo.ts:79
	// return false;
	int 0
	retsub

// arc200_approve(address,uint256)bool
*abi_route_arc200_approve:
	// The ABI return prefix
	byte 0x151f7c75

	// value: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==
	assert

	// spender: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==
	assert

	// execute arc200_approve(address,uint256)bool
	callsub arc200_approve
	byte 0x00
	int 0
	uncover 2
	setbit
	concat
	log
	int 1
	return

// arc200_approve(spender: Address, value: uint256): boolean
//
// Approve spender for a token
//
// @param spender Who is allowed to take tokens on owner's behalf
// @param value Amount of tokens to be taken by spender
// @returns Success
arc200_approve:
	proto 2 1

	// contracts\arc200.algo.ts:90
	// return false;
	int 0
	retsub

// arc200_allowance(address,address)uint256
*abi_route_arc200_allowance:
	// The ABI return prefix
	byte 0x151f7c75

	// spender: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==
	assert

	// owner: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==
	assert

	// execute arc200_allowance(address,address)uint256
	callsub arc200_allowance
	dup
	bitlen
	int 256
	<=
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// arc200_allowance(owner: Address, spender: Address): uint256
//
// Returns the current allowance of the spender of the tokens of the owner
//
// @param owner Owner's account
// @param spender Who is allowed to take tokens on owner's behalf
// @returns The remaining allowance
arc200_allowance:
	proto 2 1

	// contracts\arc200.algo.ts:102
	// return 0 as uint256;
	byte 0x0000000000000000000000000000000000000000000000000000000000000000
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication
	err

*call_NoOp:
	method "arc200_name()string"
	method "arc200_symbol()string"
	method "arc200_decimals()uint8"
	method "arc200_totalSupply()uint256"
	method "arc200_balanceOf(address)uint256"
	method "arc200_transfer(address,uint256)bool"
	method "arc200_transferFrom(address,address,uint256)bool"
	method "arc200_approve(address,uint256)bool"
	method "arc200_allowance(address,address)uint256"
	txna ApplicationArgs 0
	match *abi_route_arc200_name *abi_route_arc200_symbol *abi_route_arc200_decimals *abi_route_arc200_totalSupply *abi_route_arc200_balanceOf *abi_route_arc200_transfer *abi_route_arc200_transferFrom *abi_route_arc200_approve *abi_route_arc200_allowance
	err",
122
+ "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw"
123
+ },
124
+ "contract": {
125
+ "name": "Arc200",
126
+ "desc": "",
127
+ "methods": [
128
+ {
129
+ "name": "arc200_name",
130
+ "desc": "Returns the name of the token",
131
+ "readonly": true,
132
+ "args": [],
133
+ "returns": {
134
+ "type": "string",
135
+ "desc": "The name of the token"
136
+ }
137
+ },
138
+ {
139
+ "name": "arc200_symbol",
140
+ "desc": "Returns the symbol of the token",
141
+ "readonly": true,
142
+ "args": [],
143
+ "returns": {
144
+ "type": "string",
145
+ "desc": "The symbol of the token"
146
+ }
147
+ },
148
+ {
149
+ "name": "arc200_decimals",
150
+ "desc": "Returns the decimals of the token",
151
+ "readonly": true,
152
+ "args": [],
153
+ "returns": {
154
+ "type": "uint8",
155
+ "desc": "The decimals of the token"
156
+ }
157
+ },
158
+ {
159
+ "name": "arc200_totalSupply",
160
+ "desc": "Returns the total supply of the token",
161
+ "readonly": true,
162
+ "args": [],
163
+ "returns": {
164
+ "type": "uint256",
165
+ "desc": "The total supply of the token"
166
+ }
167
+ },
168
+ {
169
+ "name": "arc200_balanceOf",
170
+ "desc": "Returns the current balance of the owner of the token",
171
+ "readonly": true,
172
+ "args": [
173
+ {
174
+ "name": "owner",
175
+ "type": "address",
176
+ "desc": "The address of the owner of the token"
177
+ }
178
+ ],
179
+ "returns": {
180
+ "type": "uint256",
181
+ "desc": "The current balance of the holder of the token"
182
+ }
183
+ },
184
+ {
185
+ "name": "arc200_transfer",
186
+ "desc": "Transfers tokens",
187
+ "args": [
188
+ {
189
+ "name": "to",
190
+ "type": "address",
191
+ "desc": "The destination of the transfer"
192
+ },
193
+ {
194
+ "name": "value",
195
+ "type": "uint256",
196
+ "desc": "Amount of tokens to transfer"
197
+ }
198
+ ],
199
+ "returns": {
200
+ "type": "bool",
201
+ "desc": "Success"
202
+ }
203
+ },
204
+ {
205
+ "name": "arc200_transferFrom",
206
+ "desc": "Transfers tokens from source to destination as approved spender",
207
+ "args": [
208
+ {
209
+ "name": "from",
210
+ "type": "address",
211
+ "desc": "The source of the transfer"
212
+ },
213
+ {
214
+ "name": "to",
215
+ "type": "address",
216
+ "desc": "The destination of the transfer"
217
+ },
218
+ {
219
+ "name": "value",
220
+ "type": "uint256",
221
+ "desc": "Amount of tokens to transfer"
222
+ }
223
+ ],
224
+ "returns": {
225
+ "type": "bool",
226
+ "desc": "Success"
227
+ }
228
+ },
229
+ {
230
+ "name": "arc200_approve",
231
+ "desc": "Approve spender for a token",
232
+ "args": [
233
+ {
234
+ "name": "spender",
235
+ "type": "address",
236
+ "desc": "Who is allowed to take tokens on owner's behalf"
237
+ },
238
+ {
239
+ "name": "value",
240
+ "type": "uint256",
241
+ "desc": "Amount of tokens to be taken by spender"
242
+ }
243
+ ],
244
+ "returns": {
245
+ "type": "bool",
246
+ "desc": "Success"
247
+ }
248
+ },
249
+ {
250
+ "name": "arc200_allowance",
251
+ "desc": "Returns the current allowance of the spender of the tokens of the owner",
252
+ "readonly": true,
253
+ "args": [
254
+ {
255
+ "name": "owner",
256
+ "type": "address",
257
+ "desc": "Owner's account"
258
+ },
259
+ {
260
+ "name": "spender",
261
+ "type": "address",
262
+ "desc": "Who is allowed to take tokens on owner's behalf"
263
+ }
264
+ ],
265
+ "returns": {
266
+ "type": "uint256",
267
+ "desc": "The remaining allowance"
268
+ }
269
+ },
270
+ {
271
+ "name": "createApplication",
272
+ "args": [],
273
+ "returns": {
274
+ "type": "void"
275
+ }
276
+ }
277
+ ]
278
+ }
279
+ };
280
+ var Arc200CallFactory = class {
281
+ /**
282
+ * Gets available create call factories
283
+ */
284
+ static get create() {
285
+ return {
286
+ /**
287
+ * Constructs a create call for the Arc200 smart contract using the createApplication()void ABI method
288
+ *
289
+ * @param args Any args for the contract call
290
+ * @param params Any additional parameters for the call
291
+ * @returns A TypedCallParams object for the call
292
+ */
293
+ createApplication(args, params = {}) {
294
+ return {
295
+ method: "createApplication()void",
296
+ methodArgs: Array.isArray(args) ? args : [],
297
+ ...params
298
+ };
299
+ }
300
+ };
301
+ }
302
+ /**
303
+ * Constructs a no op call for the arc200_name()string ABI method
304
+ *
305
+ * Returns the name of the token
306
+ *
307
+ * @param args Any args for the contract call
308
+ * @param params Any additional parameters for the call
309
+ * @returns A TypedCallParams object for the call
310
+ */
311
+ static arc200Name(args, params) {
312
+ return {
313
+ method: "arc200_name()string",
314
+ methodArgs: Array.isArray(args) ? args : [],
315
+ ...params
316
+ };
317
+ }
318
+ /**
319
+ * Constructs a no op call for the arc200_symbol()string ABI method
320
+ *
321
+ * Returns the symbol of the token
322
+ *
323
+ * @param args Any args for the contract call
324
+ * @param params Any additional parameters for the call
325
+ * @returns A TypedCallParams object for the call
326
+ */
327
+ static arc200Symbol(args, params) {
328
+ return {
329
+ method: "arc200_symbol()string",
330
+ methodArgs: Array.isArray(args) ? args : [],
331
+ ...params
332
+ };
333
+ }
334
+ /**
335
+ * Constructs a no op call for the arc200_decimals()uint8 ABI method
336
+ *
337
+ * Returns the decimals of the token
338
+ *
339
+ * @param args Any args for the contract call
340
+ * @param params Any additional parameters for the call
341
+ * @returns A TypedCallParams object for the call
342
+ */
343
+ static arc200Decimals(args, params) {
344
+ return {
345
+ method: "arc200_decimals()uint8",
346
+ methodArgs: Array.isArray(args) ? args : [],
347
+ ...params
348
+ };
349
+ }
350
+ /**
351
+ * Constructs a no op call for the arc200_totalSupply()uint256 ABI method
352
+ *
353
+ * Returns the total supply of the token
354
+ *
355
+ * @param args Any args for the contract call
356
+ * @param params Any additional parameters for the call
357
+ * @returns A TypedCallParams object for the call
358
+ */
359
+ static arc200TotalSupply(args, params) {
360
+ return {
361
+ method: "arc200_totalSupply()uint256",
362
+ methodArgs: Array.isArray(args) ? args : [],
363
+ ...params
364
+ };
365
+ }
366
+ /**
367
+ * Constructs a no op call for the arc200_balanceOf(address)uint256 ABI method
368
+ *
369
+ * Returns the current balance of the owner of the token
370
+ *
371
+ * @param args Any args for the contract call
372
+ * @param params Any additional parameters for the call
373
+ * @returns A TypedCallParams object for the call
374
+ */
375
+ static arc200BalanceOf(args, params) {
376
+ return {
377
+ method: "arc200_balanceOf(address)uint256",
378
+ methodArgs: Array.isArray(args) ? args : [args.owner],
379
+ ...params
380
+ };
381
+ }
382
+ /**
383
+ * Constructs a no op call for the arc200_transfer(address,uint256)bool ABI method
384
+ *
385
+ * Transfers tokens
386
+ *
387
+ * @param args Any args for the contract call
388
+ * @param params Any additional parameters for the call
389
+ * @returns A TypedCallParams object for the call
390
+ */
391
+ static arc200Transfer(args, params) {
392
+ return {
393
+ method: "arc200_transfer(address,uint256)bool",
394
+ methodArgs: Array.isArray(args) ? args : [args.to, args.value],
395
+ ...params
396
+ };
397
+ }
398
+ /**
399
+ * Constructs a no op call for the arc200_transferFrom(address,address,uint256)bool ABI method
400
+ *
401
+ * Transfers tokens from source to destination as approved spender
402
+ *
403
+ * @param args Any args for the contract call
404
+ * @param params Any additional parameters for the call
405
+ * @returns A TypedCallParams object for the call
406
+ */
407
+ static arc200TransferFrom(args, params) {
408
+ return {
409
+ method: "arc200_transferFrom(address,address,uint256)bool",
410
+ methodArgs: Array.isArray(args) ? args : [args.from, args.to, args.value],
411
+ ...params
412
+ };
413
+ }
414
+ /**
415
+ * Constructs a no op call for the arc200_approve(address,uint256)bool ABI method
416
+ *
417
+ * Approve spender for a token
418
+ *
419
+ * @param args Any args for the contract call
420
+ * @param params Any additional parameters for the call
421
+ * @returns A TypedCallParams object for the call
422
+ */
423
+ static arc200Approve(args, params) {
424
+ return {
425
+ method: "arc200_approve(address,uint256)bool",
426
+ methodArgs: Array.isArray(args) ? args : [args.spender, args.value],
427
+ ...params
428
+ };
429
+ }
430
+ /**
431
+ * Constructs a no op call for the arc200_allowance(address,address)uint256 ABI method
432
+ *
433
+ * Returns the current allowance of the spender of the tokens of the owner
434
+ *
435
+ * @param args Any args for the contract call
436
+ * @param params Any additional parameters for the call
437
+ * @returns A TypedCallParams object for the call
438
+ */
439
+ static arc200Allowance(args, params) {
440
+ return {
441
+ method: "arc200_allowance(address,address)uint256",
442
+ methodArgs: Array.isArray(args) ? args : [args.owner, args.spender],
443
+ ...params
444
+ };
445
+ }
446
+ };
447
+ var Arc200Client = class {
448
+ /**
449
+ * Creates a new instance of `Arc200Client`
450
+ *
451
+ * @param appDetails appDetails The details to identify the app to deploy
452
+ * @param algod An algod client instance
453
+ */
454
+ constructor(appDetails, algod) {
455
+ this.algod = algod;
456
+ this.sender = appDetails.sender;
457
+ this.appClient = algokit.getAppClient({
458
+ ...appDetails,
459
+ app: APP_SPEC
460
+ }, algod);
461
+ }
462
+ /**
463
+ * Checks for decode errors on the AppCallTransactionResult and maps the return value to the specified generic type
464
+ *
465
+ * @param result The AppCallTransactionResult to be mapped
466
+ * @param returnValueFormatter An optional delegate to format the return value if required
467
+ * @returns The smart contract response with an updated return value
468
+ */
469
+ mapReturnValue(result, returnValueFormatter) {
470
+ if (result.return?.decodeError) {
471
+ throw result.return.decodeError;
472
+ }
473
+ const returnValue = result.return?.returnValue !== void 0 && returnValueFormatter !== void 0 ? returnValueFormatter(result.return.returnValue) : result.return?.returnValue;
474
+ return { ...result, return: returnValue };
475
+ }
476
+ /**
477
+ * Calls the ABI method with the matching signature using an onCompletion code of NO_OP
478
+ *
479
+ * @param typedCallParams An object containing the method signature, args, and any other relevant parameters
480
+ * @param returnValueFormatter An optional delegate which when provided will be used to map non-undefined return values to the target type
481
+ * @returns The result of the smart contract call
482
+ */
483
+ async call(typedCallParams, returnValueFormatter) {
484
+ return this.mapReturnValue(await this.appClient.call(typedCallParams), returnValueFormatter);
485
+ }
486
+ /**
487
+ * Idempotently deploys the Arc200 smart contract.
488
+ *
489
+ * @param params The arguments for the contract calls and any additional parameters for the call
490
+ * @returns The deployment result
491
+ */
492
+ deploy(params = {}) {
493
+ const createArgs = params.createCall?.(Arc200CallFactory.create);
494
+ return this.appClient.deploy({
495
+ ...params,
496
+ createArgs,
497
+ createOnCompleteAction: createArgs?.onCompleteAction
498
+ });
499
+ }
500
+ /**
501
+ * Gets available create methods
502
+ */
503
+ get create() {
504
+ const $this = this;
505
+ return {
506
+ /**
507
+ * Creates a new instance of the Arc200 smart contract using the createApplication()void ABI method.
508
+ *
509
+ * @param args The arguments for the smart contract call
510
+ * @param params Any additional parameters for the call
511
+ * @returns The create result
512
+ */
513
+ async createApplication(args, params = {}) {
514
+ return $this.mapReturnValue(await $this.appClient.create(Arc200CallFactory.create.createApplication(args, params)));
515
+ }
516
+ };
517
+ }
518
+ /**
519
+ * Makes a clear_state call to an existing instance of the Arc200 smart contract.
520
+ *
521
+ * @param args The arguments for the bare call
522
+ * @returns The clear_state result
523
+ */
524
+ clearState(args = {}) {
525
+ return this.appClient.clearState(args);
526
+ }
527
+ /**
528
+ * Calls the arc200_name()string ABI method.
529
+ *
530
+ * Returns the name of the token
531
+ *
532
+ * @param args The arguments for the contract call
533
+ * @param params Any additional parameters for the call
534
+ * @returns The result of the call: The name of the token
535
+ */
536
+ arc200Name(args, params = {}) {
537
+ return this.call(Arc200CallFactory.arc200Name(args, params));
538
+ }
539
+ /**
540
+ * Calls the arc200_symbol()string ABI method.
541
+ *
542
+ * Returns the symbol of the token
543
+ *
544
+ * @param args The arguments for the contract call
545
+ * @param params Any additional parameters for the call
546
+ * @returns The result of the call: The symbol of the token
547
+ */
548
+ arc200Symbol(args, params = {}) {
549
+ return this.call(Arc200CallFactory.arc200Symbol(args, params));
550
+ }
551
+ /**
552
+ * Calls the arc200_decimals()uint8 ABI method.
553
+ *
554
+ * Returns the decimals of the token
555
+ *
556
+ * @param args The arguments for the contract call
557
+ * @param params Any additional parameters for the call
558
+ * @returns The result of the call: The decimals of the token
559
+ */
560
+ arc200Decimals(args, params = {}) {
561
+ return this.call(Arc200CallFactory.arc200Decimals(args, params));
562
+ }
563
+ /**
564
+ * Calls the arc200_totalSupply()uint256 ABI method.
565
+ *
566
+ * Returns the total supply of the token
567
+ *
568
+ * @param args The arguments for the contract call
569
+ * @param params Any additional parameters for the call
570
+ * @returns The result of the call: The total supply of the token
571
+ */
572
+ arc200TotalSupply(args, params = {}) {
573
+ return this.call(Arc200CallFactory.arc200TotalSupply(args, params));
574
+ }
575
+ /**
576
+ * Calls the arc200_balanceOf(address)uint256 ABI method.
577
+ *
578
+ * Returns the current balance of the owner of the token
579
+ *
580
+ * @param args The arguments for the contract call
581
+ * @param params Any additional parameters for the call
582
+ * @returns The result of the call: The current balance of the holder of the token
583
+ */
584
+ arc200BalanceOf(args, params = {}) {
585
+ return this.call(Arc200CallFactory.arc200BalanceOf(args, params));
586
+ }
587
+ /**
588
+ * Calls the arc200_transfer(address,uint256)bool ABI method.
589
+ *
590
+ * Transfers tokens
591
+ *
592
+ * @param args The arguments for the contract call
593
+ * @param params Any additional parameters for the call
594
+ * @returns The result of the call: Success
595
+ */
596
+ arc200Transfer(args, params = {}) {
597
+ return this.call(Arc200CallFactory.arc200Transfer(args, params));
598
+ }
599
+ /**
600
+ * Calls the arc200_transferFrom(address,address,uint256)bool ABI method.
601
+ *
602
+ * Transfers tokens from source to destination as approved spender
603
+ *
604
+ * @param args The arguments for the contract call
605
+ * @param params Any additional parameters for the call
606
+ * @returns The result of the call: Success
607
+ */
608
+ arc200TransferFrom(args, params = {}) {
609
+ return this.call(Arc200CallFactory.arc200TransferFrom(args, params));
610
+ }
611
+ /**
612
+ * Calls the arc200_approve(address,uint256)bool ABI method.
613
+ *
614
+ * Approve spender for a token
615
+ *
616
+ * @param args The arguments for the contract call
617
+ * @param params Any additional parameters for the call
618
+ * @returns The result of the call: Success
619
+ */
620
+ arc200Approve(args, params = {}) {
621
+ return this.call(Arc200CallFactory.arc200Approve(args, params));
622
+ }
623
+ /**
624
+ * Calls the arc200_allowance(address,address)uint256 ABI method.
625
+ *
626
+ * Returns the current allowance of the spender of the tokens of the owner
627
+ *
628
+ * @param args The arguments for the contract call
629
+ * @param params Any additional parameters for the call
630
+ * @returns The result of the call: The remaining allowance
631
+ */
632
+ arc200Allowance(args, params = {}) {
633
+ return this.call(Arc200CallFactory.arc200Allowance(args, params));
634
+ }
635
+ compose() {
636
+ const client = this;
637
+ const atc = new import_algosdk.AtomicTransactionComposer();
638
+ let promiseChain = Promise.resolve();
639
+ const resultMappers = [];
640
+ return {
641
+ arc200Name(args, params) {
642
+ promiseChain = promiseChain.then(() => client.arc200Name(args, { ...params, sendParams: { ...params?.sendParams, skipSending: true, atc } }));
643
+ resultMappers.push(void 0);
644
+ return this;
645
+ },
646
+ arc200Symbol(args, params) {
647
+ promiseChain = promiseChain.then(() => client.arc200Symbol(args, { ...params, sendParams: { ...params?.sendParams, skipSending: true, atc } }));
648
+ resultMappers.push(void 0);
649
+ return this;
650
+ },
651
+ arc200Decimals(args, params) {
652
+ promiseChain = promiseChain.then(() => client.arc200Decimals(args, { ...params, sendParams: { ...params?.sendParams, skipSending: true, atc } }));
653
+ resultMappers.push(void 0);
654
+ return this;
655
+ },
656
+ arc200TotalSupply(args, params) {
657
+ promiseChain = promiseChain.then(() => client.arc200TotalSupply(args, { ...params, sendParams: { ...params?.sendParams, skipSending: true, atc } }));
658
+ resultMappers.push(void 0);
659
+ return this;
660
+ },
661
+ arc200BalanceOf(args, params) {
662
+ promiseChain = promiseChain.then(() => client.arc200BalanceOf(args, { ...params, sendParams: { ...params?.sendParams, skipSending: true, atc } }));
663
+ resultMappers.push(void 0);
664
+ return this;
665
+ },
666
+ arc200Transfer(args, params) {
667
+ promiseChain = promiseChain.then(() => client.arc200Transfer(args, { ...params, sendParams: { ...params?.sendParams, skipSending: true, atc } }));
668
+ resultMappers.push(void 0);
669
+ return this;
670
+ },
671
+ arc200TransferFrom(args, params) {
672
+ promiseChain = promiseChain.then(() => client.arc200TransferFrom(args, { ...params, sendParams: { ...params?.sendParams, skipSending: true, atc } }));
673
+ resultMappers.push(void 0);
674
+ return this;
675
+ },
676
+ arc200Approve(args, params) {
677
+ promiseChain = promiseChain.then(() => client.arc200Approve(args, { ...params, sendParams: { ...params?.sendParams, skipSending: true, atc } }));
678
+ resultMappers.push(void 0);
679
+ return this;
680
+ },
681
+ arc200Allowance(args, params) {
682
+ promiseChain = promiseChain.then(() => client.arc200Allowance(args, { ...params, sendParams: { ...params?.sendParams, skipSending: true, atc } }));
683
+ resultMappers.push(void 0);
684
+ return this;
685
+ },
686
+ clearState(args) {
687
+ promiseChain = promiseChain.then(() => client.clearState({ ...args, sendParams: { ...args?.sendParams, skipSending: true, atc } }));
688
+ resultMappers.push(void 0);
689
+ return this;
690
+ },
691
+ addTransaction(txn, defaultSender) {
692
+ promiseChain = promiseChain.then(async () => atc.addTransaction(await algokit.getTransactionWithSigner(txn, defaultSender ?? client.sender)));
693
+ return this;
694
+ },
695
+ async atc() {
696
+ await promiseChain;
697
+ return atc;
698
+ },
699
+ async simulate(options) {
700
+ await promiseChain;
701
+ const result = await atc.simulate(client.algod, new import_algosdk.modelsv2.SimulateRequest({ txnGroups: [], ...options }));
702
+ return {
703
+ ...result,
704
+ returns: result.methodResults?.map((val, i) => resultMappers[i] !== void 0 ? resultMappers[i](val.returnValue) : val.returnValue)
705
+ };
706
+ },
707
+ async execute() {
708
+ await promiseChain;
709
+ const result = await algokit.sendAtomicTransactionComposer({ atc, sendParams: {} }, client.algod);
710
+ return {
711
+ ...result,
712
+ returns: result.returns?.map((val, i) => resultMappers[i] !== void 0 ? resultMappers[i](val.returnValue) : val.returnValue)
713
+ };
714
+ }
715
+ };
716
+ }
717
+ };
718
+
719
+ // src/getArc200Client.ts
720
+ var getArc200Client = (input) => {
721
+ return new Arc200Client(
722
+ {
723
+ sender: input.sender,
724
+ resolveBy: "id",
725
+ id: input.appId
726
+ },
727
+ input.algod
728
+ );
729
+ };
730
+ var getArc200Client_default = getArc200Client;
731
+ // Annotate the CommonJS export names for ESM import in node:
732
+ 0 && (module.exports = {
733
+ getArc200Client
734
+ });
735
+ //# sourceMappingURL=index.js.map