@allbridge/bridge-core-sdk 3.26.0 → 3.27.0-alpha.10

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 (91) hide show
  1. package/dist/browser/index.js +6 -1
  2. package/dist/browser/index.js.map +4 -4
  3. package/dist/cjs/index.js +6 -1
  4. package/dist/cjs/index.js.map +4 -4
  5. package/dist/esm/index.js +6 -1
  6. package/dist/esm/index.js.map +4 -4
  7. package/dist/src/chains/chain.enums.d.ts +12 -2
  8. package/dist/src/chains/chain.enums.js +10 -0
  9. package/dist/src/chains/chain.enums.js.map +1 -1
  10. package/dist/src/chains/index.js +12 -0
  11. package/dist/src/chains/index.js.map +1 -1
  12. package/dist/src/client/core-api/core-api-mapper.js +2 -0
  13. package/dist/src/client/core-api/core-api-mapper.js.map +1 -1
  14. package/dist/src/client/core-api/core-api.model.d.ts +2 -0
  15. package/dist/src/client/core-api/core-api.model.js.map +1 -1
  16. package/dist/src/configs/mainnet.js +1 -0
  17. package/dist/src/configs/mainnet.js.map +1 -1
  18. package/dist/src/index.d.ts +6 -4
  19. package/dist/src/index.js +5 -11
  20. package/dist/src/index.js.map +1 -1
  21. package/dist/src/services/bridge/alg/index.d.ts +16 -0
  22. package/dist/src/services/bridge/alg/index.js +181 -0
  23. package/dist/src/services/bridge/alg/index.js.map +1 -0
  24. package/dist/src/services/bridge/index.js +21 -0
  25. package/dist/src/services/bridge/index.js.map +1 -1
  26. package/dist/src/services/bridge/models/bridge.model.d.ts +2 -0
  27. package/dist/src/services/bridge/models/bridge.model.js.map +1 -1
  28. package/dist/src/services/bridge/stx/index.d.ts +16 -0
  29. package/dist/src/services/bridge/stx/index.js +127 -0
  30. package/dist/src/services/bridge/stx/index.js.map +1 -0
  31. package/dist/src/services/bridge/sui/index.js.map +1 -1
  32. package/dist/src/services/bridge/utils.d.ts +5 -1
  33. package/dist/src/services/bridge/utils.js +95 -15
  34. package/dist/src/services/bridge/utils.js.map +1 -1
  35. package/dist/src/services/liquidity-pool/alg/index.d.ts +19 -0
  36. package/dist/src/services/liquidity-pool/alg/index.js +134 -0
  37. package/dist/src/services/liquidity-pool/alg/index.js.map +1 -0
  38. package/dist/src/services/liquidity-pool/index.js +21 -0
  39. package/dist/src/services/liquidity-pool/index.js.map +1 -1
  40. package/dist/src/services/liquidity-pool/stx/index.d.ts +21 -0
  41. package/dist/src/services/liquidity-pool/stx/index.js +141 -0
  42. package/dist/src/services/liquidity-pool/stx/index.js.map +1 -0
  43. package/dist/src/services/liquidity-pool/sui/index.js.map +1 -1
  44. package/dist/src/services/liquidity-pool/trx/index.js.map +1 -1
  45. package/dist/src/services/models/alg/BridgeClient.d.ts +2743 -0
  46. package/dist/src/services/models/alg/BridgeClient.js +2685 -0
  47. package/dist/src/services/models/alg/BridgeClient.js.map +1 -0
  48. package/dist/src/services/models/alg/PaddingUtilClient.d.ts +639 -0
  49. package/dist/src/services/models/alg/PaddingUtilClient.js +425 -0
  50. package/dist/src/services/models/alg/PaddingUtilClient.js.map +1 -0
  51. package/dist/src/services/models/alg/PoolClient.d.ts +2268 -0
  52. package/dist/src/services/models/alg/PoolClient.js +2195 -0
  53. package/dist/src/services/models/alg/PoolClient.js.map +1 -0
  54. package/dist/src/services/models/index.d.ts +7 -5
  55. package/dist/src/services/models/index.js.map +1 -1
  56. package/dist/src/services/models/stx/clarigen-types.d.ts +657 -0
  57. package/dist/src/services/models/stx/clarigen-types.js +2296 -0
  58. package/dist/src/services/models/stx/clarigen-types.js.map +1 -0
  59. package/dist/src/services/token/alg/index.d.ts +17 -0
  60. package/dist/src/services/token/alg/index.js +46 -0
  61. package/dist/src/services/token/alg/index.js.map +1 -0
  62. package/dist/src/services/token/index.js +21 -0
  63. package/dist/src/services/token/index.js.map +1 -1
  64. package/dist/src/services/token/stx/index.d.ts +20 -0
  65. package/dist/src/services/token/stx/index.js +59 -0
  66. package/dist/src/services/token/stx/index.js.map +1 -0
  67. package/dist/src/services/token/sui/index.js.map +1 -1
  68. package/dist/src/services/utils/alg/index.d.ts +9 -0
  69. package/dist/src/services/utils/alg/index.js +74 -0
  70. package/dist/src/services/utils/alg/index.js.map +1 -0
  71. package/dist/src/services/utils/stx/get-token-name.d.ts +2 -0
  72. package/dist/src/services/utils/stx/get-token-name.js +15 -0
  73. package/dist/src/services/utils/stx/get-token-name.js.map +1 -0
  74. package/dist/src/services/utils/stx/post-conditions.d.ts +3 -0
  75. package/dist/src/services/utils/stx/post-conditions.js +27 -0
  76. package/dist/src/services/utils/stx/post-conditions.js.map +1 -0
  77. package/dist/src/services/utils/trx/index.js.map +1 -1
  78. package/dist/src/services/yield/index.js +8 -0
  79. package/dist/src/services/yield/index.js.map +1 -1
  80. package/dist/src/tokens-info/tokens-info.model.d.ts +8 -0
  81. package/dist/src/tokens-info/tokens-info.model.js.map +1 -1
  82. package/dist/src/utils/alg/index.d.ts +21 -0
  83. package/dist/src/utils/alg/index.js +67 -0
  84. package/dist/src/utils/alg/index.js.map +1 -0
  85. package/dist/src/utils/index.d.ts +3 -0
  86. package/dist/src/utils/index.js +3 -0
  87. package/dist/src/utils/index.js.map +1 -1
  88. package/dist/src/version.d.ts +1 -1
  89. package/dist/src/version.js +1 -1
  90. package/dist/src/version.js.map +1 -1
  91. package/package.json +9 -2
@@ -0,0 +1,2685 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.BridgeClient = exports.BridgeFactory = exports.BridgeParamsFactory = exports.APP_SPEC = void 0;
4
+ const app_arc56_1 = require("@algorandfoundation/algokit-utils/types/app-arc56");
5
+ const app_client_1 = require("@algorandfoundation/algokit-utils/types/app-client");
6
+ const app_factory_1 = require("@algorandfoundation/algokit-utils/types/app-factory");
7
+ exports.APP_SPEC = {
8
+ name: "Bridge",
9
+ structs: {},
10
+ methods: [
11
+ {
12
+ name: "createApplication",
13
+ args: [
14
+ { type: "address", name: "owner" },
15
+ { type: "byte", name: "chainId" },
16
+ { type: "uint64", name: "messenger" },
17
+ { type: "uint64", name: "gasOracle" },
18
+ ],
19
+ returns: { type: "void" },
20
+ actions: { create: ["NoOp"], call: [] },
21
+ readonly: false,
22
+ events: [],
23
+ recommendations: {},
24
+ },
25
+ {
26
+ name: "optInAsset",
27
+ args: [{ type: "uint64", name: "asset" }],
28
+ returns: { type: "void" },
29
+ actions: { create: [], call: ["NoOp"] },
30
+ readonly: false,
31
+ events: [],
32
+ recommendations: {},
33
+ },
34
+ {
35
+ name: "swapAndBridge",
36
+ args: [
37
+ { type: "pay", name: "paymentRef" },
38
+ { type: "axfer", name: "assetTransferRef" },
39
+ { type: "byte[32]", name: "recipient" },
40
+ { type: "byte", name: "destinationChainId" },
41
+ { type: "byte[32]", name: "receiveToken" },
42
+ { type: "byte[32]", name: "nonce" },
43
+ { type: "uint64", name: "budget", defaultValue: { source: "literal", data: "AAAAAAAAA+g=", type: "uint64" } },
44
+ ],
45
+ returns: { type: "void" },
46
+ actions: { create: [], call: ["NoOp"] },
47
+ readonly: false,
48
+ events: [
49
+ {
50
+ name: "BridgingFeeFromTokens",
51
+ args: [
52
+ { type: "uint64", name: "feeFromNative" },
53
+ { type: "uint64", name: "feeFromStable" },
54
+ { type: "uint64", name: "feeStableTokenAmount" },
55
+ ],
56
+ },
57
+ {
58
+ name: "ReceiveFee",
59
+ args: [
60
+ { type: "uint64", name: "bridgeTransactionCost" },
61
+ { type: "uint64", name: "messageTransactionCost" },
62
+ ],
63
+ },
64
+ {
65
+ name: "TokensSent",
66
+ args: [
67
+ { type: "uint64", name: "amount" },
68
+ { type: "byte[32]", name: "recipient" },
69
+ { type: "byte", name: "destinationChainId" },
70
+ { type: "byte[32]", name: "receiveToken" },
71
+ { type: "byte[32]", name: "nonce" },
72
+ { type: "byte", name: "messenger" },
73
+ ],
74
+ },
75
+ ],
76
+ recommendations: {},
77
+ },
78
+ {
79
+ name: "swapAndBridgeWithStable",
80
+ args: [
81
+ { type: "axfer", name: "assetTransferRef" },
82
+ { type: "byte[32]", name: "recipient" },
83
+ { type: "byte", name: "destinationChainId" },
84
+ { type: "byte[32]", name: "receiveToken" },
85
+ { type: "byte[32]", name: "nonce" },
86
+ { type: "uint64", name: "feeTokenAmount" },
87
+ { type: "uint64", name: "budget", defaultValue: { source: "literal", data: "AAAAAAAAA+g=", type: "uint64" } },
88
+ ],
89
+ returns: { type: "void" },
90
+ actions: { create: [], call: ["NoOp"] },
91
+ readonly: false,
92
+ events: [
93
+ {
94
+ name: "BridgingFeeFromTokens",
95
+ args: [
96
+ { type: "uint64", name: "feeFromNative" },
97
+ { type: "uint64", name: "feeFromStable" },
98
+ { type: "uint64", name: "feeStableTokenAmount" },
99
+ ],
100
+ },
101
+ {
102
+ name: "ReceiveFee",
103
+ args: [
104
+ { type: "uint64", name: "bridgeTransactionCost" },
105
+ { type: "uint64", name: "messageTransactionCost" },
106
+ ],
107
+ },
108
+ {
109
+ name: "TokensSent",
110
+ args: [
111
+ { type: "uint64", name: "amount" },
112
+ { type: "byte[32]", name: "recipient" },
113
+ { type: "byte", name: "destinationChainId" },
114
+ { type: "byte[32]", name: "receiveToken" },
115
+ { type: "byte[32]", name: "nonce" },
116
+ { type: "byte", name: "messenger" },
117
+ ],
118
+ },
119
+ ],
120
+ recommendations: {},
121
+ },
122
+ {
123
+ name: "receiveTokens",
124
+ args: [
125
+ { type: "pay", name: "paymentRef" },
126
+ { type: "uint64", name: "amount" },
127
+ { type: "byte[32]", name: "recipient" },
128
+ { type: "byte", name: "sourceChainId" },
129
+ { type: "byte[32]", name: "receiveToken" },
130
+ { type: "byte[32]", name: "nonce" },
131
+ { type: "uint64", name: "receiveAmountMin" },
132
+ ],
133
+ returns: { type: "void" },
134
+ actions: { create: [], call: ["NoOp"] },
135
+ readonly: false,
136
+ events: [
137
+ {
138
+ name: "TokensReceived",
139
+ args: [
140
+ { type: "uint64", name: "receiveAmount" },
141
+ { type: "address", name: "recipient" },
142
+ { type: "byte[32]", name: "nonce" },
143
+ { type: "byte", name: "messenger" },
144
+ { type: "byte[32]", name: "message" },
145
+ ],
146
+ },
147
+ ],
148
+ recommendations: {},
149
+ },
150
+ {
151
+ name: "registerBridge",
152
+ args: [
153
+ { type: "byte", name: "chainId" },
154
+ { type: "byte[32]", name: "bridgeAddress" },
155
+ ],
156
+ returns: { type: "void" },
157
+ actions: { create: [], call: ["NoOp"] },
158
+ readonly: false,
159
+ events: [],
160
+ recommendations: {},
161
+ },
162
+ {
163
+ name: "addBridgeToken",
164
+ args: [
165
+ { type: "byte", name: "chainId" },
166
+ { type: "byte[32]", name: "tokenAddress" },
167
+ ],
168
+ returns: { type: "void" },
169
+ actions: { create: [], call: ["NoOp"] },
170
+ readonly: false,
171
+ events: [],
172
+ recommendations: {},
173
+ },
174
+ {
175
+ name: "removeBridgeToken",
176
+ args: [
177
+ { type: "byte", name: "chainId" },
178
+ { type: "byte[32]", name: "tokenAddress" },
179
+ ],
180
+ returns: { type: "void" },
181
+ actions: { create: [], call: ["NoOp"] },
182
+ readonly: false,
183
+ events: [],
184
+ recommendations: {},
185
+ },
186
+ {
187
+ name: "withdrawGasTokens",
188
+ args: [{ type: "uint64", name: "amount" }],
189
+ returns: { type: "void" },
190
+ actions: { create: [], call: ["NoOp"] },
191
+ readonly: false,
192
+ events: [],
193
+ recommendations: {},
194
+ },
195
+ {
196
+ name: "withdrawBridgingFeeInTokens",
197
+ args: [{ type: "uint64", name: "asset" }],
198
+ returns: { type: "void" },
199
+ actions: { create: [], call: ["NoOp"] },
200
+ readonly: false,
201
+ events: [],
202
+ recommendations: {},
203
+ },
204
+ {
205
+ name: "getBridgingCostInTokens",
206
+ args: [
207
+ { type: "byte", name: "destinationChainId" },
208
+ { type: "uint64", name: "asset" },
209
+ ],
210
+ returns: { type: "uint64" },
211
+ actions: { create: [], call: ["NoOp"] },
212
+ readonly: true,
213
+ events: [],
214
+ recommendations: {},
215
+ },
216
+ {
217
+ name: "hashMessage",
218
+ args: [
219
+ { type: "uint64", name: "amount" },
220
+ { type: "byte[32]", name: "recipient" },
221
+ { type: "byte", name: "sourceChainId" },
222
+ { type: "byte", name: "destinationChainId" },
223
+ { type: "byte[32]", name: "receiveToken" },
224
+ { type: "byte[32]", name: "nonce" },
225
+ ],
226
+ returns: { type: "byte[32]" },
227
+ actions: { create: [], call: ["NoOp"] },
228
+ readonly: true,
229
+ events: [],
230
+ recommendations: {},
231
+ },
232
+ {
233
+ name: "isOtherBridgeTokenSupported",
234
+ args: [
235
+ { type: "byte", name: "chainId" },
236
+ { type: "byte[32]", name: "token" },
237
+ ],
238
+ returns: { type: "bool" },
239
+ actions: { create: [], call: ["NoOp"] },
240
+ readonly: true,
241
+ events: [],
242
+ recommendations: {},
243
+ },
244
+ {
245
+ name: "getTransactionCost",
246
+ args: [{ type: "byte", name: "chainId" }],
247
+ returns: { type: "uint64" },
248
+ actions: { create: [], call: ["NoOp"] },
249
+ readonly: true,
250
+ events: [],
251
+ recommendations: {},
252
+ },
253
+ {
254
+ name: "getReceiveTokensCost",
255
+ args: [],
256
+ returns: { type: "uint64" },
257
+ actions: { create: [], call: ["NoOp"] },
258
+ readonly: true,
259
+ events: [],
260
+ recommendations: {},
261
+ },
262
+ {
263
+ name: "getSendTransactionStorageCost",
264
+ args: [],
265
+ returns: { type: "uint64" },
266
+ actions: { create: [], call: ["NoOp"] },
267
+ readonly: true,
268
+ events: [],
269
+ recommendations: {},
270
+ },
271
+ {
272
+ name: "swap",
273
+ args: [
274
+ { type: "axfer", name: "assetTransferRef", desc: "The token to be swapped." },
275
+ { type: "uint64", name: "receiveAsset", desc: "The token to receive in exchange for the swapped token." },
276
+ { type: "address", name: "recipient", desc: "The address to receive the tokens." },
277
+ {
278
+ type: "uint64",
279
+ name: "receiveAmountMin",
280
+ desc: "The minimum amount of tokens required to receive during the swap.",
281
+ },
282
+ { type: "uint64", name: "budget", defaultValue: { source: "literal", data: "AAAAAAAAA+g=", type: "uint64" } },
283
+ ],
284
+ returns: { type: "void" },
285
+ actions: { create: [], call: ["NoOp"] },
286
+ readonly: false,
287
+ events: [
288
+ {
289
+ name: "Swapped",
290
+ args: [
291
+ { type: "address", name: "sender" },
292
+ { type: "address", name: "recipient" },
293
+ { type: "uint64", name: "tokenId" },
294
+ { type: "uint64", name: "receiveTokenId" },
295
+ { type: "uint64", name: "amount" },
296
+ { type: "uint64", name: "receivedAmount" },
297
+ ],
298
+ },
299
+ ],
300
+ recommendations: {},
301
+ },
302
+ {
303
+ name: "addPool",
304
+ args: [
305
+ { type: "uint64", name: "poolId", desc: "The address of the `Pool` contract." },
306
+ { type: "uint64", name: "asset", desc: "The address of the token in the liquidity pool." },
307
+ ],
308
+ returns: { type: "void" },
309
+ actions: { create: [], call: ["NoOp"] },
310
+ readonly: false,
311
+ events: [],
312
+ recommendations: {},
313
+ },
314
+ {
315
+ name: "removePool",
316
+ args: [{ type: "uint64", name: "tokenId" }],
317
+ returns: { type: "void" },
318
+ actions: { create: [], call: ["NoOp"] },
319
+ readonly: false,
320
+ events: [],
321
+ recommendations: {},
322
+ },
323
+ {
324
+ name: "stopSwap",
325
+ args: [],
326
+ returns: { type: "void" },
327
+ actions: { create: [], call: ["NoOp"] },
328
+ readonly: false,
329
+ events: [],
330
+ recommendations: {},
331
+ },
332
+ {
333
+ name: "startSwap",
334
+ args: [],
335
+ returns: { type: "void" },
336
+ actions: { create: [], call: ["NoOp"] },
337
+ readonly: false,
338
+ events: [],
339
+ recommendations: {},
340
+ },
341
+ {
342
+ name: "setStopAuthority",
343
+ args: [{ type: "address", name: "stopAuthority" }],
344
+ returns: { type: "void" },
345
+ actions: { create: [], call: ["NoOp"] },
346
+ readonly: false,
347
+ events: [],
348
+ recommendations: {},
349
+ },
350
+ {
351
+ name: "setRebalancer",
352
+ args: [{ type: "address", name: "rebalancer" }],
353
+ returns: { type: "void" },
354
+ actions: { create: [], call: ["NoOp"] },
355
+ readonly: false,
356
+ events: [],
357
+ recommendations: {},
358
+ },
359
+ {
360
+ name: "getGasUsage",
361
+ args: [{ type: "byte", name: "chainId" }],
362
+ returns: { type: "uint64" },
363
+ actions: { create: [], call: ["NoOp"] },
364
+ readonly: true,
365
+ events: [],
366
+ recommendations: {},
367
+ },
368
+ {
369
+ name: "setGasUsage",
370
+ args: [
371
+ { type: "byte", name: "chainId" },
372
+ { type: "uint64", name: "gasAmount" },
373
+ ],
374
+ returns: { type: "void" },
375
+ actions: { create: [], call: ["NoOp"] },
376
+ readonly: false,
377
+ events: [],
378
+ recommendations: {},
379
+ },
380
+ {
381
+ name: "setGasOracle",
382
+ args: [{ type: "uint64", name: "gasOracle" }],
383
+ returns: { type: "void" },
384
+ actions: { create: [], call: ["NoOp"] },
385
+ readonly: false,
386
+ events: [],
387
+ recommendations: {},
388
+ },
389
+ {
390
+ name: "getTransactionRelayerCost",
391
+ args: [{ type: "byte", name: "chainId" }],
392
+ returns: { type: "uint64" },
393
+ actions: { create: [], call: ["NoOp"] },
394
+ readonly: true,
395
+ events: [],
396
+ recommendations: {},
397
+ },
398
+ {
399
+ name: "transferOwnership",
400
+ args: [{ type: "address", name: "newOwner" }],
401
+ returns: { type: "void" },
402
+ actions: { create: [], call: ["NoOp"] },
403
+ readonly: false,
404
+ events: [],
405
+ recommendations: {},
406
+ },
407
+ ],
408
+ arcs: [22, 28],
409
+ networks: {},
410
+ state: {
411
+ schema: { global: { ints: 3, bytes: 4 }, local: { ints: 0, bytes: 0 } },
412
+ keys: {
413
+ global: {
414
+ chainId: { keyType: "AVMString", valueType: "byte", key: "Y2hhaW5JZA==" },
415
+ messenger: { keyType: "AVMString", valueType: "AVMUint64", key: "bWVzc2VuZ2Vy" },
416
+ stopAuthority: { keyType: "AVMString", valueType: "address", key: "c3RvcEF1dGhvcml0eQ==" },
417
+ rebalancer: { keyType: "AVMString", valueType: "address", key: "cmViYWxhbmNlcg==" },
418
+ canSwap: { keyType: "AVMString", valueType: "AVMUint64", key: "Y2FuU3dhcA==" },
419
+ gasOracle: { keyType: "AVMString", valueType: "AVMUint64", key: "Z2FzT3JhY2xl" },
420
+ owner: { keyType: "AVMString", valueType: "address", key: "b3duZXI=" },
421
+ },
422
+ local: {},
423
+ box: {},
424
+ },
425
+ maps: {
426
+ global: {},
427
+ local: {},
428
+ box: {
429
+ processedMessages: { keyType: "byte[32]", valueType: "byte[0]", prefix: "bQ==" },
430
+ sentMessages: { keyType: "byte[32]", valueType: "byte[0]", prefix: "cw==" },
431
+ otherBridges: { keyType: "byte", valueType: "byte[32]", prefix: "Yg==" },
432
+ otherBridgeTokens: { keyType: "AVMBytes", valueType: "byte[0]", prefix: "dA==" },
433
+ pools: { keyType: "uint64", valueType: "uint64", prefix: "cA==" },
434
+ fromGasOracleScalingFactor: { keyType: "uint64", valueType: "uint64", prefix: "ZQ==" },
435
+ bridgingFeeConversionScalingFactor: { keyType: "uint64", valueType: "uint64", prefix: "Zg==" },
436
+ gasUsage: { keyType: "byte", valueType: "uint64", prefix: "dQ==" },
437
+ },
438
+ },
439
+ },
440
+ bareActions: { create: [], call: [] },
441
+ sourceInfo: {
442
+ approval: {
443
+ sourceInfo: [
444
+ { pc: [431], errorMessage: "Asset must go to app" },
445
+ { pc: [877, 1323, 2099, 2412, 2424], errorMessage: "Box must have value" },
446
+ { pc: [1835], errorMessage: "Bridge: amount too low for fee" },
447
+ { pc: [1842], errorMessage: "Bridge: bridge to the zero address" },
448
+ { pc: [911], errorMessage: "Bridge: message processed" },
449
+ { pc: [961], errorMessage: "Bridge: no message" },
450
+ { pc: [853, 2063], errorMessage: "Bridge: not enough fee" },
451
+ { pc: [843], errorMessage: "Bridge: source not registered" },
452
+ { pc: [1950], errorMessage: "Bridge: tokens already sent" },
453
+ { pc: [1915], errorMessage: "Bridge: unknown chain or token" },
454
+ { pc: [1902], errorMessage: "Bridge: wrong destination chain" },
455
+ { pc: [953, 1256, 1308, 1995, 2146, 2289, 2395, 2469], errorMessage: "Bytes has valid prefix" },
456
+ { pc: [447], errorMessage: "CloseTo not allowed" },
457
+ { pc: [137], errorMessage: "OnCompletion must be NoOp" },
458
+ { pc: [2484], errorMessage: "Only owner" },
459
+ { pc: [439], errorMessage: "Rekey not allowed" },
460
+ { pc: [1665], errorMessage: "Router: is not stopAuthority" },
461
+ { pc: [2311], errorMessage: "Router: no pool" },
462
+ { pc: [2221], errorMessage: "Router: no receive pool" },
463
+ { pc: [832, 1502, 1825], errorMessage: "Router: swap prohibited" },
464
+ { pc: [1166], errorMessage: "account opted into asset" },
465
+ { pc: [2006, 2319], errorMessage: "application exists" },
466
+ { pc: [1599], errorMessage: "asset exists" },
467
+ {
468
+ pc: [831, 858, 920, 1127, 1174, 1225, 1267, 1501, 1663, 1824, 1896, 1964, 2108, 2113, 2236, 2346, 2430, 2482],
469
+ errorMessage: "check GlobalState exists",
470
+ },
471
+ { pc: [1956], errorMessage: "index access is out of bounds" },
472
+ { pc: [958], errorMessage: "invalid number of bytes for arc4.bool" },
473
+ {
474
+ pc: [
475
+ 504, 642, 658, 666, 711, 727, 735, 791, 807, 818, 1040, 1069, 1098, 1349, 1373, 1381, 1406, 1475, 1686,
476
+ 1703, 1803,
477
+ ],
478
+ errorMessage: "invalid number of bytes for arc4.static_array<arc4.uint8, 32>",
479
+ },
480
+ {
481
+ pc: [
482
+ 520, 529, 561, 674, 743, 752, 779, 826, 1118, 1148, 1213, 1261, 1313, 1340, 1466, 1483, 1492, 1571, 1580,
483
+ 1643, 1746, 1768, 2000, 2151, 2294, 2400, 2474,
484
+ ],
485
+ errorMessage: "invalid number of bytes for arc4.uint64",
486
+ },
487
+ {
488
+ pc: [512, 650, 719, 799, 1032, 1061, 1090, 1205, 1357, 1365, 1398, 1434, 1720, 1738, 1785],
489
+ errorMessage: "invalid number of bytes for arc4.uint8",
490
+ },
491
+ { pc: [899, 2205], errorMessage: "invalid size" },
492
+ { pc: [634, 703, 1458], errorMessage: "transaction type is axfer" },
493
+ { pc: [623, 771], errorMessage: "transaction type is pay" },
494
+ ],
495
+ pcOffsetMethod: "none",
496
+ },
497
+ clear: { sourceInfo: [], pcOffsetMethod: "none" },
498
+ },
499
+ source: {
500
+ approval: "#pragma version 11
#pragma typetrack false

// @algorandfoundation/algorand-typescript/arc4/index.d.ts::Contract.approvalProgram() -> uint64:
main:
    intcblock 1 0 8 32 15700
    bytecblock 0x151f7c75 "canSwap" "owner" "gasOracle" "rebalancer" "chainId" "messenger" "t" "p" "stopAuthority" 0x01 0x00 "u" 0x43417aa3 0xf7475b82 0x151f7c750000000000003d54 0x068101
    txn ApplicationID
    bnz main_after_if_else@2
    // smart_contracts/contracts/router.algo.ts:52
    // private rebalancer = GlobalState<Address>({ initialValue: new Address(bzero(0)) });// can restrict deposit or withdraw operations
    intc_1 // 0
    bzero
    bytec 4 // "rebalancer"
    swap
    app_global_put
    // smart_contracts/contracts/router.algo.ts:53
    // canSwap = GlobalState<boolean>({ initialValue: true });
    bytec_1 // "canSwap"
    intc_0 // 1
    app_global_put

main_after_if_else@2:
    // smart_contracts/contracts/bridge.contract.algo.ts:55
    // export class Bridge extends Router implements ConventionalRouting, IBridge {
    txn OnCompletion
    !
    assert // OnCompletion must be NoOp
    txn ApplicationID
    bz main_create_NoOp@33
    pushbytess 0x65f70573 0x3e38027c 0xa4600aed 0xde4cad4a 0x4eba0721 0xc617ed73 0x57531560 0x63808278 0x06507c6a 0xf5f96eb3 0x4b062ca0 0xc3cdd92a // method "optInAsset(uint64)void", method "swapAndBridge(pay,axfer,byte[32],byte,byte[32],byte[32],uint64)void", method "swapAndBridgeWithStable(axfer,byte[32],byte,byte[32],byte[32],uint64,uint64)void", method "receiveTokens(pay,uint64,byte[32],byte,byte[32],byte[32],uint64)void", method "registerBridge(byte,byte[32])void", method "addBridgeToken(byte,byte[32])void", method "removeBridgeToken(byte,byte[32])void", method "withdrawGasTokens(uint64)void", method "withdrawBridgingFeeInTokens(uint64)void", method "getBridgingCostInTokens(byte,uint64)uint64", method "hashMessage(uint64,byte[32],byte,byte,byte[32],byte[32])byte[32]", method "isOtherBridgeTokenSupported(byte,byte[32])bool"
    bytec 13 // method "getTransactionCost(byte)uint64"
    pushbytess 0x07df8429 0x80c5c70f 0x4134d068 0xef15f855 0x6b1ee223 0x1870a492 0x3557324d 0x04b161f1 0xd2b357eb // method "getReceiveTokensCost()uint64", method "getSendTransactionStorageCost()uint64", method "swap(axfer,uint64,address,uint64,uint64)void", method "addPool(uint64,uint64)void", method "removePool(uint64)void", method "stopSwap()void", method "startSwap()void", method "setStopAuthority(address)void", method "setRebalancer(address)void"
    bytec 14 // method "getGasUsage(byte)uint64"
    pushbytess 0x0ca5ae7a 0x27470f07 0xcbfc6d02 0xe17bafb4 // method "setGasUsage(byte,uint64)void", method "setGasOracle(uint64)void", method "getTransactionRelayerCost(byte)uint64", method "transferOwnership(address)void"
    txna ApplicationArgs 0
    match optInAsset swapAndBridge swapAndBridgeWithStable receiveTokens registerBridge addBridgeToken removeBridgeToken withdrawGasTokens withdrawBridgingFeeInTokens getBridgingCostInTokens hashMessage isOtherBridgeTokenSupported getTransactionCost main_getReceiveTokensCost_route@18 main_getSendTransactionStorageCost_route@19 swap addPool removePool stopSwap startSwap setStopAuthority setRebalancer getGasUsage setGasUsage setGasOracle getTransactionRelayerCost transferOwnership
    err

main_getSendTransactionStorageCost_route@19:
    // smart_contracts/contracts/bridge.contract.algo.ts:351
    // @abimethod({ readonly: true })
    bytec 15 // 0x151f7c750000000000003d54
    log
    intc_0 // 1
    return

main_getReceiveTokensCost_route@18:
    // smart_contracts/contracts/bridge.contract.algo.ts:344
    // @abimethod({ readonly: true })
    bytec 15 // 0x151f7c750000000000003d54
    log
    intc_0 // 1
    return

main_create_NoOp@33:
    // smart_contracts/contracts/bridge.contract.algo.ts:55
    // export class Bridge extends Router implements ConventionalRouting, IBridge {
    pushbytes 0x664ca404 // method "createApplication(address,byte,uint64,uint64)void"
    txna ApplicationArgs 0
    match createApplication
    err


// _puya_lib.util.ensure_budget(required_budget: uint64, fee_source: uint64) -> void:
ensure_budget:
    proto 2 0
    frame_dig -2
    pushint 10 // 10
    +

ensure_budget_while_top@1:
    frame_dig 0
    global OpcodeBudget
    >
    bz ensure_budget_after_while@6
    itxn_begin
    pushint 6 // appl
    itxn_field TypeEnum
    pushint 5 // DeleteApplication
    itxn_field OnCompletion
    bytec 16 // 0x068101
    itxn_field ApprovalProgram
    bytec 16 // 0x068101
    itxn_field ClearStateProgram
    frame_dig -1
    switch ensure_budget_switch_case_0@3 ensure_budget_switch_case_1@4

ensure_budget_switch_case_next@5:
    itxn_submit
    b ensure_budget_while_top@1

ensure_budget_switch_case_1@4:
    global MinTxnFee
    itxn_field Fee
    b ensure_budget_switch_case_next@5

ensure_budget_switch_case_0@3:
    intc_1 // 0
    itxn_field Fee
    b ensure_budget_switch_case_next@5

ensure_budget_after_while@6:
    retsub


// smart_contracts/contracts/utils.algo.ts::amountFromAssetTransfer(assetTransferTxn: uint64) -> uint64:
amountFromAssetTransfer:
    // smart_contracts/contracts/utils.algo.ts:23
    // export function amountFromAssetTransfer(assetTransferTxn: gtxn.AssetTransferTxn): uint64 {
    proto 1 1
    // smart_contracts/contracts/utils.algo.ts:24
    // assert(assetTransferTxn.assetReceiver === Global.currentApplicationAddress, `Asset must go to app`);
    frame_dig -1
    gtxns AssetReceiver
    global CurrentApplicationAddress
    ==
    assert // Asset must go to app
    // smart_contracts/contracts/utils.algo.ts:27
    // assert(assetTransferTxn.rekeyTo === Global.zeroAddress, `Rekey not allowed`);
    frame_dig -1
    gtxns RekeyTo
    global ZeroAddress
    ==
    assert // Rekey not allowed
    // smart_contracts/contracts/utils.algo.ts:28
    // assert(assetTransferTxn.assetCloseTo === Global.zeroAddress, `CloseTo not allowed`);
    frame_dig -1
    gtxns AssetCloseTo
    global ZeroAddress
    ==
    assert // CloseTo not allowed
    // smart_contracts/contracts/utils.algo.ts:29
    // return assetTransferTxn.assetAmount;
    frame_dig -1
    gtxns AssetAmount
    retsub


// smart_contracts/contracts/utils.algo.ts::amountFromPayment(paymentTxn: uint64) -> uint64:
amountFromPayment:
    // smart_contracts/contracts/utils.algo.ts:32
    // export function amountFromPayment(paymentTxn: gtxn.PaymentTxn): uint64 {
    proto 1 1
    // smart_contracts/contracts/utils.algo.ts:33
    // if (paymentTxn.receiver !== Global.currentApplicationAddress) return 0;
    frame_dig -1
    gtxns Receiver
    global CurrentApplicationAddress
    !=
    bz amountFromPayment_after_if_else@2
    intc_1 // 0
    retsub

amountFromPayment_after_if_else@2:
    // smart_contracts/contracts/utils.algo.ts:35
    // if (paymentTxn.rekeyTo !== Global.zeroAddress) return 0;
    frame_dig -1
    gtxns RekeyTo
    global ZeroAddress
    !=
    bz amountFromPayment_after_if_else@4
    intc_1 // 0
    retsub

amountFromPayment_after_if_else@4:
    // smart_contracts/contracts/utils.algo.ts:36
    // if (paymentTxn.closeRemainderTo !== Global.zeroAddress) return 0;
    frame_dig -1
    gtxns CloseRemainderTo
    global ZeroAddress
    !=
    bz amountFromPayment_after_if_else@6
    intc_1 // 0
    retsub

amountFromPayment_after_if_else@6:
    // smart_contracts/contracts/utils.algo.ts:38
    // return paymentTxn.amount;
    frame_dig -1
    gtxns Amount
    retsub


// smart_contracts/contracts/bridge.contract.algo.ts::Bridge.createApplication[routing]() -> void:
createApplication:
    // smart_contracts/contracts/bridge.contract.algo.ts:69
    // createApplication(owner: Address, chainId: Byte, messenger: Application, gasOracle: Application): void {
    txna ApplicationArgs 1
    dup
    len
    intc_3 // 32
    ==
    assert // invalid number of bytes for arc4.static_array<arc4.uint8, 32>
    txna ApplicationArgs 2
    dup
    len
    intc_0 // 1
    ==
    assert // invalid number of bytes for arc4.uint8
    txna ApplicationArgs 3
    dup
    len
    intc_2 // 8
    ==
    assert // invalid number of bytes for arc4.uint64
    btoi
    txna ApplicationArgs 4
    dup
    len
    intc_2 // 8
    ==
    assert // invalid number of bytes for arc4.uint64
    btoi
    // smart_contracts/contracts/ownable.algo.ts:6
    // protected owner = GlobalState<Address>();
    bytec_2 // "owner"
    // smart_contracts/contracts/ownable.algo.ts:9
    // this.owner.value = owner;
    dig 4
    app_global_put
    // smart_contracts/contracts/gas-usage.algo.ts:9
    // gasOracle = GlobalState<Application>();
    bytec_3 // "gasOracle"
    // smart_contracts/contracts/gas-usage.algo.ts:14
    // this.gasOracle.value = gasOracle;
    swap
    app_global_put
    // smart_contracts/contracts/router.algo.ts:42
    // private stopAuthority = GlobalState<Address>();// can restrict deposit or withdraw operations
    bytec 9 // "stopAuthority"
    // smart_contracts/contracts/router.algo.ts:57
    // this.stopAuthority.value = owner;
    uncover 3
    app_global_put
    // smart_contracts/contracts/bridge.contract.algo.ts:57
    // chainId = GlobalState<Byte>();
    bytec 5 // "chainId"
    // smart_contracts/contracts/bridge.contract.algo.ts:71
    // this.chainId.value = chainId;
    uncover 2
    app_global_put
    // smart_contracts/contracts/bridge.contract.algo.ts:58
    // messenger = GlobalState<Application>();
    bytec 6 // "messenger"
    // smart_contracts/contracts/bridge.contract.algo.ts:72
    // this.messenger.value = messenger;
    swap
    app_global_put
    // smart_contracts/contracts/bridge.contract.algo.ts:69
    // createApplication(owner: Address, chainId: Byte, messenger: Application, gasOracle: Application): void {
    intc_0 // 1
    return


// smart_contracts/contracts/bridge.contract.algo.ts::Bridge.optInAsset[routing]() -> void:
optInAsset:
    // smart_contracts/contracts/bridge.contract.algo.ts:75
    // optInAsset(asset: Asset): void {
    txna ApplicationArgs 1
    dup
    len
    intc_2 // 8
    ==
    assert // invalid number of bytes for arc4.uint64
    btoi
    // smart_contracts/contracts/bridge.contract.algo.ts:76
    // this.onlyOwner();
    callsub onlyOwner
    // smart_contracts/contracts/bridge.contract.algo.ts:79-85
    // itxn
    //   .assetTransfer({
    //     xferAsset: asset,
    //     assetAmount: 0,
    //     assetReceiver: Global.currentApplicationAddress,
    //   })
    //   .submit();
    itxn_begin
    // smart_contracts/contracts/bridge.contract.algo.ts:83
    // assetReceiver: Global.currentApplicationAddress,
    global CurrentApplicationAddress
    itxn_field AssetReceiver
    // smart_contracts/contracts/bridge.contract.algo.ts:82
    // assetAmount: 0,
    intc_1 // 0
    itxn_field AssetAmount
    itxn_field XferAsset
    // smart_contracts/contracts/bridge.contract.algo.ts:79-84
    // itxn
    //   .assetTransfer({
    //     xferAsset: asset,
    //     assetAmount: 0,
    //     assetReceiver: Global.currentApplicationAddress,
    //   })
    pushint 4 // 4
    itxn_field TypeEnum
    intc_1 // 0
    itxn_field Fee
    // smart_contracts/contracts/bridge.contract.algo.ts:79-85
    // itxn
    //   .assetTransfer({
    //     xferAsset: asset,
    //     assetAmount: 0,
    //     assetReceiver: Global.currentApplicationAddress,
    //   })
    //   .submit();
    itxn_submit
    // smart_contracts/contracts/bridge.contract.algo.ts:87
    // log('Bridge: opt-in completed');
    pushbytes "Bridge: opt-in completed"
    log
    // smart_contracts/contracts/bridge.contract.algo.ts:75
    // optInAsset(asset: Asset): void {
    intc_0 // 1
    return


// smart_contracts/contracts/bridge.contract.algo.ts::Bridge.swapAndBridge[routing]() -> void:
swapAndBridge:
    // smart_contracts/contracts/bridge.contract.algo.ts:90
    // @abimethod({ defaultArguments: { budget: { constant: 1000 } } })
    txn GroupIndex
    pushint 2 // 2
    -
    dup
    gtxns TypeEnum
    intc_0 // pay
    ==
    assert // transaction type is pay
    txn GroupIndex
    intc_0 // 1
    -
    dup
    gtxns TypeEnum
    pushint 4 // axfer
    ==
    assert // transaction type is axfer
    txna ApplicationArgs 1
    dup
    len
    intc_3 // 32
    ==
    assert // invalid number of bytes for arc4.static_array<arc4.uint8, 32>
    txna ApplicationArgs 2
    dup
    len
    intc_0 // 1
    ==
    assert // invalid number of bytes for arc4.uint8
    txna ApplicationArgs 3
    dup
    len
    intc_3 // 32
    ==
    assert // invalid number of bytes for arc4.static_array<arc4.uint8, 32>
    txna ApplicationArgs 4
    dup
    len
    intc_3 // 32
    ==
    assert // invalid number of bytes for arc4.static_array<arc4.uint8, 32>
    txna ApplicationArgs 5
    dup
    len
    intc_2 // 8
    ==
    assert // invalid number of bytes for arc4.uint64
    btoi
    // smart_contracts/contracts/bridge.contract.algo.ts:100
    // this._swapAndBridge(amountFromPayment(paymentRef), assetTransferRef, recipient, destinationChainId, receiveToken, nonce, 0, budget);
    uncover 6
    callsub amountFromPayment
    cover 6
    cover 6
    intc_1 // 0
    uncover 7
    callsub _swapAndBridge
    // smart_contracts/contracts/bridge.contract.algo.ts:90
    // @abimethod({ defaultArguments: { budget: { constant: 1000 } } })
    intc_0 // 1
    return


// smart_contracts/contracts/bridge.contract.algo.ts::Bridge.swapAndBridgeWithStable[routing]() -> void:
swapAndBridgeWithStable:
    // smart_contracts/contracts/bridge.contract.algo.ts:103
    // @abimethod({ defaultArguments: { budget: { constant: 1000 } } })
    txn GroupIndex
    intc_0 // 1
    -
    dup
    gtxns TypeEnum
    pushint 4 // axfer
    ==
    assert // transaction type is axfer
    txna ApplicationArgs 1
    dup
    len
    intc_3 // 32
    ==
    assert // invalid number of bytes for arc4.static_array<arc4.uint8, 32>
    txna ApplicationArgs 2
    dup
    len
    intc_0 // 1
    ==
    assert // invalid number of bytes for arc4.uint8
    txna ApplicationArgs 3
    dup
    len
    intc_3 // 32
    ==
    assert // invalid number of bytes for arc4.static_array<arc4.uint8, 32>
    txna ApplicationArgs 4
    dup
    len
    intc_3 // 32
    ==
    assert // invalid number of bytes for arc4.static_array<arc4.uint8, 32>
    txna ApplicationArgs 5
    dup
    len
    intc_2 // 8
    ==
    assert // invalid number of bytes for arc4.uint64
    btoi
    txna ApplicationArgs 6
    dup
    len
    intc_2 // 8
    ==
    assert // invalid number of bytes for arc4.uint64
    btoi
    // smart_contracts/contracts/bridge.contract.algo.ts:113
    // this._swapAndBridge(0, assetTransferRef, recipient, destinationChainId, receiveToken, nonce, feeTokenAmount, budget);
    intc_1 // 0
    cover 7
    callsub _swapAndBridge
    // smart_contracts/contracts/bridge.contract.algo.ts:103
    // @abimethod({ defaultArguments: { budget: { constant: 1000 } } })
    intc_0 // 1
    return


// smart_contracts/contracts/bridge.contract.algo.ts::Bridge.receiveTokens[routing]() -> void:
receiveTokens:
    // smart_contracts/contracts/bridge.contract.algo.ts:193
    // @abimethod()
    txn GroupIndex
    intc_0 // 1
    -
    dup
    gtxns TypeEnum
    intc_0 // pay
    ==
    assert // transaction type is pay
    txna ApplicationArgs 1
    dup
    len
    intc_2 // 8
    ==
    assert // invalid number of bytes for arc4.uint64
    btoi
    txna ApplicationArgs 2
    dup
    cover 3
    dup
    len
    intc_3 // 32
    ==
    assert // invalid number of bytes for arc4.static_array<arc4.uint8, 32>
    txna ApplicationArgs 3
    dup
    len
    intc_0 // 1
    ==
    assert // invalid number of bytes for arc4.uint8
    txna ApplicationArgs 4
    dup
    len
    intc_3 // 32
    ==
    assert // invalid number of bytes for arc4.static_array<arc4.uint8, 32>
    txna ApplicationArgs 5
    dup
    cover 6
    dup
    len
    intc_3 // 32
    ==
    assert // invalid number of bytes for arc4.static_array<arc4.uint8, 32>
    txna ApplicationArgs 6
    dup
    len
    intc_2 // 8
    ==
    assert // invalid number of bytes for arc4.uint64
    btoi
    // smart_contracts/contracts/router.algo.ts:64
    // assert(this.canSwap.value, 'Router: swap prohibited');
    intc_1 // 0
    // smart_contracts/contracts/router.algo.ts:53
    // canSwap = GlobalState<boolean>({ initialValue: true });
    bytec_1 // "canSwap"
    // smart_contracts/contracts/router.algo.ts:64
    // assert(this.canSwap.value, 'Router: swap prohibited');
    app_global_get_ex
    assert // check GlobalState exists
    assert // Router: swap prohibited
    // smart_contracts/contracts/bridge.contract.algo.ts:64
    // otherBridges = BoxMap<Byte, StaticBytes<32>>({ keyPrefix: 'b' });
    pushbytes "b"
    dig 4
    concat
    // smart_contracts/contracts/bridge.contract.algo.ts:204
    // assert(this.otherBridges(sourceChainId).exists, 'Bridge: source not registered');
    dup
    box_len
    bury 1
    assert // Bridge: source not registered
    // smart_contracts/contracts/bridge.contract.algo.ts:206
    // const value = amountFromPayment(paymentRef);
    uncover 7
    callsub amountFromPayment
    // smart_contracts/contracts/bridge.contract.algo.ts:207
    // assert(value >= storageFee, 'Bridge: not enough fee');
    dup
    // smart_contracts/contracts/bridge.contract.algo.ts:348
    // return 15700;
    intc 4 // 15700
    // smart_contracts/contracts/bridge.contract.algo.ts:207
    // assert(value >= storageFee, 'Bridge: not enough fee');
    >=
    assert // Bridge: not enough fee
    // smart_contracts/contracts/bridge.contract.algo.ts:209
    // const message = this.hashMessage(amount, recipient, sourceChainId, this.chainId.value, receiveToken, nonce);
    intc_1 // 0
    // smart_contracts/contracts/bridge.contract.algo.ts:57
    // chainId = GlobalState<Byte>();
    bytec 5 // "chainId"
    // smart_contracts/contracts/bridge.contract.algo.ts:209
    // const message = this.hashMessage(amount, recipient, sourceChainId, this.chainId.value, receiveToken, nonce);
    app_global_get_ex
    assert // check GlobalState exists
    dig 8
    dig 8
    uncover 8
    uncover 3
    dig 8
    uncover 8
    callsub smart_contracts/contracts/bridge.contract.algo.ts::Bridge.hashMessage
    // smart_contracts/contracts/bridge.contract.algo.ts:210
    // const messageWithSender = hashWithSenderAddress(message, this.otherBridges(sourceChainId).value.bytes);
    uncover 2
    box_get
    assert // Box must have value
    // smart_contracts/contracts/utils.algo.ts:52
    // const h: bytes = op.keccak256(op.concat(message.bytes, senderAddress));
    dig 1
    swap
    concat
    keccak256
    // smart_contracts/contracts/utils.algo.ts:55
    // const first2 = op.substring(message.bytes, 0, 2);
    swap
    substring 0 2
    // smart_contracts/contracts/utils.algo.ts:57
    // const last30 = op.substring(h, 2, 32);
    swap
    substring 2 32
    // smart_contracts/contracts/utils.algo.ts:60
    // return new StaticBytes<32>(op.concat(first2, last30));
    concat
    dup
    cover 6
    dup
    len
    intc_3 // 32
    ==
    assert // invalid size
    // smart_contracts/contracts/bridge.contract.algo.ts:60
    // processedMessages = BoxMap<StaticBytes<32>, StaticBytes>({ keyPrefix: 'm' });
    pushbytes "m"
    dig 1
    concat
    // smart_contracts/contracts/bridge.contract.algo.ts:212
    // assert(!this.processedMessages(messageWithSender).exists, 'Bridge: message processed');
    dup
    box_len
    bury 1
    !
    assert // Bridge: message processed
    // smart_contracts/contracts/bridge.contract.algo.ts:214
    // this.processedMessages(messageWithSender).value = new StaticBytes();
    pushbytes 0x
    box_put
    // smart_contracts/contracts/bridge.contract.algo.ts:217-221
    // assert(abiCall({
    //   method: Messenger.prototype.receivedMessages,
    //   appId: this.messenger.value.id,
    //   args: [messageWithSender],
    // }).returnValue, 'Bridge: no message');
    itxn_begin
    // smart_contracts/contracts/bridge.contract.algo.ts:219
    // appId: this.messenger.value.id,
    intc_1 // 0
    // smart_contracts/contracts/bridge.contract.algo.ts:58
    // messenger = GlobalState<Application>();
    bytec 6 // "messenger"
    // smart_contracts/contracts/bridge.contract.algo.ts:219
    // appId: this.messenger.value.id,
    app_global_get_ex
    assert // check GlobalState exists
    // smart_contracts/contracts/bridge.contract.algo.ts:217-221
    // assert(abiCall({
    //   method: Messenger.prototype.receivedMessages,
    //   appId: this.messenger.value.id,
    //   args: [messageWithSender],
    // }).returnValue, 'Bridge: no message');
    pushbytes 0x33e147aa // method "receivedMessages(byte[32])bool"
    itxn_field ApplicationArgs
    itxn_field ApplicationID
    itxn_field ApplicationArgs
    pushint 6 // appl
    itxn_field TypeEnum
    intc_1 // 0
    itxn_field Fee
    itxn_submit
    itxn LastLog
    dup
    extract 4 0
    swap
    extract 0 4
    bytec_0 // 0x151f7c75
    ==
    assert // Bytes has valid prefix
    dup
    len
    intc_0 // 1
    ==
    assert // invalid number of bytes for arc4.bool
    intc_1 // 0
    getbit
    assert // Bridge: no message
    // smart_contracts/contracts/bridge.contract.algo.ts:223
    // const tokenId: uint64 = op.extractUint64(receiveToken.bytes, 24);
    uncover 2
    pushint 24 // 24
    extract_uint64
    // smart_contracts/contracts/bridge.contract.algo.ts:225-230
    // const receiveAmount = this.receiveAndSwapFromVUsd(
    //   Asset(tokenId),
    //   recipientAddress,
    //   amount,
    //   receiveAmountMin,
    // );
    uncover 3
    uncover 4
    uncover 4
    callsub receiveAndSwapFromVUsd
    swap
    // smart_contracts/contracts/bridge.contract.algo.ts:348
    // return 15700;
    intc 4 // 15700
    // smart_contracts/contracts/bridge.contract.algo.ts:233
    // const extraGas: uint64 = value - storageFee;
    -
    dup
    // smart_contracts/contracts/bridge.contract.algo.ts:234
    // if (extraGas > 0) {
    bz receiveTokens_after_if_else@5
    // smart_contracts/contracts/bridge.contract.algo.ts:235-238
    // itxn.payment({
    //   amount: extraGas,
    //   receiver: recipientAddress.bytes,
    // }).submit();
    itxn_begin
    dig 4
    itxn_field Receiver
    dup
    itxn_field Amount
    intc_0 // 1
    itxn_field TypeEnum
    intc_1 // 0
    itxn_field Fee
    itxn_submit

receiveTokens_after_if_else@5:
    // smart_contracts/contracts/bridge.contract.algo.ts:240-246
    // emit<TokensReceived>({
    //   receiveAmount,
    //   recipient: recipientAddress,
    //   nonce,
    //   messenger: ALLBRIDGE_MESSENGER,
    //   message: messageWithSender,
    // });
    dig 1
    itob
    dig 5
    concat
    dig 4
    concat
    // smart_contracts/contracts/bridge.contract.algo.ts:244
    // messenger: ALLBRIDGE_MESSENGER,
    bytec 10 // 0x01
    // smart_contracts/contracts/bridge.contract.algo.ts:240-246
    // emit<TokensReceived>({
    //   receiveAmount,
    //   recipient: recipientAddress,
    //   nonce,
    //   messenger: ALLBRIDGE_MESSENGER,
    //   message: messageWithSender,
    // });
    concat
    dig 3
    concat
    pushbytes 0x45836ad6 // method "TokensReceived(uint64,address,byte[32],byte,byte[32])"
    swap
    concat
    log
    // smart_contracts/contracts/bridge.contract.algo.ts:193
    // @abimethod()
    intc_0 // 1
    return


// smart_contracts/contracts/bridge.contract.algo.ts::Bridge.registerBridge[routing]() -> void:
registerBridge:
    // smart_contracts/contracts/bridge.contract.algo.ts:249
    // @abimethod()
    txna ApplicationArgs 1
    dup
    len
    intc_0 // 1
    ==
    assert // invalid number of bytes for arc4.uint8
    txna ApplicationArgs 2
    dup
    len
    intc_3 // 32
    ==
    assert // invalid number of bytes for arc4.static_array<arc4.uint8, 32>
    // smart_contracts/contracts/bridge.contract.algo.ts:251
    // this.onlyOwner();
    callsub onlyOwner
    // smart_contracts/contracts/bridge.contract.algo.ts:64
    // otherBridges = BoxMap<Byte, StaticBytes<32>>({ keyPrefix: 'b' });
    pushbytes "b"
    uncover 2
    concat
    // smart_contracts/contracts/bridge.contract.algo.ts:252
    // this.otherBridges(chainId).value = bridgeAddress;
    swap
    box_put
    // smart_contracts/contracts/bridge.contract.algo.ts:249
    // @abimethod()
    intc_0 // 1
    return


// smart_contracts/contracts/bridge.contract.algo.ts::Bridge.addBridgeToken[routing]() -> void:
addBridgeToken:
    // smart_contracts/contracts/bridge.contract.algo.ts:255
    // @abimethod()
    txna ApplicationArgs 1
    dup
    len
    intc_0 // 1
    ==
    assert // invalid number of bytes for arc4.uint8
    txna ApplicationArgs 2
    dup
    len
    intc_3 // 32
    ==
    assert // invalid number of bytes for arc4.static_array<arc4.uint8, 32>
    // smart_contracts/contracts/bridge.contract.algo.ts:257
    // this.onlyOwner();
    callsub onlyOwner
    // smart_contracts/contracts/bridge.contract.algo.ts:361
    // return chainId.bytes.concat(token.bytes);
    concat
    // smart_contracts/contracts/bridge.contract.algo.ts:67
    // otherBridgeTokens = BoxMap<bytes, StaticBytes>({ keyPrefix: 't' });
    bytec 7 // "t"
    swap
    concat
    // smart_contracts/contracts/bridge.contract.algo.ts:258
    // this.otherBridgeTokens(this._getOtherBridgeTokensKey(chainId, tokenAddress)).value = new StaticBytes();
    pushbytes 0x
    box_put
    // smart_contracts/contracts/bridge.contract.algo.ts:255
    // @abimethod()
    intc_0 // 1
    return


// smart_contracts/contracts/bridge.contract.algo.ts::Bridge.removeBridgeToken[routing]() -> void:
removeBridgeToken:
    // smart_contracts/contracts/bridge.contract.algo.ts:261
    // @abimethod()
    txna ApplicationArgs 1
    dup
    len
    intc_0 // 1
    ==
    assert // invalid number of bytes for arc4.uint8
    txna ApplicationArgs 2
    dup
    len
    intc_3 // 32
    ==
    assert // invalid number of bytes for arc4.static_array<arc4.uint8, 32>
    // smart_contracts/contracts/bridge.contract.algo.ts:263
    // this.onlyOwner();
    callsub onlyOwner
    // smart_contracts/contracts/bridge.contract.algo.ts:361
    // return chainId.bytes.concat(token.bytes);
    concat
    // smart_contracts/contracts/bridge.contract.algo.ts:67
    // otherBridgeTokens = BoxMap<bytes, StaticBytes>({ keyPrefix: 't' });
    bytec 7 // "t"
    swap
    concat
    // smart_contracts/contracts/bridge.contract.algo.ts:264
    // this.otherBridgeTokens(this._getOtherBridgeTokensKey(chainId, tokenAddress)).delete();
    box_del
    pop
    // smart_contracts/contracts/bridge.contract.algo.ts:261
    // @abimethod()
    intc_0 // 1
    return


// smart_contracts/contracts/bridge.contract.algo.ts::Bridge.withdrawGasTokens[routing]() -> void:
withdrawGasTokens:
    // smart_contracts/contracts/bridge.contract.algo.ts:267
    // @abimethod()
    txna ApplicationArgs 1
    dup
    len
    intc_2 // 8
    ==
    assert // invalid number of bytes for arc4.uint64
    btoi
    // smart_contracts/contracts/bridge.contract.algo.ts:269
    // this.onlyOwner();
    callsub onlyOwner
    // smart_contracts/contracts/bridge.contract.algo.ts:270
    // itxn.payment({ amount: amount, receiver: this.owner.value.bytes }).submit();
    itxn_begin
    intc_1 // 0
    // smart_contracts/contracts/ownable.algo.ts:6
    // protected owner = GlobalState<Address>();
    bytec_2 // "owner"
    // smart_contracts/contracts/bridge.contract.algo.ts:270
    // itxn.payment({ amount: amount, receiver: this.owner.value.bytes }).submit();
    app_global_get_ex
    assert // check GlobalState exists
    itxn_field Receiver
    itxn_field Amount
    intc_0 // 1
    itxn_field TypeEnum
    intc_1 // 0
    itxn_field Fee
    itxn_submit
    // smart_contracts/contracts/bridge.contract.algo.ts:267
    // @abimethod()
    intc_0 // 1
    return


// smart_contracts/contracts/bridge.contract.algo.ts::Bridge.withdrawBridgingFeeInTokens[routing]() -> void:
withdrawBridgingFeeInTokens:
    // smart_contracts/contracts/bridge.contract.algo.ts:273
    // @abimethod()
    txna ApplicationArgs 1
    dup
    len
    intc_2 // 8
    ==
    assert // invalid number of bytes for arc4.uint64
    btoi
    dup
    // smart_contracts/contracts/bridge.contract.algo.ts:275
    // this.onlyOwner();
    callsub onlyOwner
    // smart_contracts/contracts/bridge.contract.algo.ts:276
    // const appAcct: Account = Global.currentApplicationAddress;
    global CurrentApplicationAddress
    dup
    cover 2
    // smart_contracts/contracts/bridge.contract.algo.ts:277
    // const balance = asset.balance(appAcct);
    swap
    asset_holding_get AssetBalance
    swap
    dup
    uncover 2
    assert // account opted into asset
    // smart_contracts/contracts/bridge.contract.algo.ts:278
    // if (balance > Uint64(0)) {
    bz withdrawBridgingFeeInTokens_after_if_else@4
    // smart_contracts/contracts/bridge.contract.algo.ts:279-284
    // itxn.assetTransfer({
    //   sender: appAcct,
    //   xferAsset: asset,
    //   assetAmount: balance,
    //   assetReceiver: this.owner.value.bytes,
    // }).submit();
    itxn_begin
    // smart_contracts/contracts/bridge.contract.algo.ts:283
    // assetReceiver: this.owner.value.bytes,
    intc_1 // 0
    // smart_contracts/contracts/ownable.algo.ts:6
    // protected owner = GlobalState<Address>();
    bytec_2 // "owner"
    // smart_contracts/contracts/bridge.contract.algo.ts:283
    // assetReceiver: this.owner.value.bytes,
    app_global_get_ex
    assert // check GlobalState exists
    itxn_field AssetReceiver
    dup
    itxn_field AssetAmount
    dig 2
    itxn_field XferAsset
    dig 1
    itxn_field Sender
    // smart_contracts/contracts/bridge.contract.algo.ts:279-284
    // itxn.assetTransfer({
    //   sender: appAcct,
    //   xferAsset: asset,
    //   assetAmount: balance,
    //   assetReceiver: this.owner.value.bytes,
    // }).submit();
    pushint 4 // 4
    itxn_field TypeEnum
    intc_1 // 0
    itxn_field Fee
    itxn_submit

withdrawBridgingFeeInTokens_after_if_else@4:
    // smart_contracts/contracts/bridge.contract.algo.ts:273
    // @abimethod()
    intc_0 // 1
    return


// smart_contracts/contracts/bridge.contract.algo.ts::Bridge.getBridgingCostInTokens[routing]() -> void:
getBridgingCostInTokens:
    // smart_contracts/contracts/bridge.contract.algo.ts:288
    // @abimethod({ readonly: true })
    txna ApplicationArgs 1
    dup
    len
    intc_0 // 1
    ==
    assert // invalid number of bytes for arc4.uint8
    txna ApplicationArgs 2
    dup
    len
    intc_2 // 8
    ==
    assert // invalid number of bytes for arc4.uint64
    btoi
    // smart_contracts/contracts/bridge.contract.algo.ts:293
    // const bridgeGasAmount: uint64 = this.getGasUsage(destinationChainId);
    dig 1
    callsub smart_contracts/contracts/gas-usage.algo.ts::GasUsage.getGasUsage
    // smart_contracts/contracts/bridge.contract.algo.ts:294-298
    // const messengerGasAmount: uint64 = abiCall({
    //   method: Messenger.prototype.getGasUsage,
    //   appId: this.messenger.value.id,
    //   args: [destinationChainId],
    // }).returnValue;
    itxn_begin
    // smart_contracts/contracts/bridge.contract.algo.ts:296
    // appId: this.messenger.value.id,
    intc_1 // 0
    // smart_contracts/contracts/bridge.contract.algo.ts:58
    // messenger = GlobalState<Application>();
    bytec 6 // "messenger"
    // smart_contracts/contracts/bridge.contract.algo.ts:296
    // appId: this.messenger.value.id,
    app_global_get_ex
    assert // check GlobalState exists
    // smart_contracts/contracts/bridge.contract.algo.ts:294-298
    // const messengerGasAmount: uint64 = abiCall({
    //   method: Messenger.prototype.getGasUsage,
    //   appId: this.messenger.value.id,
    //   args: [destinationChainId],
    // }).returnValue;
    bytec 14 // method "getGasUsage(byte)uint64"
    itxn_field ApplicationArgs
    dig 3
    itxn_field ApplicationArgs
    itxn_field ApplicationID
    pushint 6 // appl
    itxn_field TypeEnum
    intc_1 // 0
    itxn_field Fee
    itxn_submit
    itxn LastLog
    dup
    extract 4 0
    swap
    extract 0 4
    bytec_0 // 0x151f7c75
    ==
    assert // Bytes has valid prefix
    dup
    len
    intc_2 // 8
    ==
    assert // invalid number of bytes for arc4.uint64
    btoi
    // smart_contracts/contracts/bridge.contract.algo.ts:300-304
    // return abiCall({
    //   method: GasOracle.prototype.getTransactionGasCostInUSD,
    //   appId: this.gasOracle.value.id,
    //   args: [destinationChainId, bridgeGasAmount + messengerGasAmount],
    // }).returnValue / this.fromGasOracleScalingFactor(asset).value;
    itxn_begin
    // smart_contracts/contracts/bridge.contract.algo.ts:302
    // appId: this.gasOracle.value.id,
    intc_1 // 0
    // smart_contracts/contracts/gas-usage.algo.ts:9
    // gasOracle = GlobalState<Application>();
    bytec_3 // "gasOracle"
    // smart_contracts/contracts/bridge.contract.algo.ts:302
    // appId: this.gasOracle.value.id,
    app_global_get_ex
    assert // check GlobalState exists
    // smart_contracts/contracts/bridge.contract.algo.ts:303
    // args: [destinationChainId, bridgeGasAmount + messengerGasAmount],
    cover 2
    +
    itob
    // smart_contracts/contracts/bridge.contract.algo.ts:300-304
    // return abiCall({
    //   method: GasOracle.prototype.getTransactionGasCostInUSD,
    //   appId: this.gasOracle.value.id,
    //   args: [destinationChainId, bridgeGasAmount + messengerGasAmount],
    // }).returnValue / this.fromGasOracleScalingFactor(asset).value;
    pushbytes 0x7bf7d50c // method "getTransactionGasCostInUSD(byte,uint64)uint64"
    itxn_field ApplicationArgs
    uncover 3
    itxn_field ApplicationArgs
    itxn_field ApplicationArgs
    itxn_field ApplicationID
    pushint 6 // appl
    itxn_field TypeEnum
    intc_1 // 0
    itxn_field Fee
    itxn_submit
    itxn LastLog
    dup
    extract 4 0
    swap
    extract 0 4
    bytec_0 // 0x151f7c75
    ==
    assert // Bytes has valid prefix
    dup
    len
    intc_2 // 8
    ==
    assert // invalid number of bytes for arc4.uint64
    btoi
    // smart_contracts/contracts/bridge.contract.algo.ts:304
    // }).returnValue / this.fromGasOracleScalingFactor(asset).value;
    swap
    itob
    // smart_contracts/contracts/router.algo.ts:36
    // protected fromGasOracleScalingFactor = BoxMap<Asset, uint64>({ keyPrefix: 'e' });
    pushbytes "e"
    swap
    concat
    // smart_contracts/contracts/bridge.contract.algo.ts:304
    // }).returnValue / this.fromGasOracleScalingFactor(asset).value;
    box_get
    assert // Box must have value
    btoi
    // smart_contracts/contracts/bridge.contract.algo.ts:300-304
    // return abiCall({
    //   method: GasOracle.prototype.getTransactionGasCostInUSD,
    //   appId: this.gasOracle.value.id,
    //   args: [destinationChainId, bridgeGasAmount + messengerGasAmount],
    // }).returnValue / this.fromGasOracleScalingFactor(asset).value;
    /
    // smart_contracts/contracts/bridge.contract.algo.ts:288
    // @abimethod({ readonly: true })
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// smart_contracts/contracts/bridge.contract.algo.ts::Bridge.hashMessage[routing]() -> void:
hashMessage:
    // smart_contracts/contracts/bridge.contract.algo.ts:307
    // @abimethod({ readonly: true })
    txna ApplicationArgs 1
    dup
    len
    intc_2 // 8
    ==
    assert // invalid number of bytes for arc4.uint64
    btoi
    txna ApplicationArgs 2
    dup
    len
    intc_3 // 32
    ==
    assert // invalid number of bytes for arc4.static_array<arc4.uint8, 32>
    txna ApplicationArgs 3
    dup
    len
    intc_0 // 1
    ==
    assert // invalid number of bytes for arc4.uint8
    txna ApplicationArgs 4
    dup
    len
    intc_0 // 1
    ==
    assert // invalid number of bytes for arc4.uint8
    txna ApplicationArgs 5
    dup
    len
    intc_3 // 32
    ==
    assert // invalid number of bytes for arc4.static_array<arc4.uint8, 32>
    txna ApplicationArgs 6
    dup
    len
    intc_3 // 32
    ==
    assert // invalid number of bytes for arc4.static_array<arc4.uint8, 32>
    callsub smart_contracts/contracts/bridge.contract.algo.ts::Bridge.hashMessage
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// smart_contracts/contracts/bridge.contract.algo.ts::Bridge.isOtherBridgeTokenSupported[routing]() -> void:
isOtherBridgeTokenSupported:
    // smart_contracts/contracts/bridge.contract.algo.ts:334
    // @abimethod({ readonly: true })
    txna ApplicationArgs 1
    dup
    len
    intc_0 // 1
    ==
    assert // invalid number of bytes for arc4.uint8
    txna ApplicationArgs 2
    dup
    len
    intc_3 // 32
    ==
    assert // invalid number of bytes for arc4.static_array<arc4.uint8, 32>
    // smart_contracts/contracts/bridge.contract.algo.ts:361
    // return chainId.bytes.concat(token.bytes);
    concat
    // smart_contracts/contracts/bridge.contract.algo.ts:67
    // otherBridgeTokens = BoxMap<bytes, StaticBytes>({ keyPrefix: 't' });
    bytec 7 // "t"
    swap
    concat
    // smart_contracts/contracts/bridge.contract.algo.ts:336
    // return this.otherBridgeTokens(this._getOtherBridgeTokensKey(chainId, token)).exists;
    box_len
    bury 1
    // smart_contracts/contracts/bridge.contract.algo.ts:334
    // @abimethod({ readonly: true })
    bytec 11 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// smart_contracts/contracts/bridge.contract.algo.ts::Bridge.getTransactionCost[routing]() -> void:
getTransactionCost:
    // smart_contracts/contracts/bridge.contract.algo.ts:339
    // @abimethod({ readonly: true })
    txna ApplicationArgs 1
    dup
    len
    intc_0 // 1
    ==
    assert // invalid number of bytes for arc4.uint8
    // smart_contracts/contracts/bridge.contract.algo.ts:341
    // return this.getTransactionRelayerCost(chainId) + this.getSendTransactionStorageCost();
    callsub smart_contracts/contracts/gas-usage.algo.ts::GasUsage.getTransactionRelayerCost
    // smart_contracts/contracts/bridge.contract.algo.ts:355
    // return 15700;
    intc 4 // 15700
    // smart_contracts/contracts/bridge.contract.algo.ts:341
    // return this.getTransactionRelayerCost(chainId) + this.getSendTransactionStorageCost();
    +
    // smart_contracts/contracts/bridge.contract.algo.ts:339
    // @abimethod({ readonly: true })
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// smart_contracts/contracts/router.algo.ts::Router.swap[routing]() -> void:
swap:
    // smart_contracts/contracts/router.algo.ts:81
    // @abimethod({ defaultArguments: { budget: { constant: 1000 } } })
    txn GroupIndex
    intc_0 // 1
    -
    dup
    gtxns TypeEnum
    pushint 4 // axfer
    ==
    assert // transaction type is axfer
    txna ApplicationArgs 1
    dup
    len
    intc_2 // 8
    ==
    assert // invalid number of bytes for arc4.uint64
    btoi
    txna ApplicationArgs 2
    dup
    len
    intc_3 // 32
    ==
    assert // invalid number of bytes for arc4.static_array<arc4.uint8, 32>
    txna ApplicationArgs 3
    dup
    len
    intc_2 // 8
    ==
    assert // invalid number of bytes for arc4.uint64
    btoi
    txna ApplicationArgs 4
    dup
    len
    intc_2 // 8
    ==
    assert // invalid number of bytes for arc4.uint64
    btoi
    // smart_contracts/contracts/router.algo.ts:89
    // ensureBudget(budget, OpUpFeeSource.GroupCredit);
    intc_1 // 0
    callsub ensure_budget
    // smart_contracts/contracts/router.algo.ts:64
    // assert(this.canSwap.value, 'Router: swap prohibited');
    intc_1 // 0
    // smart_contracts/contracts/router.algo.ts:53
    // canSwap = GlobalState<boolean>({ initialValue: true });
    bytec_1 // "canSwap"
    // smart_contracts/contracts/router.algo.ts:64
    // assert(this.canSwap.value, 'Router: swap prohibited');
    app_global_get_ex
    assert // check GlobalState exists
    assert // Router: swap prohibited
    // smart_contracts/contracts/router.algo.ts:91
    // const sender = new Address(Txn.sender);
    txn Sender
    // smart_contracts/contracts/router.algo.ts:92
    // const amount = amountFromAssetTransfer(assetTransferRef);
    dig 4
    callsub amountFromAssetTransfer
    // smart_contracts/contracts/router.algo.ts:93
    // const vUsdAmount = this.sendAndSwapToVUsd(assetTransferRef.xferAsset, sender, amount);
    uncover 5
    gtxns XferAsset
    dup
    dig 3
    dig 3
    callsub sendAndSwapToVUsd
    // smart_contracts/contracts/router.algo.ts:94
    // const receivedAmount = this.receiveAndSwapFromVUsd(receiveAsset, recipient, vUsdAmount, receiveAmountMin);
    dig 6
    dig 6
    uncover 2
    uncover 6
    callsub receiveAndSwapFromVUsd
    // smart_contracts/contracts/router.algo.ts:95-102
    // emit<Swapped>({
    //   sender,
    //   recipient,
    //   tokenId: assetTransferRef.xferAsset.id,
    //   receiveTokenId: receiveAsset.id,
    //   amount,
    //   receivedAmount,
    // });
    uncover 3
    uncover 4
    concat
    uncover 2
    itob
    concat
    uncover 3
    itob
    concat
    uncover 2
    itob
    concat
    swap
    itob
    concat
    pushbytes 0x154044b3 // method "Swapped(address,address,uint64,uint64,uint64,uint64)"
    swap
    concat
    log
    // smart_contracts/contracts/router.algo.ts:81
    // @abimethod({ defaultArguments: { budget: { constant: 1000 } } })
    intc_0 // 1
    return


// smart_contracts/contracts/router.algo.ts::Router.addPool[routing]() -> void:
addPool:
    // smart_contracts/contracts/router.algo.ts:112
    // @abimethod()
    txna ApplicationArgs 1
    dup
    len
    intc_2 // 8
    ==
    assert // invalid number of bytes for arc4.uint64
    btoi
    txna ApplicationArgs 2
    dup
    len
    intc_2 // 8
    ==
    assert // invalid number of bytes for arc4.uint64
    btoi
    // smart_contracts/contracts/router.algo.ts:114
    // this.onlyOwner();
    callsub onlyOwner
    // smart_contracts/contracts/router.algo.ts:115
    // this.pools(asset).value = poolId;
    dup
    itob
    // smart_contracts/contracts/router.algo.ts:34
    // pools = BoxMap<Asset, uint64>({ keyPrefix: 'p' });
    bytec 8 // "p"
    dig 1
    concat
    // smart_contracts/contracts/router.algo.ts:115
    // this.pools(asset).value = poolId;
    uncover 3
    itob
    box_put
    // smart_contracts/contracts/router.algo.ts:116
    // const tokenDecimals = asset.decimals;
    swap
    asset_params_get AssetDecimals
    assert // asset exists
    // smart_contracts/contracts/router.algo.ts:117
    // this.bridgingFeeConversionScalingFactor(asset).value = 10 ** (ORACLE_PRICE_PRECISION - tokenDecimals + CHAIN_PRECISION);
    pushint 9 // 9
    swap
    -
    dup
    pushint 6 // 6
    +
    pushint 10 // 10
    swap
    exp
    // smart_contracts/contracts/router.algo.ts:39
    // protected bridgingFeeConversionScalingFactor = BoxMap<Asset, uint64>({ keyPrefix: 'f' });
    pushbytes "f"
    dig 3
    concat
    // smart_contracts/contracts/router.algo.ts:117
    // this.bridgingFeeConversionScalingFactor(asset).value = 10 ** (ORACLE_PRICE_PRECISION - tokenDecimals + CHAIN_PRECISION);
    swap
    itob
    box_put
    // smart_contracts/contracts/router.algo.ts:118
    // this.fromGasOracleScalingFactor(asset).value = 10 ** (ORACLE_PRICE_PRECISION - tokenDecimals);
    pushint 10 // 10
    swap
    exp
    // smart_contracts/contracts/router.algo.ts:36
    // protected fromGasOracleScalingFactor = BoxMap<Asset, uint64>({ keyPrefix: 'e' });
    pushbytes "e"
    uncover 2
    concat
    // smart_contracts/contracts/router.algo.ts:118
    // this.fromGasOracleScalingFactor(asset).value = 10 ** (ORACLE_PRICE_PRECISION - tokenDecimals);
    swap
    itob
    box_put
    // smart_contracts/contracts/router.algo.ts:112
    // @abimethod()
    intc_0 // 1
    return


// smart_contracts/contracts/router.algo.ts::Router.removePool[routing]() -> void:
removePool:
    // smart_contracts/contracts/router.algo.ts:121
    // @abimethod()
    txna ApplicationArgs 1
    dup
    len
    intc_2 // 8
    ==
    assert // invalid number of bytes for arc4.uint64
    btoi
    // smart_contracts/contracts/router.algo.ts:123
    // this.onlyOwner();
    callsub onlyOwner
    // smart_contracts/contracts/router.algo.ts:124
    // this.pools(tokenId).delete();
    itob
    // smart_contracts/contracts/router.algo.ts:34
    // pools = BoxMap<Asset, uint64>({ keyPrefix: 'p' });
    bytec 8 // "p"
    swap
    concat
    // smart_contracts/contracts/router.algo.ts:124
    // this.pools(tokenId).delete();
    box_del
    pop
    // smart_contracts/contracts/router.algo.ts:121
    // @abimethod()
    intc_0 // 1
    return


// smart_contracts/contracts/router.algo.ts::Router.stopSwap[routing]() -> void:
stopSwap:
    // smart_contracts/contracts/router.algo.ts:71
    // assert(op.Txn.sender.bytes === this.stopAuthority.value.bytes, 'Router: is not stopAuthority');
    txn Sender
    intc_1 // 0
    // smart_contracts/contracts/router.algo.ts:42
    // private stopAuthority = GlobalState<Address>();// can restrict deposit or withdraw operations
    bytec 9 // "stopAuthority"
    // smart_contracts/contracts/router.algo.ts:71
    // assert(op.Txn.sender.bytes === this.stopAuthority.value.bytes, 'Router: is not stopAuthority');
    app_global_get_ex
    assert // check GlobalState exists
    ==
    assert // Router: is not stopAuthority
    // smart_contracts/contracts/router.algo.ts:53
    // canSwap = GlobalState<boolean>({ initialValue: true });
    bytec_1 // "canSwap"
    // smart_contracts/contracts/router.algo.ts:133
    // this.canSwap.value = false;
    intc_1 // 0
    app_global_put
    // smart_contracts/contracts/router.algo.ts:130
    // @abimethod()
    intc_0 // 1
    return


// smart_contracts/contracts/router.algo.ts::Router.startSwap[routing]() -> void:
startSwap:
    // smart_contracts/contracts/router.algo.ts:141
    // this.onlyOwner();
    callsub onlyOwner
    // smart_contracts/contracts/router.algo.ts:53
    // canSwap = GlobalState<boolean>({ initialValue: true });
    bytec_1 // "canSwap"
    // smart_contracts/contracts/router.algo.ts:142
    // this.canSwap.value = true;
    intc_0 // 1
    app_global_put
    // smart_contracts/contracts/router.algo.ts:139
    // @abimethod()
    intc_0 // 1
    return


// smart_contracts/contracts/router.algo.ts::Router.setStopAuthority[routing]() -> void:
setStopAuthority:
    // smart_contracts/contracts/router.algo.ts:148
    // @abimethod()
    txna ApplicationArgs 1
    dup
    len
    intc_3 // 32
    ==
    assert // invalid number of bytes for arc4.static_array<arc4.uint8, 32>
    // smart_contracts/contracts/router.algo.ts:150
    // this.onlyOwner();
    callsub onlyOwner
    // smart_contracts/contracts/router.algo.ts:42
    // private stopAuthority = GlobalState<Address>();// can restrict deposit or withdraw operations
    bytec 9 // "stopAuthority"
    // smart_contracts/contracts/router.algo.ts:151
    // this.stopAuthority.value = stopAuthority;
    swap
    app_global_put
    // smart_contracts/contracts/router.algo.ts:148
    // @abimethod()
    intc_0 // 1
    return


// smart_contracts/contracts/router.algo.ts::Router.setRebalancer[routing]() -> void:
setRebalancer:
    // smart_contracts/contracts/router.algo.ts:157
    // @abimethod()
    txna ApplicationArgs 1
    dup
    len
    intc_3 // 32
    ==
    assert // invalid number of bytes for arc4.static_array<arc4.uint8, 32>
    // smart_contracts/contracts/router.algo.ts:159
    // this.onlyOwner();
    callsub onlyOwner
    // smart_contracts/contracts/router.algo.ts:52
    // private rebalancer = GlobalState<Address>({ initialValue: new Address(bzero(0)) });// can restrict deposit or withdraw operations
    bytec 4 // "rebalancer"
    // smart_contracts/contracts/router.algo.ts:160
    // this.rebalancer.value = rebalancer;
    swap
    app_global_put
    // smart_contracts/contracts/router.algo.ts:157
    // @abimethod()
    intc_0 // 1
    return


// smart_contracts/contracts/gas-usage.algo.ts::GasUsage.getGasUsage[routing]() -> void:
getGasUsage:
    // smart_contracts/contracts/gas-usage.algo.ts:17
    // @abimethod({ readonly: true })
    txna ApplicationArgs 1
    dup
    len
    intc_0 // 1
    ==
    assert // invalid number of bytes for arc4.uint8
    callsub smart_contracts/contracts/gas-usage.algo.ts::GasUsage.getGasUsage
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// smart_contracts/contracts/gas-usage.algo.ts::GasUsage.setGasUsage[routing]() -> void:
setGasUsage:
    // smart_contracts/contracts/gas-usage.algo.ts:22
    // @abimethod()
    txna ApplicationArgs 1
    dup
    len
    intc_0 // 1
    ==
    assert // invalid number of bytes for arc4.uint8
    txna ApplicationArgs 2
    dup
    len
    intc_2 // 8
    ==
    assert // invalid number of bytes for arc4.uint64
    btoi
    // smart_contracts/contracts/gas-usage.algo.ts:24
    // this.onlyOwner();
    callsub onlyOwner
    // smart_contracts/contracts/gas-usage.algo.ts:10
    // gasUsage = BoxMap<Byte, uint64>({ keyPrefix: 'u' });
    bytec 12 // "u"
    uncover 2
    concat
    // smart_contracts/contracts/gas-usage.algo.ts:25
    // this.gasUsage(chainId).value = gasAmount;
    swap
    itob
    box_put
    // smart_contracts/contracts/gas-usage.algo.ts:22
    // @abimethod()
    intc_0 // 1
    return


// smart_contracts/contracts/gas-usage.algo.ts::GasUsage.setGasOracle[routing]() -> void:
setGasOracle:
    // smart_contracts/contracts/gas-usage.algo.ts:28
    // @abimethod()
    txna ApplicationArgs 1
    dup
    len
    intc_2 // 8
    ==
    assert // invalid number of bytes for arc4.uint64
    btoi
    // smart_contracts/contracts/gas-usage.algo.ts:30
    // this.onlyOwner();
    callsub onlyOwner
    // smart_contracts/contracts/gas-usage.algo.ts:9
    // gasOracle = GlobalState<Application>();
    bytec_3 // "gasOracle"
    // smart_contracts/contracts/gas-usage.algo.ts:31
    // this.gasOracle.value = gasOracle;
    swap
    app_global_put
    // smart_contracts/contracts/gas-usage.algo.ts:28
    // @abimethod()
    intc_0 // 1
    return


// smart_contracts/contracts/gas-usage.algo.ts::GasUsage.getTransactionRelayerCost[routing]() -> void:
getTransactionRelayerCost:
    // smart_contracts/contracts/gas-usage.algo.ts:34
    // @abimethod({ readonly: true })
    txna ApplicationArgs 1
    dup
    len
    intc_0 // 1
    ==
    assert // invalid number of bytes for arc4.uint8
    callsub smart_contracts/contracts/gas-usage.algo.ts::GasUsage.getTransactionRelayerCost
    itob
    bytec_0 // 0x151f7c75
    swap
    concat
    log
    intc_0 // 1
    return


// smart_contracts/contracts/ownable.algo.ts::Ownable.transferOwnership[routing]() -> void:
transferOwnership:
    // smart_contracts/contracts/ownable.algo.ts:16
    // @abimethod()
    txna ApplicationArgs 1
    dup
    len
    intc_3 // 32
    ==
    assert // invalid number of bytes for arc4.static_array<arc4.uint8, 32>
    // smart_contracts/contracts/ownable.algo.ts:18
    // this.onlyOwner();
    callsub onlyOwner
    // smart_contracts/contracts/ownable.algo.ts:6
    // protected owner = GlobalState<Address>();
    bytec_2 // "owner"
    // smart_contracts/contracts/ownable.algo.ts:19
    // this.owner.value = newOwner;
    swap
    app_global_put
    // smart_contracts/contracts/ownable.algo.ts:16
    // @abimethod()
    intc_0 // 1
    return


// smart_contracts/contracts/bridge.contract.algo.ts::Bridge._swapAndBridge(feeFromNative: uint64, assetTransferRef: uint64, recipient: bytes, destinationChainId: bytes, receiveToken: bytes, nonce: bytes, feeTokenAmount: uint64, budget: uint64) -> void:
_swapAndBridge:
    // smart_contracts/contracts/bridge.contract.algo.ts:116-125
    // private _swapAndBridge(
    //   feeFromNative: uint64,
    //   assetTransferRef: gtxn.AssetTransferTxn,
    //   recipient: StaticBytes<32>,
    //   destinationChainId: Byte,
    //   receiveToken: StaticBytes<32>,
    //   nonce: StaticBytes<32>,
    //   feeTokenAmount: uint64,
    //   budget: uint64,
    // ): void {
    proto 8 0
    // smart_contracts/contracts/bridge.contract.algo.ts:126
    // ensureBudget(budget, OpUpFeeSource.GroupCredit);
    frame_dig -1
    intc_1 // 0
    callsub ensure_budget
    // smart_contracts/contracts/router.algo.ts:64
    // assert(this.canSwap.value, 'Router: swap prohibited');
    intc_1 // 0
    // smart_contracts/contracts/router.algo.ts:53
    // canSwap = GlobalState<boolean>({ initialValue: true });
    bytec_1 // "canSwap"
    // smart_contracts/contracts/router.algo.ts:64
    // assert(this.canSwap.value, 'Router: swap prohibited');
    app_global_get_ex
    assert // check GlobalState exists
    assert // Router: swap prohibited
    // smart_contracts/contracts/bridge.contract.algo.ts:128
    // const amount = amountFromAssetTransfer(assetTransferRef);
    frame_dig -7
    callsub amountFromAssetTransfer
    dup
    // smart_contracts/contracts/bridge.contract.algo.ts:129
    // assert(amount > feeTokenAmount, 'Bridge: amount too low for fee');
    frame_dig -2
    >
    assert // Bridge: amount too low for fee
    // smart_contracts/contracts/bridge.contract.algo.ts:130
    // assert(!recipient.bytes.equals(bzero(32)), 'Bridge: bridge to the zero address');
    intc_3 // 32
    bzero
    frame_dig -6
    ==
    !
    assert // Bridge: bridge to the zero address
    // smart_contracts/contracts/bridge.contract.algo.ts:132
    // const feeFromStable: uint64 = this._convertBridgingFeeInTokensToNativeToken(assetTransferRef.xferAsset, feeTokenAmount);
    frame_dig -7
    gtxns XferAsset
    // smart_contracts/contracts/bridge.contract.algo.ts:365
    // if (feeTokenAmount === 0) return 0;
    frame_dig -2
    bnz _swapAndBridge_after_if_else@3
    intc_1 // 0

_swapAndBridge_after_inlined_smart_contracts/contracts/bridge.contract.algo.ts::Bridge._convertBridgingFeeInTokensToNativeToken@5:
    // smart_contracts/contracts/bridge.contract.algo.ts:133
    // const bridgingFee: uint64 = feeFromNative + feeFromStable;
    frame_dig -8
    dig 1
    +
    // smart_contracts/contracts/bridge.contract.algo.ts:134
    // emit<BridgingFeeFromTokens>({ feeFromNative, feeFromStable, feeStableTokenAmount: feeTokenAmount });
    frame_dig -8
    itob
    uncover 2
    itob
    concat
    frame_dig -2
    itob
    concat
    pushbytes 0x36bafadd // method "BridgingFeeFromTokens(uint64,uint64,uint64)"
    swap
    concat
    log
    // smart_contracts/contracts/bridge.contract.algo.ts:136
    // const amountAfterFee: uint64 = amount - feeTokenAmount;
    frame_dig 0
    frame_dig -2
    -
    // smart_contracts/contracts/bridge.contract.algo.ts:138
    // const vUsdAmount = this.sendAndSwapToVUsd(assetTransferRef.xferAsset, sender, amountAfterFee);
    frame_dig 1
    // smart_contracts/contracts/bridge.contract.algo.ts:137
    // const sender = new Address(Txn.sender);
    txn Sender
    // smart_contracts/contracts/bridge.contract.algo.ts:138
    // const vUsdAmount = this.sendAndSwapToVUsd(assetTransferRef.xferAsset, sender, amountAfterFee);
    uncover 2
    callsub sendAndSwapToVUsd
    // smart_contracts/contracts/bridge.contract.algo.ts:150
    // assert(destinationChainId !== this.chainId.value, 'Bridge: wrong destination chain');
    intc_1 // 0
    // smart_contracts/contracts/bridge.contract.algo.ts:57
    // chainId = GlobalState<Byte>();
    bytec 5 // "chainId"
    // smart_contracts/contracts/bridge.contract.algo.ts:150
    // assert(destinationChainId !== this.chainId.value, 'Bridge: wrong destination chain');
    app_global_get_ex
    assert // check GlobalState exists
    frame_dig -5
    dig 1
    !=
    assert // Bridge: wrong destination chain
    // smart_contracts/contracts/bridge.contract.algo.ts:361
    // return chainId.bytes.concat(token.bytes);
    frame_dig -5
    frame_dig -4
    concat
    // smart_contracts/contracts/bridge.contract.algo.ts:67
    // otherBridgeTokens = BoxMap<bytes, StaticBytes>({ keyPrefix: 't' });
    bytec 7 // "t"
    swap
    concat
    // smart_contracts/contracts/bridge.contract.algo.ts:151
    // assert(this.otherBridgeTokens(this._getOtherBridgeTokensKey(destinationChainId, receiveToken)).exists, 'Bridge: unknown chain or token');
    box_len
    bury 1
    assert // Bridge: unknown chain or token
    // smart_contracts/contracts/bridge.contract.algo.ts:153
    // const message = this.hashMessage(amount, recipient, this.chainId.value, destinationChainId, receiveToken, nonce);
    dig 1
    frame_dig -6
    uncover 2
    frame_dig -5
    frame_dig -4
    frame_dig -3
    callsub smart_contracts/contracts/bridge.contract.algo.ts::Bridge.hashMessage
    // smart_contracts/contracts/bridge.contract.algo.ts:341
    // return this.getTransactionRelayerCost(chainId) + this.getSendTransactionStorageCost();
    frame_dig -5
    callsub smart_contracts/contracts/gas-usage.algo.ts::GasUsage.getTransactionRelayerCost
    // smart_contracts/contracts/bridge.contract.algo.ts:355
    // return 15700;
    intc 4 // 15700
    // smart_contracts/contracts/bridge.contract.algo.ts:341
    // return this.getTransactionRelayerCost(chainId) + this.getSendTransactionStorageCost();
    +
    // smart_contracts/contracts/bridge.contract.algo.ts:62
    // sentMessages = BoxMap<StaticBytes<32>, StaticBytes>({ keyPrefix: 's' });
    pushbytes "s"
    dig 2
    concat
    // smart_contracts/contracts/bridge.contract.algo.ts:172
    // assert(!this.sentMessages(message).exists, 'Bridge: tokens already sent');
    dup
    box_len
    bury 1
    !
    assert // Bridge: tokens already sent
    // smart_contracts/contracts/bridge.contract.algo.ts:174
    // this.sentMessages(message).value = new StaticBytes();
    pushbytes 0x
    box_put
    // smart_contracts/contracts/bridge.contract.algo.ts:176
    // const destinationChainId = message.at(1);
    dig 1
    extract 1 1 // on error: index access is out of bounds
    // smart_contracts/contracts/bridge.contract.algo.ts:177-181
    // const messageCost = abiCall({
    //   method: Messenger.prototype.getTransactionCost,
    //   appId: this.messenger.value.id,
    //   args: [destinationChainId],
    // }).returnValue;
    itxn_begin
    // smart_contracts/contracts/bridge.contract.algo.ts:179
    // appId: this.messenger.value.id,
    intc_1 // 0
    // smart_contracts/contracts/bridge.contract.algo.ts:58
    // messenger = GlobalState<Application>();
    bytec 6 // "messenger"
    // smart_contracts/contracts/bridge.contract.algo.ts:179
    // appId: this.messenger.value.id,
    app_global_get_ex
    assert // check GlobalState exists
    // smart_contracts/contracts/bridge.contract.algo.ts:177-181
    // const messageCost = abiCall({
    //   method: Messenger.prototype.getTransactionCost,
    //   appId: this.messenger.value.id,
    //   args: [destinationChainId],
    // }).returnValue;
    bytec 13 // method "getTransactionCost(byte)uint64"
    itxn_field ApplicationArgs
    swap
    itxn_field ApplicationArgs
    dup
    itxn_field ApplicationID
    pushint 6 // appl
    itxn_field TypeEnum
    intc_1 // 0
    itxn_field Fee
    itxn_submit
    itxn LastLog
    dup
    extract 4 0
    swap
    extract 0 4
    bytec_0 // 0x151f7c75
    ==
    assert // Bytes has valid prefix
    dup
    len
    intc_2 // 8
    ==
    assert // invalid number of bytes for arc4.uint64
    btoi
    // smart_contracts/contracts/bridge.contract.algo.ts:185
    // receiver: this.messenger.value.address,
    dig 1
    app_params_get AppAddress
    assert // application exists
    // smart_contracts/contracts/bridge.contract.algo.ts:187-189
    // abiCall({
    //   method: Messenger.prototype.sendMessage, appId: this.messenger.value.id, args: [paymentParams, message],
    // });
    itxn_begin
    itxn_field Receiver
    dup
    itxn_field Amount
    // smart_contracts/contracts/bridge.contract.algo.ts:183-186
    // const paymentParams = itxn.payment({
    //   amount: messageCost,
    //   receiver: this.messenger.value.address,
    // });
    intc_0 // 1
    itxn_field TypeEnum
    intc_1 // 0
    itxn_field Fee
    // smart_contracts/contracts/bridge.contract.algo.ts:187-189
    // abiCall({
    //   method: Messenger.prototype.sendMessage, appId: this.messenger.value.id, args: [paymentParams, message],
    // });
    itxn_next
    pushbytes 0xd02f57f5 // method "sendMessage(pay,byte[32])void"
    itxn_field ApplicationArgs
    uncover 3
    itxn_field ApplicationArgs
    swap
    itxn_field ApplicationID
    pushint 6 // appl
    itxn_field TypeEnum
    intc_1 // 0
    itxn_field Fee
    itxn_submit
    // smart_contracts/contracts/bridge.contract.algo.ts:156
    // emit<ReceiveFee>({ bridgeTransactionCost, messageTransactionCost });
    dig 1
    itob
    dig 1
    itob
    concat
    pushbytes 0x4b55419b // method "ReceiveFee(uint64,uint64)"
    swap
    concat
    log
    // smart_contracts/contracts/bridge.contract.algo.ts:157
    // assert(bridgingFee >= bridgeTransactionCost + messageTransactionCost, 'Bridge: not enough fee');
    +
    uncover 2
    <=
    assert // Bridge: not enough fee
    // smart_contracts/contracts/bridge.contract.algo.ts:158-165
    // emit<TokensSent>({
    //     amount,
    //     recipient,
    //     destinationChainId,
    //     receiveToken,
    //     nonce,
    //     messenger: ALLBRIDGE_MESSENGER,
    //   },
    itob
    frame_dig -6
    concat
    frame_dig -5
    concat
    frame_dig -4
    concat
    frame_dig -3
    concat
    // smart_contracts/contracts/bridge.contract.algo.ts:164
    // messenger: ALLBRIDGE_MESSENGER,
    bytec 10 // 0x01
    // smart_contracts/contracts/bridge.contract.algo.ts:158-165
    // emit<TokensSent>({
    //     amount,
    //     recipient,
    //     destinationChainId,
    //     receiveToken,
    //     nonce,
    //     messenger: ALLBRIDGE_MESSENGER,
    //   },
    concat
    // smart_contracts/contracts/bridge.contract.algo.ts:158-166
    // emit<TokensSent>({
    //     amount,
    //     recipient,
    //     destinationChainId,
    //     receiveToken,
    //     nonce,
    //     messenger: ALLBRIDGE_MESSENGER,
    //   },
    // );
    pushbytes 0x229fbaec // method "TokensSent(uint64,byte[32],byte,byte[32],byte[32],byte)"
    swap
    concat
    log
    retsub

_swapAndBridge_after_if_else@3:
    // smart_contracts/contracts/bridge.contract.algo.ts:367
    // const fee: uint64 = this.bridgingFeeConversionScalingFactor(asset).value * feeTokenAmount / abiCall({
    frame_dig 1
    itob
    // smart_contracts/contracts/router.algo.ts:39
    // protected bridgingFeeConversionScalingFactor = BoxMap<Asset, uint64>({ keyPrefix: 'f' });
    pushbytes "f"
    swap
    concat
    // smart_contracts/contracts/bridge.contract.algo.ts:367
    // const fee: uint64 = this.bridgingFeeConversionScalingFactor(asset).value * feeTokenAmount / abiCall({
    box_get
    assert // Box must have value
    btoi
    frame_dig -2
    *
    // smart_contracts/contracts/bridge.contract.algo.ts:367-371
    // const fee: uint64 = this.bridgingFeeConversionScalingFactor(asset).value * feeTokenAmount / abiCall({
    //   method: GasOracle.prototype.getPrice,
    //   appId: this.gasOracle.value.id,
    //   args: [this.chainId.value],
    // }).returnValue;
    itxn_begin
    // smart_contracts/contracts/bridge.contract.algo.ts:369
    // appId: this.gasOracle.value.id,
    intc_1 // 0
    // smart_contracts/contracts/gas-usage.algo.ts:9
    // gasOracle = GlobalState<Application>();
    bytec_3 // "gasOracle"
    // smart_contracts/contracts/bridge.contract.algo.ts:369
    // appId: this.gasOracle.value.id,
    app_global_get_ex
    assert // check GlobalState exists
    // smart_contracts/contracts/bridge.contract.algo.ts:370
    // args: [this.chainId.value],
    intc_1 // 0
    // smart_contracts/contracts/bridge.contract.algo.ts:57
    // chainId = GlobalState<Byte>();
    bytec 5 // "chainId"
    // smart_contracts/contracts/bridge.contract.algo.ts:370
    // args: [this.chainId.value],
    app_global_get_ex
    assert // check GlobalState exists
    // smart_contracts/contracts/bridge.contract.algo.ts:367-371
    // const fee: uint64 = this.bridgingFeeConversionScalingFactor(asset).value * feeTokenAmount / abiCall({
    //   method: GasOracle.prototype.getPrice,
    //   appId: this.gasOracle.value.id,
    //   args: [this.chainId.value],
    // }).returnValue;
    pushbytes 0x1db70cdd // method "getPrice(byte)uint64"
    itxn_field ApplicationArgs
    itxn_field ApplicationArgs
    itxn_field ApplicationID
    pushint 6 // appl
    itxn_field TypeEnum
    intc_1 // 0
    itxn_field Fee
    itxn_submit
    itxn LastLog
    dup
    extract 4 0
    swap
    extract 0 4
    bytec_0 // 0x151f7c75
    ==
    assert // Bytes has valid prefix
    dup
    len
    intc_2 // 8
    ==
    assert // invalid number of bytes for arc4.uint64
    btoi
    /
    // smart_contracts/contracts/bridge.contract.algo.ts:132
    // const feeFromStable: uint64 = this._convertBridgingFeeInTokensToNativeToken(assetTransferRef.xferAsset, feeTokenAmount);
    b _swapAndBridge_after_inlined_smart_contracts/contracts/bridge.contract.algo.ts::Bridge._convertBridgingFeeInTokensToNativeToken@5


// smart_contracts/contracts/bridge.contract.algo.ts::Bridge.hashMessage(amount: uint64, recipient: bytes, sourceChainId: bytes, destinationChainId: bytes, receiveToken: bytes, nonce: bytes) -> bytes:
smart_contracts/contracts/bridge.contract.algo.ts::Bridge.hashMessage:
    // smart_contracts/contracts/bridge.contract.algo.ts:307-315
    // @abimethod({ readonly: true })
    // hashMessage(
    //   amount: uint64,
    //   recipient: StaticBytes<32>,
    //   sourceChainId: Byte,
    //   destinationChainId: Byte,
    //   receiveToken: StaticBytes<32>,
    //   nonce: StaticBytes<32>,
    // ): StaticBytes<32> {
    proto 6 1
    // smart_contracts/contracts/bridge.contract.algo.ts:316
    // const amount32 = bzero(24).concat(op.itob(amount));
    pushint 24 // 24
    bzero
    frame_dig -6
    itob
    concat
    // smart_contracts/contracts/bridge.contract.algo.ts:317
    // const sourceChainId32 = bzero(31).concat(sourceChainId.bytes);
    pushint 31 // 31
    bzero
    frame_dig -4
    concat
    // smart_contracts/contracts/bridge.contract.algo.ts:318-319
    // const packed = amount32
    //   .concat(recipient.bytes)
    swap
    frame_dig -5
    concat
    // smart_contracts/contracts/bridge.contract.algo.ts:318-320
    // const packed = amount32
    //   .concat(recipient.bytes)
    //   .concat(sourceChainId32)
    swap
    concat
    // smart_contracts/contracts/bridge.contract.algo.ts:318-321
    // const packed = amount32
    //   .concat(recipient.bytes)
    //   .concat(sourceChainId32)
    //   .concat(receiveToken.bytes)
    frame_dig -2
    concat
    // smart_contracts/contracts/bridge.contract.algo.ts:318-322
    // const packed = amount32
    //   .concat(recipient.bytes)
    //   .concat(sourceChainId32)
    //   .concat(receiveToken.bytes)
    //   .concat(nonce.bytes)
    frame_dig -1
    concat
    // smart_contracts/contracts/bridge.contract.algo.ts:323
    // .concat(ALLBRIDGE_MESSENGER.bytes);
    bytec 10 // 0x01
    // smart_contracts/contracts/bridge.contract.algo.ts:318-323
    // const packed = amount32
    //   .concat(recipient.bytes)
    //   .concat(sourceChainId32)
    //   .concat(receiveToken.bytes)
    //   .concat(nonce.bytes)
    //   .concat(ALLBRIDGE_MESSENGER.bytes);
    concat
    // smart_contracts/contracts/bridge.contract.algo.ts:325
    // const hash = op.keccak256(packed); // 32 bytes
    keccak256
    // smart_contracts/contracts/bridge.contract.algo.ts:328
    // const withSrc = op.setByte(hash, 0, op.btoi(sourceChainId.bytes));
    frame_dig -4
    btoi
    intc_1 // 0
    swap
    setbyte
    // smart_contracts/contracts/bridge.contract.algo.ts:329
    // const withDst = op.setByte(withSrc, 1, op.btoi(destinationChainId.bytes));
    frame_dig -3
    btoi
    intc_0 // 1
    swap
    setbyte
    // smart_contracts/contracts/bridge.contract.algo.ts:331
    // return new StaticBytes<32>(withDst);
    dup
    len
    intc_3 // 32
    ==
    assert // invalid size
    retsub


// smart_contracts/contracts/router.algo.ts::Router.receiveAndSwapFromVUsd(asset: uint64, recipient: bytes, vUsdAmount: uint64, receiveAmountMin: uint64) -> uint64:
receiveAndSwapFromVUsd:
    // smart_contracts/contracts/router.algo.ts:163-168
    // protected receiveAndSwapFromVUsd(
    //   asset: Asset,
    //   recipient: Address,
    //   vUsdAmount: uint64,
    //   receiveAmountMin: uint64,
    // ): uint64 {
    proto 4 1
    // smart_contracts/contracts/router.algo.ts:169
    // assert(this.pools(asset).exists, 'Router: no receive pool');
    frame_dig -4
    itob
    // smart_contracts/contracts/router.algo.ts:34
    // pools = BoxMap<Asset, uint64>({ keyPrefix: 'p' });
    bytec 8 // "p"
    swap
    concat
    // smart_contracts/contracts/router.algo.ts:169
    // assert(this.pools(asset).exists, 'Router: no receive pool');
    dup
    box_len
    bury 1
    assert // Router: no receive pool
    // smart_contracts/contracts/router.algo.ts:170
    // const poolId = this.pools(asset).value;
    box_get
    pop
    btoi
    // smart_contracts/contracts/router.algo.ts:171-175
    // return abiCall({
    //   method: Pool.prototype.swapFromVUsd,
    //   appId: poolId,
    //   args: [recipient, vUsdAmount, receiveAmountMin, recipient === this.rebalancer.value],
    // }).returnValue;
    itxn_begin
    // smart_contracts/contracts/router.algo.ts:174
    // args: [recipient, vUsdAmount, receiveAmountMin, recipient === this.rebalancer.value],
    frame_dig -2
    itob
    frame_dig -1
    itob
    intc_1 // 0
    // smart_contracts/contracts/router.algo.ts:52
    // private rebalancer = GlobalState<Address>({ initialValue: new Address(bzero(0)) });// can restrict deposit or withdraw operations
    bytec 4 // "rebalancer"
    // smart_contracts/contracts/router.algo.ts:174
    // args: [recipient, vUsdAmount, receiveAmountMin, recipient === this.rebalancer.value],
    app_global_get_ex
    assert // check GlobalState exists
    frame_dig -3
    ==
    bytec 11 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    // smart_contracts/contracts/router.algo.ts:171-175
    // return abiCall({
    //   method: Pool.prototype.swapFromVUsd,
    //   appId: poolId,
    //   args: [recipient, vUsdAmount, receiveAmountMin, recipient === this.rebalancer.value],
    // }).returnValue;
    pushbytes 0x0d1b4c06 // method "swapFromVUsd(address,uint64,uint64,bool)uint64"
    itxn_field ApplicationArgs
    frame_dig -3
    itxn_field ApplicationArgs
    uncover 2
    itxn_field ApplicationArgs
    swap
    itxn_field ApplicationArgs
    itxn_field ApplicationArgs
    itxn_field ApplicationID
    pushint 6 // appl
    itxn_field TypeEnum
    intc_1 // 0
    itxn_field Fee
    itxn_submit
    itxn LastLog
    dup
    extract 4 0
    swap
    extract 0 4
    bytec_0 // 0x151f7c75
    ==
    assert // Bytes has valid prefix
    dup
    len
    intc_2 // 8
    ==
    assert // invalid number of bytes for arc4.uint64
    btoi
    retsub


// smart_contracts/contracts/router.algo.ts::Router.sendAndSwapToVUsd(asset: uint64, user: bytes, amount: uint64) -> uint64:
sendAndSwapToVUsd:
    // smart_contracts/contracts/router.algo.ts:179
    // protected sendAndSwapToVUsd(asset: Asset, user: Address, amount: uint64): uint64 {
    proto 3 1
    // smart_contracts/contracts/router.algo.ts:180
    // assert(this.pools(asset).exists, 'Router: no pool');
    frame_dig -3
    itob
    // smart_contracts/contracts/router.algo.ts:34
    // pools = BoxMap<Asset, uint64>({ keyPrefix: 'p' });
    bytec 8 // "p"
    swap
    concat
    // smart_contracts/contracts/router.algo.ts:180
    // assert(this.pools(asset).exists, 'Router: no pool');
    dup
    box_len
    bury 1
    assert // Router: no pool
    // smart_contracts/contracts/router.algo.ts:181
    // const poolId = this.pools(asset).value;
    box_get
    pop
    btoi
    // smart_contracts/contracts/router.algo.ts:183-188
    // itxn.assetTransfer({
    //   xferAsset: asset,
    //   assetAmount: amount,
    //   assetReceiver: Application(poolId).address,
    // })
    //   .submit();
    itxn_begin
    // smart_contracts/contracts/router.algo.ts:186
    // assetReceiver: Application(poolId).address,
    dup
    app_params_get AppAddress
    assert // application exists
    itxn_field AssetReceiver
    frame_dig -1
    itxn_field AssetAmount
    frame_dig -3
    itxn_field XferAsset
    // smart_contracts/contracts/router.algo.ts:183-187
    // itxn.assetTransfer({
    //   xferAsset: asset,
    //   assetAmount: amount,
    //   assetReceiver: Application(poolId).address,
    // })
    pushint 4 // 4
    itxn_field TypeEnum
    intc_1 // 0
    itxn_field Fee
    // smart_contracts/contracts/router.algo.ts:183-188
    // itxn.assetTransfer({
    //   xferAsset: asset,
    //   assetAmount: amount,
    //   assetReceiver: Application(poolId).address,
    // })
    //   .submit();
    itxn_submit
    // smart_contracts/contracts/router.algo.ts:190-194
    // return abiCall({
    //   method: Pool.prototype.swapToVUsd,
    //   appId: poolId,
    //   args: [user, amount, user === this.rebalancer.value],
    // }).returnValue;
    itxn_begin
    // smart_contracts/contracts/router.algo.ts:193
    // args: [user, amount, user === this.rebalancer.value],
    frame_dig -1
    itob
    intc_1 // 0
    // smart_contracts/contracts/router.algo.ts:52
    // private rebalancer = GlobalState<Address>({ initialValue: new Address(bzero(0)) });// can restrict deposit or withdraw operations
    bytec 4 // "rebalancer"
    // smart_contracts/contracts/router.algo.ts:193
    // args: [user, amount, user === this.rebalancer.value],
    app_global_get_ex
    assert // check GlobalState exists
    frame_dig -2
    ==
    bytec 11 // 0x00
    intc_1 // 0
    uncover 2
    setbit
    // smart_contracts/contracts/router.algo.ts:190-194
    // return abiCall({
    //   method: Pool.prototype.swapToVUsd,
    //   appId: poolId,
    //   args: [user, amount, user === this.rebalancer.value],
    // }).returnValue;
    pushbytes 0xd978ad14 // method "swapToVUsd(address,uint64,bool)uint64"
    itxn_field ApplicationArgs
    frame_dig -2
    itxn_field ApplicationArgs
    swap
    itxn_field ApplicationArgs
    itxn_field ApplicationArgs
    itxn_field ApplicationID
    pushint 6 // appl
    itxn_field TypeEnum
    intc_1 // 0
    itxn_field Fee
    itxn_submit
    itxn LastLog
    dup
    extract 4 0
    swap
    extract 0 4
    bytec_0 // 0x151f7c75
    ==
    assert // Bytes has valid prefix
    dup
    len
    intc_2 // 8
    ==
    assert // invalid number of bytes for arc4.uint64
    btoi
    retsub


// smart_contracts/contracts/gas-usage.algo.ts::GasUsage.getGasUsage(chainId: bytes) -> uint64:
smart_contracts/contracts/gas-usage.algo.ts::GasUsage.getGasUsage:
    // smart_contracts/contracts/gas-usage.algo.ts:17-18
    // @abimethod({ readonly: true })
    // getGasUsage(chainId: Byte): uint64 {
    proto 1 1
    // smart_contracts/contracts/gas-usage.algo.ts:10
    // gasUsage = BoxMap<Byte, uint64>({ keyPrefix: 'u' });
    bytec 12 // "u"
    frame_dig -1
    concat
    // smart_contracts/contracts/gas-usage.algo.ts:19
    // return this.gasUsage(chainId).value;
    box_get
    assert // Box must have value
    btoi
    retsub


// smart_contracts/contracts/gas-usage.algo.ts::GasUsage.getTransactionRelayerCost(chainId: bytes) -> uint64:
smart_contracts/contracts/gas-usage.algo.ts::GasUsage.getTransactionRelayerCost:
    // smart_contracts/contracts/gas-usage.algo.ts:34-35
    // @abimethod({ readonly: true })
    // getTransactionRelayerCost(chainId: Byte): uint64 {
    proto 1 1
    // smart_contracts/contracts/gas-usage.algo.ts:10
    // gasUsage = BoxMap<Byte, uint64>({ keyPrefix: 'u' });
    bytec 12 // "u"
    frame_dig -1
    concat
    // smart_contracts/contracts/gas-usage.algo.ts:36
    // const gasAmount = this.gasUsage(chainId).value;
    box_get
    assert // Box must have value
    btoi
    // smart_contracts/contracts/gas-usage.algo.ts:37-41
    // return abiCall({
    //   method: GasOracle.prototype.getTransactionGasCostInNativeToken,
    //   appId: this.gasOracle.value.id,
    //   args: [chainId, gasAmount],
    // }).returnValue;
    itxn_begin
    // smart_contracts/contracts/gas-usage.algo.ts:39
    // appId: this.gasOracle.value.id,
    intc_1 // 0
    // smart_contracts/contracts/gas-usage.algo.ts:9
    // gasOracle = GlobalState<Application>();
    bytec_3 // "gasOracle"
    // smart_contracts/contracts/gas-usage.algo.ts:39
    // appId: this.gasOracle.value.id,
    app_global_get_ex
    assert // check GlobalState exists
    // smart_contracts/contracts/gas-usage.algo.ts:40
    // args: [chainId, gasAmount],
    swap
    itob
    // smart_contracts/contracts/gas-usage.algo.ts:37-41
    // return abiCall({
    //   method: GasOracle.prototype.getTransactionGasCostInNativeToken,
    //   appId: this.gasOracle.value.id,
    //   args: [chainId, gasAmount],
    // }).returnValue;
    pushbytes 0xc2afccd1 // method "getTransactionGasCostInNativeToken(byte,uint64)uint64"
    itxn_field ApplicationArgs
    frame_dig -1
    itxn_field ApplicationArgs
    itxn_field ApplicationArgs
    itxn_field ApplicationID
    pushint 6 // appl
    itxn_field TypeEnum
    intc_1 // 0
    itxn_field Fee
    itxn_submit
    itxn LastLog
    dup
    extract 4 0
    swap
    extract 0 4
    bytec_0 // 0x151f7c75
    ==
    assert // Bytes has valid prefix
    dup
    len
    intc_2 // 8
    ==
    assert // invalid number of bytes for arc4.uint64
    btoi
    retsub


// smart_contracts/contracts/ownable.algo.ts::Ownable.onlyOwner() -> void:
onlyOwner:
    // smart_contracts/contracts/ownable.algo.ts:13
    // assert(op.Txn.sender.bytes === this.owner.value.bytes, 'Only owner');
    txn Sender
    intc_1 // 0
    // smart_contracts/contracts/ownable.algo.ts:6
    // protected owner = GlobalState<Address>();
    bytec_2 // "owner"
    // smart_contracts/contracts/ownable.algo.ts:13
    // assert(op.Txn.sender.bytes === this.owner.value.bytes, 'Only owner');
    app_global_get_ex
    assert // check GlobalState exists
    ==
    assert // Only owner
    retsub
",
501
+ clear: "I3ByYWdtYSB2ZXJzaW9uIDExCiNwcmFnbWEgdHlwZXRyYWNrIGZhbHNlCgovLyBAYWxnb3JhbmRmb3VuZGF0aW9uL2FsZ29yYW5kLXR5cGVzY3JpcHQvYmFzZS1jb250cmFjdC5kLnRzOjpCYXNlQ29udHJhY3QuY2xlYXJTdGF0ZVByb2dyYW0oKSAtPiB1aW50NjQ6Cm1haW46CiAgICBwdXNoaW50IDEgLy8gMQogICAgcmV0dXJuCg==",
502
+ },
503
+ byteCode: {
504
+ approval: "CyAFAQAIINR6JhEEFR98dQdjYW5Td2FwBW93bmVyCWdhc09yYWNsZQpyZWJhbGFuY2VyB2NoYWluSWQJbWVzc2VuZ2VyAXQBcA1zdG9wQXV0aG9yaXR5AQEBAAF1BENBeqME90dbggwVH3x1AAAAAAAAPVQDBoEBMRhAAAkjrycETGcpImcxGRREMRhBAM2CDARl9wVzBD44AnwEpGAK7QTeTK1KBE66ByEExhftcwRXUxVgBGOAgngEBlB8agT1+W6zBEsGLKAEw83ZKicNggkEB9+EKQSAxccPBEE00GgE7xX4VQRrHuIjBBhwpJIENVcyTQQEsWHxBNKzV+snDoIEBAylrnoEJ0cPBwTL/G0CBOF7r7Q2GgCOGwDZARQBZAGpArACzQLqAwYDJANdA+QEHgRCAAYAAQRXBMsFEwUoBTYFPgVPBWAFcgWQBaEFswAnD7AiQycPsCJDgARmTKQENhoAjgEAiACKAgCL/oEKCIsAMgwNQQAqsYEGshCBBbIZJxCyHicQsh+L/40CAAsABLNC/9syALIBQv/1I7IBQv/viYoBAYv/OBQyChJEi/84IDIDEkSL/zgVMgMSRIv/OBKJigEBi/84BzIKE0EAAiOJi/84IDIDE0EAAiOJi/84CTIDE0EAAiOJi/84CIk2GgFJFSUSRDYaAkkVIhJENhoDSRUkEkQXNhoESRUkEkQXKksEZytMZycJTwNnJwVPAmcnBkxnIkM2GgFJFSQSRBeIB3exMgqyFCOyErIRgQSyECOyAbOAGEJyaWRnZTogb3B0LWluIGNvbXBsZXRlZLAiQzEWgQIJSTgQIhJEMRYiCUk4EIEEEkQ2GgFJFSUSRDYaAkkVIhJENhoDSRUlEkQ2GgRJFSUSRDYaBUkVJBJEF08GiP8cTgZOBiNPB4gEYSJDMRYiCUk4EIEEEkQ2GgFJFSUSRDYaAkkVIhJENhoDSRUlEkQ2GgRJFSUSRDYaBUkVJBJEFzYaBkkVJBJEFyNOB4gEHCJDMRYiCUk4ECISRDYaAUkVJBJEFzYaAklOA0kVJRJENhoDSRUiEkQ2GgRJFSUSRDYaBUlOBkkVJRJENhoGSRUkEkQXIyllRESAAWJLBFBJvUUBRE8HiP50SSEED0QjJwVlREsISwhPCE8DSwhPCIgFA08CvkRLAUxQAkxRAAJMUQIgUElOBkkVJRJEgAFtSwFQSb1FARREgAC/sSMnBmVEgAQz4UeqshqyGLIagQayECOyAbO0PklXBABMVwAEKBJESRUiEkQjU0RPAoEYW08DTwRPBIgEz0whBAlJQQAPsUsEsgdJsggishAjsgGzSwEWSwVQSwRQJwpQSwNQgARFg2rWTFCwIkM2GgFJFSISRDYaAkkVJRJEiAWZgAFiTwJQTL8iQzYaAUkVIhJENhoCSRUlEkSIBXxQJwdMUIAAvyJDNhoBSRUiEkQ2GgJJFSUSRIgFX1AnB0xQvEgiQzYaAUkVJBJEF4gFSrEjKmVEsgeyCCKyECOyAbMiQzYaAUkVJBJEF0mIBSsyCklOAkxwAExJTwJEQQAasSMqZUSyFEmyEksCshFLAbIAgQSyECOyAbMiQzYaAUkVIhJENhoCSRUkEkQXSwGIBJ+xIycGZUQnDrIaSwOyGrIYgQayECOyAbO0PklXBABMVwAEKBJESRUkEkQXsSMrZUROAggWgAR799UMshpPA7IashqyGIEGshAjsgGztD5JVwQATFcABCgSREkVJBJEF0wWgAFlTFC+RBcKFihMULAiQzYaAUkVJBJEFzYaAkkVJRJENhoDSRUiEkQ2GgRJFSISRDYaBUkVJRJENhoGSRUlEkSIAwQoTFCwIkM2GgFJFSISRDYaAkkVJRJEUCcHTFC9RQEnCyNPAlQoTFCwIkM2GgFJFSISRIgD0SEECBYoTFCwIkMxFiIJSTgQgQQSRDYaAUkVJBJEFzYaAkkVJRJENhoDSRUkEkQXNhoESRUkEkQXI4j7kCMpZUREMQBLBIj7v08FOBFJSwNLA4gDB0sGSwZPAk8GiAKiTwNPBFBPAhZQTwMWUE8CFlBMFlCABBVARLNMULAiQzYaAUkVJBJEFzYaAkkVJBJEF4gDfEkWJwhLAVBPAxa/THEBRIEJTAlJgQYIgQpMlIABZksDUEwWv4EKTJSAAWVPAlBMFr8iQzYaAUkVJBJEF4gDPRYnCExQvEgiQzEAIycJZUQSRCkjZyJDiAMjKSJnIkM2GgFJFSUSRIgDEycJTGciQzYaAUkVJRJEiAMCJwRMZyJDNhoBSRUiEkSIAqcWKExQsCJDNhoBSRUiEkQ2GgJJFSQSRBeIAtYnDE8CUEwWvyJDNhoBSRUkEkQXiALAK0xnIkM2GgFJFSISRIgCchYoTFCwIkM2GgFJFSUSRIgCnipMZyJDiggAi/8jiPpNIyllRESL+Yj6fkmL/g1EJa+L+hIURIv5OBGL/kAA7iOL+EsBCIv4Fk8CFlCL/hZQgAQ2uvrdTFCwiwCL/gmLATEATwKIAZUjJwVlRIv7SwETRIv7i/xQJwdMUL1FAURLAYv6TwKL+4v8i/2IAOKL+4gB3yEECIABc0sCUEm9RQEURIAAv0sBVwEBsSMnBmVEJw2yGkyyGkmyGIEGshAjsgGztD5JVwQATFcABCgSREkVJBJEF0sBcghEsbIHSbIIIrIQI7IBtoAE0C9X9bIaTwOyGkyyGIEGshAjsgGzSwEWSwEWUIAES1VBm0xQsAhPAg5EFov6UIv7UIv8UIv9UCcKUIAEIp+67ExQsImLARaAAWZMUL5EF4v+C7EjK2VEIycFZUSABB23DN2yGrIashiBBrIQI7IBs7Q+SVcEAExXAAQoEkRJFSQSRBcKQv7QigYBgRivi/oWUIEfr4v8UEyL+1BMUIv+UIv/UCcKUAKL/BcjTFaL/RciTFZJFSUSRImKBAGL/BYnCExQSb1FAUS+SBexi/4Wi/8WIycEZUSL/RInCyNPAlSABA0bTAayGov9shpPArIaTLIashqyGIEGshAjsgGztD5JVwQATFcABCgSREkVJBJEF4mKAwGL/RYnCExQSb1FAUS+SBexSXIIRLIUi/+yEov9shGBBLIQI7IBs7GL/xYjJwRlRIv+EicLI08CVIAE2XitFLIai/6yGkyyGrIashiBBrIQI7IBs7Q+SVcEAExXAAQoEkRJFSQSRBeJigEBJwyL/1C+RBeJigEBJwyL/1C+RBexIytlREwWgATCr8zRshqL/7IashqyGIEGshAjsgGztD5JVwQATFcABCgSREkVJBJEF4kxACMqZUQSRIk=",
505
+ clear: "C4EBQw==",
506
+ },
507
+ events: [
508
+ {
509
+ name: "BridgingFeeFromTokens",
510
+ args: [
511
+ { type: "uint64", name: "feeFromNative" },
512
+ { type: "uint64", name: "feeFromStable" },
513
+ { type: "uint64", name: "feeStableTokenAmount" },
514
+ ],
515
+ },
516
+ {
517
+ name: "ReceiveFee",
518
+ args: [
519
+ { type: "uint64", name: "bridgeTransactionCost" },
520
+ { type: "uint64", name: "messageTransactionCost" },
521
+ ],
522
+ },
523
+ {
524
+ name: "TokensSent",
525
+ args: [
526
+ { type: "uint64", name: "amount" },
527
+ { type: "byte[32]", name: "recipient" },
528
+ { type: "byte", name: "destinationChainId" },
529
+ { type: "byte[32]", name: "receiveToken" },
530
+ { type: "byte[32]", name: "nonce" },
531
+ { type: "byte", name: "messenger" },
532
+ ],
533
+ },
534
+ {
535
+ name: "TokensReceived",
536
+ args: [
537
+ { type: "uint64", name: "receiveAmount" },
538
+ { type: "address", name: "recipient" },
539
+ { type: "byte[32]", name: "nonce" },
540
+ { type: "byte", name: "messenger" },
541
+ { type: "byte[32]", name: "message" },
542
+ ],
543
+ },
544
+ {
545
+ name: "Swapped",
546
+ args: [
547
+ { type: "address", name: "sender" },
548
+ { type: "address", name: "recipient" },
549
+ { type: "uint64", name: "tokenId" },
550
+ { type: "uint64", name: "receiveTokenId" },
551
+ { type: "uint64", name: "amount" },
552
+ { type: "uint64", name: "receivedAmount" },
553
+ ],
554
+ },
555
+ ],
556
+ templateVariables: {},
557
+ };
558
+ class BinaryStateValue {
559
+ value;
560
+ constructor(value) {
561
+ this.value = value;
562
+ }
563
+ asByteArray() {
564
+ return this.value;
565
+ }
566
+ asString() {
567
+ return this.value !== undefined ? Buffer.from(this.value).toString("utf-8") : undefined;
568
+ }
569
+ }
570
+ /**
571
+ * Exposes methods for constructing `AppClient` params objects for ABI calls to the Bridge smart contract
572
+ */
573
+ class BridgeParamsFactory {
574
+ /**
575
+ * Gets available create ABI call param factories
576
+ */
577
+ static get create() {
578
+ return {
579
+ _resolveByMethod(params) {
580
+ switch (params.method) {
581
+ case "createApplication":
582
+ case "createApplication(address,byte,uint64,uint64)void":
583
+ return BridgeParamsFactory.create.createApplication(params);
584
+ }
585
+ throw new Error(`Unknown ' + verb + ' method`);
586
+ },
587
+ /**
588
+ * Constructs create ABI call params for the Bridge smart contract using the createApplication(address,byte,uint64,uint64)void ABI method
589
+ *
590
+ * @param params Parameters for the call
591
+ * @returns An `AppClientMethodCallParams` object for the call
592
+ */
593
+ createApplication(params) {
594
+ return {
595
+ ...params,
596
+ method: "createApplication(address,byte,uint64,uint64)void",
597
+ args: Array.isArray(params.args)
598
+ ? params.args
599
+ : [params.args.owner, params.args.chainId, params.args.messenger, params.args.gasOracle],
600
+ };
601
+ },
602
+ };
603
+ }
604
+ /**
605
+ * Constructs a no op call for the optInAsset(uint64)void ABI method
606
+ *
607
+ * @param params Parameters for the call
608
+ * @returns An `AppClientMethodCallParams` object for the call
609
+ */
610
+ static optInAsset(params) {
611
+ return {
612
+ ...params,
613
+ method: "optInAsset(uint64)void",
614
+ args: Array.isArray(params.args) ? params.args : [params.args.asset],
615
+ };
616
+ }
617
+ /**
618
+ * Constructs a no op call for the swapAndBridge(pay,axfer,byte[32],byte,byte[32],byte[32],uint64)void ABI method
619
+ *
620
+ * @param params Parameters for the call
621
+ * @returns An `AppClientMethodCallParams` object for the call
622
+ */
623
+ static swapAndBridge(params) {
624
+ return {
625
+ ...params,
626
+ method: "swapAndBridge(pay,axfer,byte[32],byte,byte[32],byte[32],uint64)void",
627
+ args: Array.isArray(params.args)
628
+ ? params.args
629
+ : [
630
+ params.args.paymentRef,
631
+ params.args.assetTransferRef,
632
+ params.args.recipient,
633
+ params.args.destinationChainId,
634
+ params.args.receiveToken,
635
+ params.args.nonce,
636
+ params.args.budget,
637
+ ],
638
+ };
639
+ }
640
+ /**
641
+ * Constructs a no op call for the swapAndBridgeWithStable(axfer,byte[32],byte,byte[32],byte[32],uint64,uint64)void ABI method
642
+ *
643
+ * @param params Parameters for the call
644
+ * @returns An `AppClientMethodCallParams` object for the call
645
+ */
646
+ static swapAndBridgeWithStable(params) {
647
+ return {
648
+ ...params,
649
+ method: "swapAndBridgeWithStable(axfer,byte[32],byte,byte[32],byte[32],uint64,uint64)void",
650
+ args: Array.isArray(params.args)
651
+ ? params.args
652
+ : [
653
+ params.args.assetTransferRef,
654
+ params.args.recipient,
655
+ params.args.destinationChainId,
656
+ params.args.receiveToken,
657
+ params.args.nonce,
658
+ params.args.feeTokenAmount,
659
+ params.args.budget,
660
+ ],
661
+ };
662
+ }
663
+ /**
664
+ * Constructs a no op call for the receiveTokens(pay,uint64,byte[32],byte,byte[32],byte[32],uint64)void ABI method
665
+ *
666
+ * @param params Parameters for the call
667
+ * @returns An `AppClientMethodCallParams` object for the call
668
+ */
669
+ static receiveTokens(params) {
670
+ return {
671
+ ...params,
672
+ method: "receiveTokens(pay,uint64,byte[32],byte,byte[32],byte[32],uint64)void",
673
+ args: Array.isArray(params.args)
674
+ ? params.args
675
+ : [
676
+ params.args.paymentRef,
677
+ params.args.amount,
678
+ params.args.recipient,
679
+ params.args.sourceChainId,
680
+ params.args.receiveToken,
681
+ params.args.nonce,
682
+ params.args.receiveAmountMin,
683
+ ],
684
+ };
685
+ }
686
+ /**
687
+ * Constructs a no op call for the registerBridge(byte,byte[32])void ABI method
688
+ *
689
+ * @param params Parameters for the call
690
+ * @returns An `AppClientMethodCallParams` object for the call
691
+ */
692
+ static registerBridge(params) {
693
+ return {
694
+ ...params,
695
+ method: "registerBridge(byte,byte[32])void",
696
+ args: Array.isArray(params.args) ? params.args : [params.args.chainId, params.args.bridgeAddress],
697
+ };
698
+ }
699
+ /**
700
+ * Constructs a no op call for the addBridgeToken(byte,byte[32])void ABI method
701
+ *
702
+ * @param params Parameters for the call
703
+ * @returns An `AppClientMethodCallParams` object for the call
704
+ */
705
+ static addBridgeToken(params) {
706
+ return {
707
+ ...params,
708
+ method: "addBridgeToken(byte,byte[32])void",
709
+ args: Array.isArray(params.args) ? params.args : [params.args.chainId, params.args.tokenAddress],
710
+ };
711
+ }
712
+ /**
713
+ * Constructs a no op call for the removeBridgeToken(byte,byte[32])void ABI method
714
+ *
715
+ * @param params Parameters for the call
716
+ * @returns An `AppClientMethodCallParams` object for the call
717
+ */
718
+ static removeBridgeToken(params) {
719
+ return {
720
+ ...params,
721
+ method: "removeBridgeToken(byte,byte[32])void",
722
+ args: Array.isArray(params.args) ? params.args : [params.args.chainId, params.args.tokenAddress],
723
+ };
724
+ }
725
+ /**
726
+ * Constructs a no op call for the withdrawGasTokens(uint64)void ABI method
727
+ *
728
+ * @param params Parameters for the call
729
+ * @returns An `AppClientMethodCallParams` object for the call
730
+ */
731
+ static withdrawGasTokens(params) {
732
+ return {
733
+ ...params,
734
+ method: "withdrawGasTokens(uint64)void",
735
+ args: Array.isArray(params.args) ? params.args : [params.args.amount],
736
+ };
737
+ }
738
+ /**
739
+ * Constructs a no op call for the withdrawBridgingFeeInTokens(uint64)void ABI method
740
+ *
741
+ * @param params Parameters for the call
742
+ * @returns An `AppClientMethodCallParams` object for the call
743
+ */
744
+ static withdrawBridgingFeeInTokens(params) {
745
+ return {
746
+ ...params,
747
+ method: "withdrawBridgingFeeInTokens(uint64)void",
748
+ args: Array.isArray(params.args) ? params.args : [params.args.asset],
749
+ };
750
+ }
751
+ /**
752
+ * Constructs a no op call for the getBridgingCostInTokens(byte,uint64)uint64 ABI method
753
+ *
754
+ * @param params Parameters for the call
755
+ * @returns An `AppClientMethodCallParams` object for the call
756
+ */
757
+ static getBridgingCostInTokens(params) {
758
+ return {
759
+ ...params,
760
+ method: "getBridgingCostInTokens(byte,uint64)uint64",
761
+ args: Array.isArray(params.args) ? params.args : [params.args.destinationChainId, params.args.asset],
762
+ };
763
+ }
764
+ /**
765
+ * Constructs a no op call for the hashMessage(uint64,byte[32],byte,byte,byte[32],byte[32])byte[32] ABI method
766
+ *
767
+ * @param params Parameters for the call
768
+ * @returns An `AppClientMethodCallParams` object for the call
769
+ */
770
+ static hashMessage(params) {
771
+ return {
772
+ ...params,
773
+ method: "hashMessage(uint64,byte[32],byte,byte,byte[32],byte[32])byte[32]",
774
+ args: Array.isArray(params.args)
775
+ ? params.args
776
+ : [
777
+ params.args.amount,
778
+ params.args.recipient,
779
+ params.args.sourceChainId,
780
+ params.args.destinationChainId,
781
+ params.args.receiveToken,
782
+ params.args.nonce,
783
+ ],
784
+ };
785
+ }
786
+ /**
787
+ * Constructs a no op call for the isOtherBridgeTokenSupported(byte,byte[32])bool ABI method
788
+ *
789
+ * @param params Parameters for the call
790
+ * @returns An `AppClientMethodCallParams` object for the call
791
+ */
792
+ static isOtherBridgeTokenSupported(params) {
793
+ return {
794
+ ...params,
795
+ method: "isOtherBridgeTokenSupported(byte,byte[32])bool",
796
+ args: Array.isArray(params.args) ? params.args : [params.args.chainId, params.args.token],
797
+ };
798
+ }
799
+ /**
800
+ * Constructs a no op call for the getTransactionCost(byte)uint64 ABI method
801
+ *
802
+ * @param params Parameters for the call
803
+ * @returns An `AppClientMethodCallParams` object for the call
804
+ */
805
+ static getTransactionCost(params) {
806
+ return {
807
+ ...params,
808
+ method: "getTransactionCost(byte)uint64",
809
+ args: Array.isArray(params.args) ? params.args : [params.args.chainId],
810
+ };
811
+ }
812
+ /**
813
+ * Constructs a no op call for the getReceiveTokensCost()uint64 ABI method
814
+ *
815
+ * @param params Parameters for the call
816
+ * @returns An `AppClientMethodCallParams` object for the call
817
+ */
818
+ static getReceiveTokensCost(params) {
819
+ return {
820
+ ...params,
821
+ method: "getReceiveTokensCost()uint64",
822
+ args: Array.isArray(params.args) ? params.args : [],
823
+ };
824
+ }
825
+ /**
826
+ * Constructs a no op call for the getSendTransactionStorageCost()uint64 ABI method
827
+ *
828
+ * @param params Parameters for the call
829
+ * @returns An `AppClientMethodCallParams` object for the call
830
+ */
831
+ static getSendTransactionStorageCost(params) {
832
+ return {
833
+ ...params,
834
+ method: "getSendTransactionStorageCost()uint64",
835
+ args: Array.isArray(params.args) ? params.args : [],
836
+ };
837
+ }
838
+ /**
839
+ * Constructs a no op call for the swap(axfer,uint64,address,uint64,uint64)void ABI method
840
+ *
841
+ * @param params Parameters for the call
842
+ * @returns An `AppClientMethodCallParams` object for the call
843
+ */
844
+ static swap(params) {
845
+ return {
846
+ ...params,
847
+ method: "swap(axfer,uint64,address,uint64,uint64)void",
848
+ args: Array.isArray(params.args)
849
+ ? params.args
850
+ : [
851
+ params.args.assetTransferRef,
852
+ params.args.receiveAsset,
853
+ params.args.recipient,
854
+ params.args.receiveAmountMin,
855
+ params.args.budget,
856
+ ],
857
+ };
858
+ }
859
+ /**
860
+ * Constructs a no op call for the addPool(uint64,uint64)void ABI method
861
+ *
862
+ * @param params Parameters for the call
863
+ * @returns An `AppClientMethodCallParams` object for the call
864
+ */
865
+ static addPool(params) {
866
+ return {
867
+ ...params,
868
+ method: "addPool(uint64,uint64)void",
869
+ args: Array.isArray(params.args) ? params.args : [params.args.poolId, params.args.asset],
870
+ };
871
+ }
872
+ /**
873
+ * Constructs a no op call for the removePool(uint64)void ABI method
874
+ *
875
+ * @param params Parameters for the call
876
+ * @returns An `AppClientMethodCallParams` object for the call
877
+ */
878
+ static removePool(params) {
879
+ return {
880
+ ...params,
881
+ method: "removePool(uint64)void",
882
+ args: Array.isArray(params.args) ? params.args : [params.args.tokenId],
883
+ };
884
+ }
885
+ /**
886
+ * Constructs a no op call for the stopSwap()void ABI method
887
+ *
888
+ * @param params Parameters for the call
889
+ * @returns An `AppClientMethodCallParams` object for the call
890
+ */
891
+ static stopSwap(params) {
892
+ return {
893
+ ...params,
894
+ method: "stopSwap()void",
895
+ args: Array.isArray(params.args) ? params.args : [],
896
+ };
897
+ }
898
+ /**
899
+ * Constructs a no op call for the startSwap()void ABI method
900
+ *
901
+ * @param params Parameters for the call
902
+ * @returns An `AppClientMethodCallParams` object for the call
903
+ */
904
+ static startSwap(params) {
905
+ return {
906
+ ...params,
907
+ method: "startSwap()void",
908
+ args: Array.isArray(params.args) ? params.args : [],
909
+ };
910
+ }
911
+ /**
912
+ * Constructs a no op call for the setStopAuthority(address)void ABI method
913
+ *
914
+ * @param params Parameters for the call
915
+ * @returns An `AppClientMethodCallParams` object for the call
916
+ */
917
+ static setStopAuthority(params) {
918
+ return {
919
+ ...params,
920
+ method: "setStopAuthority(address)void",
921
+ args: Array.isArray(params.args) ? params.args : [params.args.stopAuthority],
922
+ };
923
+ }
924
+ /**
925
+ * Constructs a no op call for the setRebalancer(address)void ABI method
926
+ *
927
+ * @param params Parameters for the call
928
+ * @returns An `AppClientMethodCallParams` object for the call
929
+ */
930
+ static setRebalancer(params) {
931
+ return {
932
+ ...params,
933
+ method: "setRebalancer(address)void",
934
+ args: Array.isArray(params.args) ? params.args : [params.args.rebalancer],
935
+ };
936
+ }
937
+ /**
938
+ * Constructs a no op call for the getGasUsage(byte)uint64 ABI method
939
+ *
940
+ * @param params Parameters for the call
941
+ * @returns An `AppClientMethodCallParams` object for the call
942
+ */
943
+ static getGasUsage(params) {
944
+ return {
945
+ ...params,
946
+ method: "getGasUsage(byte)uint64",
947
+ args: Array.isArray(params.args) ? params.args : [params.args.chainId],
948
+ };
949
+ }
950
+ /**
951
+ * Constructs a no op call for the setGasUsage(byte,uint64)void ABI method
952
+ *
953
+ * @param params Parameters for the call
954
+ * @returns An `AppClientMethodCallParams` object for the call
955
+ */
956
+ static setGasUsage(params) {
957
+ return {
958
+ ...params,
959
+ method: "setGasUsage(byte,uint64)void",
960
+ args: Array.isArray(params.args) ? params.args : [params.args.chainId, params.args.gasAmount],
961
+ };
962
+ }
963
+ /**
964
+ * Constructs a no op call for the setGasOracle(uint64)void ABI method
965
+ *
966
+ * @param params Parameters for the call
967
+ * @returns An `AppClientMethodCallParams` object for the call
968
+ */
969
+ static setGasOracle(params) {
970
+ return {
971
+ ...params,
972
+ method: "setGasOracle(uint64)void",
973
+ args: Array.isArray(params.args) ? params.args : [params.args.gasOracle],
974
+ };
975
+ }
976
+ /**
977
+ * Constructs a no op call for the getTransactionRelayerCost(byte)uint64 ABI method
978
+ *
979
+ * @param params Parameters for the call
980
+ * @returns An `AppClientMethodCallParams` object for the call
981
+ */
982
+ static getTransactionRelayerCost(params) {
983
+ return {
984
+ ...params,
985
+ method: "getTransactionRelayerCost(byte)uint64",
986
+ args: Array.isArray(params.args) ? params.args : [params.args.chainId],
987
+ };
988
+ }
989
+ /**
990
+ * Constructs a no op call for the transferOwnership(address)void ABI method
991
+ *
992
+ * @param params Parameters for the call
993
+ * @returns An `AppClientMethodCallParams` object for the call
994
+ */
995
+ static transferOwnership(params) {
996
+ return {
997
+ ...params,
998
+ method: "transferOwnership(address)void",
999
+ args: Array.isArray(params.args) ? params.args : [params.args.newOwner],
1000
+ };
1001
+ }
1002
+ }
1003
+ exports.BridgeParamsFactory = BridgeParamsFactory;
1004
+ /**
1005
+ * A factory to create and deploy one or more instance of the Bridge smart contract and to create one or more app clients to interact with those (or other) app instances
1006
+ */
1007
+ class BridgeFactory {
1008
+ /**
1009
+ * The underlying `AppFactory` for when you want to have more flexibility
1010
+ */
1011
+ appFactory;
1012
+ /**
1013
+ * Creates a new instance of `BridgeFactory`
1014
+ *
1015
+ * @param params The parameters to initialise the app factory with
1016
+ */
1017
+ constructor(params) {
1018
+ this.appFactory = new app_factory_1.AppFactory({
1019
+ ...params,
1020
+ appSpec: exports.APP_SPEC,
1021
+ });
1022
+ }
1023
+ /** The name of the app (from the ARC-32 / ARC-56 app spec or override). */
1024
+ get appName() {
1025
+ return this.appFactory.appName;
1026
+ }
1027
+ /** The ARC-56 app spec being used */
1028
+ get appSpec() {
1029
+ return exports.APP_SPEC;
1030
+ }
1031
+ /** A reference to the underlying `AlgorandClient` this app factory is using. */
1032
+ get algorand() {
1033
+ return this.appFactory.algorand;
1034
+ }
1035
+ /**
1036
+ * Returns a new `AppClient` client for an app instance of the given ID.
1037
+ *
1038
+ * Automatically populates appName, defaultSender and source maps from the factory
1039
+ * if not specified in the params.
1040
+ * @param params The parameters to create the app client
1041
+ * @returns The `AppClient`
1042
+ */
1043
+ getAppClientById(params) {
1044
+ return new BridgeClient(this.appFactory.getAppClientById(params));
1045
+ }
1046
+ /**
1047
+ * Returns a new `AppClient` client, resolving the app by creator address and name
1048
+ * using AlgoKit app deployment semantics (i.e. looking for the app creation transaction note).
1049
+ *
1050
+ * Automatically populates appName, defaultSender and source maps from the factory
1051
+ * if not specified in the params.
1052
+ * @param params The parameters to create the app client
1053
+ * @returns The `AppClient`
1054
+ */
1055
+ async getAppClientByCreatorAndName(params) {
1056
+ return new BridgeClient(await this.appFactory.getAppClientByCreatorAndName(params));
1057
+ }
1058
+ /**
1059
+ * Idempotently deploys the Bridge smart contract.
1060
+ *
1061
+ * @param params The arguments for the contract calls and any additional parameters for the call
1062
+ * @returns The deployment result
1063
+ */
1064
+ async deploy(params = {}) {
1065
+ const result = await this.appFactory.deploy({
1066
+ ...params,
1067
+ createParams: params.createParams?.method
1068
+ ? BridgeParamsFactory.create._resolveByMethod(params.createParams)
1069
+ : params.createParams
1070
+ ? params.createParams
1071
+ : undefined,
1072
+ });
1073
+ return { result: result.result, appClient: new BridgeClient(result.appClient) };
1074
+ }
1075
+ /**
1076
+ * Get parameters to create transactions (create and deploy related calls) for the current app. A good mental model for this is that these parameters represent a deferred transaction creation.
1077
+ */
1078
+ params = {
1079
+ /**
1080
+ * Gets available create methods
1081
+ */
1082
+ create: {
1083
+ /**
1084
+ * Creates a new instance of the Bridge smart contract using the createApplication(address,byte,uint64,uint64)void ABI method.
1085
+ *
1086
+ * @param params The params for the smart contract call
1087
+ * @returns The create params
1088
+ */
1089
+ createApplication: (params) => {
1090
+ return this.appFactory.params.create(BridgeParamsFactory.create.createApplication(params));
1091
+ },
1092
+ },
1093
+ };
1094
+ /**
1095
+ * Create transactions for the current app
1096
+ */
1097
+ createTransaction = {
1098
+ /**
1099
+ * Gets available create methods
1100
+ */
1101
+ create: {
1102
+ /**
1103
+ * Creates a new instance of the Bridge smart contract using the createApplication(address,byte,uint64,uint64)void ABI method.
1104
+ *
1105
+ * @param params The params for the smart contract call
1106
+ * @returns The create transaction
1107
+ */
1108
+ createApplication: (params) => {
1109
+ return this.appFactory.createTransaction.create(BridgeParamsFactory.create.createApplication(params));
1110
+ },
1111
+ },
1112
+ };
1113
+ /**
1114
+ * Send calls to the current app
1115
+ */
1116
+ send = {
1117
+ /**
1118
+ * Gets available create methods
1119
+ */
1120
+ create: {
1121
+ /**
1122
+ * Creates a new instance of the Bridge smart contract using an ABI method call using the createApplication(address,byte,uint64,uint64)void ABI method.
1123
+ *
1124
+ * @param params The params for the smart contract call
1125
+ * @returns The create result
1126
+ */
1127
+ createApplication: async (params) => {
1128
+ const result = await this.appFactory.send.create(BridgeParamsFactory.create.createApplication(params));
1129
+ return {
1130
+ result: {
1131
+ ...result.result,
1132
+ return: result.result.return,
1133
+ },
1134
+ appClient: new BridgeClient(result.appClient),
1135
+ };
1136
+ },
1137
+ },
1138
+ };
1139
+ }
1140
+ exports.BridgeFactory = BridgeFactory;
1141
+ /**
1142
+ * A client to make calls to the Bridge smart contract
1143
+ */
1144
+ class BridgeClient {
1145
+ /**
1146
+ * The underlying `AppClient` for when you want to have more flexibility
1147
+ */
1148
+ appClient;
1149
+ constructor(appClientOrParams) {
1150
+ this.appClient =
1151
+ appClientOrParams instanceof app_client_1.AppClient
1152
+ ? appClientOrParams
1153
+ : new app_client_1.AppClient({
1154
+ ...appClientOrParams,
1155
+ appSpec: exports.APP_SPEC,
1156
+ });
1157
+ }
1158
+ /**
1159
+ * Checks for decode errors on the given return value and maps the return value to the return type for the given method
1160
+ * @returns The typed return value or undefined if there was no value
1161
+ */
1162
+ decodeReturnValue(method, returnValue) {
1163
+ return returnValue !== undefined
1164
+ ? (0, app_arc56_1.getArc56ReturnValue)(returnValue, this.appClient.getABIMethod(method), exports.APP_SPEC.structs)
1165
+ : undefined;
1166
+ }
1167
+ /**
1168
+ * Returns a new `BridgeClient` client, resolving the app by creator address and name
1169
+ * using AlgoKit app deployment semantics (i.e. looking for the app creation transaction note).
1170
+ * @param params The parameters to create the app client
1171
+ */
1172
+ static async fromCreatorAndName(params) {
1173
+ return new BridgeClient(await app_client_1.AppClient.fromCreatorAndName({ ...params, appSpec: exports.APP_SPEC }));
1174
+ }
1175
+ /**
1176
+ * Returns an `BridgeClient` instance for the current network based on
1177
+ * pre-determined network-specific app IDs specified in the ARC-56 app spec.
1178
+ *
1179
+ * If no IDs are in the app spec or the network isn't recognised, an error is thrown.
1180
+ * @param params The parameters to create the app client
1181
+ */
1182
+ static async fromNetwork(params) {
1183
+ return new BridgeClient(await app_client_1.AppClient.fromNetwork({ ...params, appSpec: exports.APP_SPEC }));
1184
+ }
1185
+ /** The ID of the app instance this client is linked to. */
1186
+ get appId() {
1187
+ return this.appClient.appId;
1188
+ }
1189
+ /** The app address of the app instance this client is linked to. */
1190
+ get appAddress() {
1191
+ return this.appClient.appAddress;
1192
+ }
1193
+ /** The name of the app. */
1194
+ get appName() {
1195
+ return this.appClient.appName;
1196
+ }
1197
+ /** The ARC-56 app spec being used */
1198
+ get appSpec() {
1199
+ return this.appClient.appSpec;
1200
+ }
1201
+ /** A reference to the underlying `AlgorandClient` this app client is using. */
1202
+ get algorand() {
1203
+ return this.appClient.algorand;
1204
+ }
1205
+ /**
1206
+ * Get parameters to create transactions for the current app. A good mental model for this is that these parameters represent a deferred transaction creation.
1207
+ */
1208
+ params = {
1209
+ /**
1210
+ * Makes a clear_state call to an existing instance of the Bridge smart contract.
1211
+ *
1212
+ * @param params The params for the bare (raw) call
1213
+ * @returns The clearState result
1214
+ */
1215
+ clearState: (params) => {
1216
+ return this.appClient.params.bare.clearState(params);
1217
+ },
1218
+ /**
1219
+ * Makes a call to the Bridge smart contract using the `optInAsset(uint64)void` ABI method.
1220
+ *
1221
+ * @param params The params for the smart contract call
1222
+ * @returns The call params
1223
+ */
1224
+ optInAsset: (params) => {
1225
+ return this.appClient.params.call(BridgeParamsFactory.optInAsset(params));
1226
+ },
1227
+ /**
1228
+ * Makes a call to the Bridge smart contract using the `swapAndBridge(pay,axfer,byte[32],byte,byte[32],byte[32],uint64)void` ABI method.
1229
+ *
1230
+ * @param params The params for the smart contract call
1231
+ * @returns The call params
1232
+ */
1233
+ swapAndBridge: (params) => {
1234
+ return this.appClient.params.call(BridgeParamsFactory.swapAndBridge(params));
1235
+ },
1236
+ /**
1237
+ * Makes a call to the Bridge smart contract using the `swapAndBridgeWithStable(axfer,byte[32],byte,byte[32],byte[32],uint64,uint64)void` ABI method.
1238
+ *
1239
+ * @param params The params for the smart contract call
1240
+ * @returns The call params
1241
+ */
1242
+ swapAndBridgeWithStable: (params) => {
1243
+ return this.appClient.params.call(BridgeParamsFactory.swapAndBridgeWithStable(params));
1244
+ },
1245
+ /**
1246
+ * Makes a call to the Bridge smart contract using the `receiveTokens(pay,uint64,byte[32],byte,byte[32],byte[32],uint64)void` ABI method.
1247
+ *
1248
+ * @param params The params for the smart contract call
1249
+ * @returns The call params
1250
+ */
1251
+ receiveTokens: (params) => {
1252
+ return this.appClient.params.call(BridgeParamsFactory.receiveTokens(params));
1253
+ },
1254
+ /**
1255
+ * Makes a call to the Bridge smart contract using the `registerBridge(byte,byte[32])void` ABI method.
1256
+ *
1257
+ * @param params The params for the smart contract call
1258
+ * @returns The call params
1259
+ */
1260
+ registerBridge: (params) => {
1261
+ return this.appClient.params.call(BridgeParamsFactory.registerBridge(params));
1262
+ },
1263
+ /**
1264
+ * Makes a call to the Bridge smart contract using the `addBridgeToken(byte,byte[32])void` ABI method.
1265
+ *
1266
+ * @param params The params for the smart contract call
1267
+ * @returns The call params
1268
+ */
1269
+ addBridgeToken: (params) => {
1270
+ return this.appClient.params.call(BridgeParamsFactory.addBridgeToken(params));
1271
+ },
1272
+ /**
1273
+ * Makes a call to the Bridge smart contract using the `removeBridgeToken(byte,byte[32])void` ABI method.
1274
+ *
1275
+ * @param params The params for the smart contract call
1276
+ * @returns The call params
1277
+ */
1278
+ removeBridgeToken: (params) => {
1279
+ return this.appClient.params.call(BridgeParamsFactory.removeBridgeToken(params));
1280
+ },
1281
+ /**
1282
+ * Makes a call to the Bridge smart contract using the `withdrawGasTokens(uint64)void` ABI method.
1283
+ *
1284
+ * @param params The params for the smart contract call
1285
+ * @returns The call params
1286
+ */
1287
+ withdrawGasTokens: (params) => {
1288
+ return this.appClient.params.call(BridgeParamsFactory.withdrawGasTokens(params));
1289
+ },
1290
+ /**
1291
+ * Makes a call to the Bridge smart contract using the `withdrawBridgingFeeInTokens(uint64)void` ABI method.
1292
+ *
1293
+ * @param params The params for the smart contract call
1294
+ * @returns The call params
1295
+ */
1296
+ withdrawBridgingFeeInTokens: (params) => {
1297
+ return this.appClient.params.call(BridgeParamsFactory.withdrawBridgingFeeInTokens(params));
1298
+ },
1299
+ /**
1300
+ * Makes a call to the Bridge smart contract using the `getBridgingCostInTokens(byte,uint64)uint64` ABI method.
1301
+ *
1302
+ * This method is a readonly method; calling it with onComplete of NoOp will result in a simulated transaction rather than a real transaction.
1303
+ *
1304
+ * @param params The params for the smart contract call
1305
+ * @returns The call params
1306
+ */
1307
+ getBridgingCostInTokens: (params) => {
1308
+ return this.appClient.params.call(BridgeParamsFactory.getBridgingCostInTokens(params));
1309
+ },
1310
+ /**
1311
+ * Makes a call to the Bridge smart contract using the `hashMessage(uint64,byte[32],byte,byte,byte[32],byte[32])byte[32]` ABI method.
1312
+ *
1313
+ * This method is a readonly method; calling it with onComplete of NoOp will result in a simulated transaction rather than a real transaction.
1314
+ *
1315
+ * @param params The params for the smart contract call
1316
+ * @returns The call params
1317
+ */
1318
+ hashMessage: (params) => {
1319
+ return this.appClient.params.call(BridgeParamsFactory.hashMessage(params));
1320
+ },
1321
+ /**
1322
+ * Makes a call to the Bridge smart contract using the `isOtherBridgeTokenSupported(byte,byte[32])bool` ABI method.
1323
+ *
1324
+ * This method is a readonly method; calling it with onComplete of NoOp will result in a simulated transaction rather than a real transaction.
1325
+ *
1326
+ * @param params The params for the smart contract call
1327
+ * @returns The call params
1328
+ */
1329
+ isOtherBridgeTokenSupported: (params) => {
1330
+ return this.appClient.params.call(BridgeParamsFactory.isOtherBridgeTokenSupported(params));
1331
+ },
1332
+ /**
1333
+ * Makes a call to the Bridge smart contract using the `getTransactionCost(byte)uint64` ABI method.
1334
+ *
1335
+ * This method is a readonly method; calling it with onComplete of NoOp will result in a simulated transaction rather than a real transaction.
1336
+ *
1337
+ * @param params The params for the smart contract call
1338
+ * @returns The call params
1339
+ */
1340
+ getTransactionCost: (params) => {
1341
+ return this.appClient.params.call(BridgeParamsFactory.getTransactionCost(params));
1342
+ },
1343
+ /**
1344
+ * Makes a call to the Bridge smart contract using the `getReceiveTokensCost()uint64` ABI method.
1345
+ *
1346
+ * This method is a readonly method; calling it with onComplete of NoOp will result in a simulated transaction rather than a real transaction.
1347
+ *
1348
+ * @param params The params for the smart contract call
1349
+ * @returns The call params
1350
+ */
1351
+ getReceiveTokensCost: (params = { args: [] }) => {
1352
+ return this.appClient.params.call(BridgeParamsFactory.getReceiveTokensCost(params));
1353
+ },
1354
+ /**
1355
+ * Makes a call to the Bridge smart contract using the `getSendTransactionStorageCost()uint64` ABI method.
1356
+ *
1357
+ * This method is a readonly method; calling it with onComplete of NoOp will result in a simulated transaction rather than a real transaction.
1358
+ *
1359
+ * @param params The params for the smart contract call
1360
+ * @returns The call params
1361
+ */
1362
+ getSendTransactionStorageCost: (params = { args: [] }) => {
1363
+ return this.appClient.params.call(BridgeParamsFactory.getSendTransactionStorageCost(params));
1364
+ },
1365
+ /**
1366
+ * Makes a call to the Bridge smart contract using the `swap(axfer,uint64,address,uint64,uint64)void` ABI method.
1367
+ *
1368
+ * @param params The params for the smart contract call
1369
+ * @returns The call params
1370
+ */
1371
+ swap: (params) => {
1372
+ return this.appClient.params.call(BridgeParamsFactory.swap(params));
1373
+ },
1374
+ /**
1375
+ * Makes a call to the Bridge smart contract using the `addPool(uint64,uint64)void` ABI method.
1376
+ *
1377
+ * @param params The params for the smart contract call
1378
+ * @returns The call params
1379
+ */
1380
+ addPool: (params) => {
1381
+ return this.appClient.params.call(BridgeParamsFactory.addPool(params));
1382
+ },
1383
+ /**
1384
+ * Makes a call to the Bridge smart contract using the `removePool(uint64)void` ABI method.
1385
+ *
1386
+ * @param params The params for the smart contract call
1387
+ * @returns The call params
1388
+ */
1389
+ removePool: (params) => {
1390
+ return this.appClient.params.call(BridgeParamsFactory.removePool(params));
1391
+ },
1392
+ /**
1393
+ * Makes a call to the Bridge smart contract using the `stopSwap()void` ABI method.
1394
+ *
1395
+ * @param params The params for the smart contract call
1396
+ * @returns The call params
1397
+ */
1398
+ stopSwap: (params = { args: [] }) => {
1399
+ return this.appClient.params.call(BridgeParamsFactory.stopSwap(params));
1400
+ },
1401
+ /**
1402
+ * Makes a call to the Bridge smart contract using the `startSwap()void` ABI method.
1403
+ *
1404
+ * @param params The params for the smart contract call
1405
+ * @returns The call params
1406
+ */
1407
+ startSwap: (params = { args: [] }) => {
1408
+ return this.appClient.params.call(BridgeParamsFactory.startSwap(params));
1409
+ },
1410
+ /**
1411
+ * Makes a call to the Bridge smart contract using the `setStopAuthority(address)void` ABI method.
1412
+ *
1413
+ * @param params The params for the smart contract call
1414
+ * @returns The call params
1415
+ */
1416
+ setStopAuthority: (params) => {
1417
+ return this.appClient.params.call(BridgeParamsFactory.setStopAuthority(params));
1418
+ },
1419
+ /**
1420
+ * Makes a call to the Bridge smart contract using the `setRebalancer(address)void` ABI method.
1421
+ *
1422
+ * @param params The params for the smart contract call
1423
+ * @returns The call params
1424
+ */
1425
+ setRebalancer: (params) => {
1426
+ return this.appClient.params.call(BridgeParamsFactory.setRebalancer(params));
1427
+ },
1428
+ /**
1429
+ * Makes a call to the Bridge smart contract using the `getGasUsage(byte)uint64` ABI method.
1430
+ *
1431
+ * This method is a readonly method; calling it with onComplete of NoOp will result in a simulated transaction rather than a real transaction.
1432
+ *
1433
+ * @param params The params for the smart contract call
1434
+ * @returns The call params
1435
+ */
1436
+ getGasUsage: (params) => {
1437
+ return this.appClient.params.call(BridgeParamsFactory.getGasUsage(params));
1438
+ },
1439
+ /**
1440
+ * Makes a call to the Bridge smart contract using the `setGasUsage(byte,uint64)void` ABI method.
1441
+ *
1442
+ * @param params The params for the smart contract call
1443
+ * @returns The call params
1444
+ */
1445
+ setGasUsage: (params) => {
1446
+ return this.appClient.params.call(BridgeParamsFactory.setGasUsage(params));
1447
+ },
1448
+ /**
1449
+ * Makes a call to the Bridge smart contract using the `setGasOracle(uint64)void` ABI method.
1450
+ *
1451
+ * @param params The params for the smart contract call
1452
+ * @returns The call params
1453
+ */
1454
+ setGasOracle: (params) => {
1455
+ return this.appClient.params.call(BridgeParamsFactory.setGasOracle(params));
1456
+ },
1457
+ /**
1458
+ * Makes a call to the Bridge smart contract using the `getTransactionRelayerCost(byte)uint64` ABI method.
1459
+ *
1460
+ * This method is a readonly method; calling it with onComplete of NoOp will result in a simulated transaction rather than a real transaction.
1461
+ *
1462
+ * @param params The params for the smart contract call
1463
+ * @returns The call params
1464
+ */
1465
+ getTransactionRelayerCost: (params) => {
1466
+ return this.appClient.params.call(BridgeParamsFactory.getTransactionRelayerCost(params));
1467
+ },
1468
+ /**
1469
+ * Makes a call to the Bridge smart contract using the `transferOwnership(address)void` ABI method.
1470
+ *
1471
+ * @param params The params for the smart contract call
1472
+ * @returns The call params
1473
+ */
1474
+ transferOwnership: (params) => {
1475
+ return this.appClient.params.call(BridgeParamsFactory.transferOwnership(params));
1476
+ },
1477
+ };
1478
+ /**
1479
+ * Create transactions for the current app
1480
+ */
1481
+ createTransaction = {
1482
+ /**
1483
+ * Makes a clear_state call to an existing instance of the Bridge smart contract.
1484
+ *
1485
+ * @param params The params for the bare (raw) call
1486
+ * @returns The clearState result
1487
+ */
1488
+ clearState: (params) => {
1489
+ return this.appClient.createTransaction.bare.clearState(params);
1490
+ },
1491
+ /**
1492
+ * Makes a call to the Bridge smart contract using the `optInAsset(uint64)void` ABI method.
1493
+ *
1494
+ * @param params The params for the smart contract call
1495
+ * @returns The call transaction
1496
+ */
1497
+ optInAsset: (params) => {
1498
+ return this.appClient.createTransaction.call(BridgeParamsFactory.optInAsset(params));
1499
+ },
1500
+ /**
1501
+ * Makes a call to the Bridge smart contract using the `swapAndBridge(pay,axfer,byte[32],byte,byte[32],byte[32],uint64)void` ABI method.
1502
+ *
1503
+ * @param params The params for the smart contract call
1504
+ * @returns The call transaction
1505
+ */
1506
+ swapAndBridge: (params) => {
1507
+ return this.appClient.createTransaction.call(BridgeParamsFactory.swapAndBridge(params));
1508
+ },
1509
+ /**
1510
+ * Makes a call to the Bridge smart contract using the `swapAndBridgeWithStable(axfer,byte[32],byte,byte[32],byte[32],uint64,uint64)void` ABI method.
1511
+ *
1512
+ * @param params The params for the smart contract call
1513
+ * @returns The call transaction
1514
+ */
1515
+ swapAndBridgeWithStable: (params) => {
1516
+ return this.appClient.createTransaction.call(BridgeParamsFactory.swapAndBridgeWithStable(params));
1517
+ },
1518
+ /**
1519
+ * Makes a call to the Bridge smart contract using the `receiveTokens(pay,uint64,byte[32],byte,byte[32],byte[32],uint64)void` ABI method.
1520
+ *
1521
+ * @param params The params for the smart contract call
1522
+ * @returns The call transaction
1523
+ */
1524
+ receiveTokens: (params) => {
1525
+ return this.appClient.createTransaction.call(BridgeParamsFactory.receiveTokens(params));
1526
+ },
1527
+ /**
1528
+ * Makes a call to the Bridge smart contract using the `registerBridge(byte,byte[32])void` ABI method.
1529
+ *
1530
+ * @param params The params for the smart contract call
1531
+ * @returns The call transaction
1532
+ */
1533
+ registerBridge: (params) => {
1534
+ return this.appClient.createTransaction.call(BridgeParamsFactory.registerBridge(params));
1535
+ },
1536
+ /**
1537
+ * Makes a call to the Bridge smart contract using the `addBridgeToken(byte,byte[32])void` ABI method.
1538
+ *
1539
+ * @param params The params for the smart contract call
1540
+ * @returns The call transaction
1541
+ */
1542
+ addBridgeToken: (params) => {
1543
+ return this.appClient.createTransaction.call(BridgeParamsFactory.addBridgeToken(params));
1544
+ },
1545
+ /**
1546
+ * Makes a call to the Bridge smart contract using the `removeBridgeToken(byte,byte[32])void` ABI method.
1547
+ *
1548
+ * @param params The params for the smart contract call
1549
+ * @returns The call transaction
1550
+ */
1551
+ removeBridgeToken: (params) => {
1552
+ return this.appClient.createTransaction.call(BridgeParamsFactory.removeBridgeToken(params));
1553
+ },
1554
+ /**
1555
+ * Makes a call to the Bridge smart contract using the `withdrawGasTokens(uint64)void` ABI method.
1556
+ *
1557
+ * @param params The params for the smart contract call
1558
+ * @returns The call transaction
1559
+ */
1560
+ withdrawGasTokens: (params) => {
1561
+ return this.appClient.createTransaction.call(BridgeParamsFactory.withdrawGasTokens(params));
1562
+ },
1563
+ /**
1564
+ * Makes a call to the Bridge smart contract using the `withdrawBridgingFeeInTokens(uint64)void` ABI method.
1565
+ *
1566
+ * @param params The params for the smart contract call
1567
+ * @returns The call transaction
1568
+ */
1569
+ withdrawBridgingFeeInTokens: (params) => {
1570
+ return this.appClient.createTransaction.call(BridgeParamsFactory.withdrawBridgingFeeInTokens(params));
1571
+ },
1572
+ /**
1573
+ * Makes a call to the Bridge smart contract using the `getBridgingCostInTokens(byte,uint64)uint64` ABI method.
1574
+ *
1575
+ * This method is a readonly method; calling it with onComplete of NoOp will result in a simulated transaction rather than a real transaction.
1576
+ *
1577
+ * @param params The params for the smart contract call
1578
+ * @returns The call transaction
1579
+ */
1580
+ getBridgingCostInTokens: (params) => {
1581
+ return this.appClient.createTransaction.call(BridgeParamsFactory.getBridgingCostInTokens(params));
1582
+ },
1583
+ /**
1584
+ * Makes a call to the Bridge smart contract using the `hashMessage(uint64,byte[32],byte,byte,byte[32],byte[32])byte[32]` ABI method.
1585
+ *
1586
+ * This method is a readonly method; calling it with onComplete of NoOp will result in a simulated transaction rather than a real transaction.
1587
+ *
1588
+ * @param params The params for the smart contract call
1589
+ * @returns The call transaction
1590
+ */
1591
+ hashMessage: (params) => {
1592
+ return this.appClient.createTransaction.call(BridgeParamsFactory.hashMessage(params));
1593
+ },
1594
+ /**
1595
+ * Makes a call to the Bridge smart contract using the `isOtherBridgeTokenSupported(byte,byte[32])bool` ABI method.
1596
+ *
1597
+ * This method is a readonly method; calling it with onComplete of NoOp will result in a simulated transaction rather than a real transaction.
1598
+ *
1599
+ * @param params The params for the smart contract call
1600
+ * @returns The call transaction
1601
+ */
1602
+ isOtherBridgeTokenSupported: (params) => {
1603
+ return this.appClient.createTransaction.call(BridgeParamsFactory.isOtherBridgeTokenSupported(params));
1604
+ },
1605
+ /**
1606
+ * Makes a call to the Bridge smart contract using the `getTransactionCost(byte)uint64` ABI method.
1607
+ *
1608
+ * This method is a readonly method; calling it with onComplete of NoOp will result in a simulated transaction rather than a real transaction.
1609
+ *
1610
+ * @param params The params for the smart contract call
1611
+ * @returns The call transaction
1612
+ */
1613
+ getTransactionCost: (params) => {
1614
+ return this.appClient.createTransaction.call(BridgeParamsFactory.getTransactionCost(params));
1615
+ },
1616
+ /**
1617
+ * Makes a call to the Bridge smart contract using the `getReceiveTokensCost()uint64` ABI method.
1618
+ *
1619
+ * This method is a readonly method; calling it with onComplete of NoOp will result in a simulated transaction rather than a real transaction.
1620
+ *
1621
+ * @param params The params for the smart contract call
1622
+ * @returns The call transaction
1623
+ */
1624
+ getReceiveTokensCost: (params = { args: [] }) => {
1625
+ return this.appClient.createTransaction.call(BridgeParamsFactory.getReceiveTokensCost(params));
1626
+ },
1627
+ /**
1628
+ * Makes a call to the Bridge smart contract using the `getSendTransactionStorageCost()uint64` ABI method.
1629
+ *
1630
+ * This method is a readonly method; calling it with onComplete of NoOp will result in a simulated transaction rather than a real transaction.
1631
+ *
1632
+ * @param params The params for the smart contract call
1633
+ * @returns The call transaction
1634
+ */
1635
+ getSendTransactionStorageCost: (params = { args: [] }) => {
1636
+ return this.appClient.createTransaction.call(BridgeParamsFactory.getSendTransactionStorageCost(params));
1637
+ },
1638
+ /**
1639
+ * Makes a call to the Bridge smart contract using the `swap(axfer,uint64,address,uint64,uint64)void` ABI method.
1640
+ *
1641
+ * @param params The params for the smart contract call
1642
+ * @returns The call transaction
1643
+ */
1644
+ swap: (params) => {
1645
+ return this.appClient.createTransaction.call(BridgeParamsFactory.swap(params));
1646
+ },
1647
+ /**
1648
+ * Makes a call to the Bridge smart contract using the `addPool(uint64,uint64)void` ABI method.
1649
+ *
1650
+ * @param params The params for the smart contract call
1651
+ * @returns The call transaction
1652
+ */
1653
+ addPool: (params) => {
1654
+ return this.appClient.createTransaction.call(BridgeParamsFactory.addPool(params));
1655
+ },
1656
+ /**
1657
+ * Makes a call to the Bridge smart contract using the `removePool(uint64)void` ABI method.
1658
+ *
1659
+ * @param params The params for the smart contract call
1660
+ * @returns The call transaction
1661
+ */
1662
+ removePool: (params) => {
1663
+ return this.appClient.createTransaction.call(BridgeParamsFactory.removePool(params));
1664
+ },
1665
+ /**
1666
+ * Makes a call to the Bridge smart contract using the `stopSwap()void` ABI method.
1667
+ *
1668
+ * @param params The params for the smart contract call
1669
+ * @returns The call transaction
1670
+ */
1671
+ stopSwap: (params = { args: [] }) => {
1672
+ return this.appClient.createTransaction.call(BridgeParamsFactory.stopSwap(params));
1673
+ },
1674
+ /**
1675
+ * Makes a call to the Bridge smart contract using the `startSwap()void` ABI method.
1676
+ *
1677
+ * @param params The params for the smart contract call
1678
+ * @returns The call transaction
1679
+ */
1680
+ startSwap: (params = { args: [] }) => {
1681
+ return this.appClient.createTransaction.call(BridgeParamsFactory.startSwap(params));
1682
+ },
1683
+ /**
1684
+ * Makes a call to the Bridge smart contract using the `setStopAuthority(address)void` ABI method.
1685
+ *
1686
+ * @param params The params for the smart contract call
1687
+ * @returns The call transaction
1688
+ */
1689
+ setStopAuthority: (params) => {
1690
+ return this.appClient.createTransaction.call(BridgeParamsFactory.setStopAuthority(params));
1691
+ },
1692
+ /**
1693
+ * Makes a call to the Bridge smart contract using the `setRebalancer(address)void` ABI method.
1694
+ *
1695
+ * @param params The params for the smart contract call
1696
+ * @returns The call transaction
1697
+ */
1698
+ setRebalancer: (params) => {
1699
+ return this.appClient.createTransaction.call(BridgeParamsFactory.setRebalancer(params));
1700
+ },
1701
+ /**
1702
+ * Makes a call to the Bridge smart contract using the `getGasUsage(byte)uint64` ABI method.
1703
+ *
1704
+ * This method is a readonly method; calling it with onComplete of NoOp will result in a simulated transaction rather than a real transaction.
1705
+ *
1706
+ * @param params The params for the smart contract call
1707
+ * @returns The call transaction
1708
+ */
1709
+ getGasUsage: (params) => {
1710
+ return this.appClient.createTransaction.call(BridgeParamsFactory.getGasUsage(params));
1711
+ },
1712
+ /**
1713
+ * Makes a call to the Bridge smart contract using the `setGasUsage(byte,uint64)void` ABI method.
1714
+ *
1715
+ * @param params The params for the smart contract call
1716
+ * @returns The call transaction
1717
+ */
1718
+ setGasUsage: (params) => {
1719
+ return this.appClient.createTransaction.call(BridgeParamsFactory.setGasUsage(params));
1720
+ },
1721
+ /**
1722
+ * Makes a call to the Bridge smart contract using the `setGasOracle(uint64)void` ABI method.
1723
+ *
1724
+ * @param params The params for the smart contract call
1725
+ * @returns The call transaction
1726
+ */
1727
+ setGasOracle: (params) => {
1728
+ return this.appClient.createTransaction.call(BridgeParamsFactory.setGasOracle(params));
1729
+ },
1730
+ /**
1731
+ * Makes a call to the Bridge smart contract using the `getTransactionRelayerCost(byte)uint64` ABI method.
1732
+ *
1733
+ * This method is a readonly method; calling it with onComplete of NoOp will result in a simulated transaction rather than a real transaction.
1734
+ *
1735
+ * @param params The params for the smart contract call
1736
+ * @returns The call transaction
1737
+ */
1738
+ getTransactionRelayerCost: (params) => {
1739
+ return this.appClient.createTransaction.call(BridgeParamsFactory.getTransactionRelayerCost(params));
1740
+ },
1741
+ /**
1742
+ * Makes a call to the Bridge smart contract using the `transferOwnership(address)void` ABI method.
1743
+ *
1744
+ * @param params The params for the smart contract call
1745
+ * @returns The call transaction
1746
+ */
1747
+ transferOwnership: (params) => {
1748
+ return this.appClient.createTransaction.call(BridgeParamsFactory.transferOwnership(params));
1749
+ },
1750
+ };
1751
+ /**
1752
+ * Send calls to the current app
1753
+ */
1754
+ send = {
1755
+ /**
1756
+ * Makes a clear_state call to an existing instance of the Bridge smart contract.
1757
+ *
1758
+ * @param params The params for the bare (raw) call
1759
+ * @returns The clearState result
1760
+ */
1761
+ clearState: (params) => {
1762
+ return this.appClient.send.bare.clearState(params);
1763
+ },
1764
+ /**
1765
+ * Makes a call to the Bridge smart contract using the `optInAsset(uint64)void` ABI method.
1766
+ *
1767
+ * @param params The params for the smart contract call
1768
+ * @returns The call result
1769
+ */
1770
+ optInAsset: async (params) => {
1771
+ const result = await this.appClient.send.call(BridgeParamsFactory.optInAsset(params));
1772
+ return { ...result, return: result.return };
1773
+ },
1774
+ /**
1775
+ * Makes a call to the Bridge smart contract using the `swapAndBridge(pay,axfer,byte[32],byte,byte[32],byte[32],uint64)void` ABI method.
1776
+ *
1777
+ * @param params The params for the smart contract call
1778
+ * @returns The call result
1779
+ */
1780
+ swapAndBridge: async (params) => {
1781
+ const result = await this.appClient.send.call(BridgeParamsFactory.swapAndBridge(params));
1782
+ return {
1783
+ ...result,
1784
+ return: result.return,
1785
+ };
1786
+ },
1787
+ /**
1788
+ * Makes a call to the Bridge smart contract using the `swapAndBridgeWithStable(axfer,byte[32],byte,byte[32],byte[32],uint64,uint64)void` ABI method.
1789
+ *
1790
+ * @param params The params for the smart contract call
1791
+ * @returns The call result
1792
+ */
1793
+ swapAndBridgeWithStable: async (params) => {
1794
+ const result = await this.appClient.send.call(BridgeParamsFactory.swapAndBridgeWithStable(params));
1795
+ return {
1796
+ ...result,
1797
+ return: result.return,
1798
+ };
1799
+ },
1800
+ /**
1801
+ * Makes a call to the Bridge smart contract using the `receiveTokens(pay,uint64,byte[32],byte,byte[32],byte[32],uint64)void` ABI method.
1802
+ *
1803
+ * @param params The params for the smart contract call
1804
+ * @returns The call result
1805
+ */
1806
+ receiveTokens: async (params) => {
1807
+ const result = await this.appClient.send.call(BridgeParamsFactory.receiveTokens(params));
1808
+ return {
1809
+ ...result,
1810
+ return: result.return,
1811
+ };
1812
+ },
1813
+ /**
1814
+ * Makes a call to the Bridge smart contract using the `registerBridge(byte,byte[32])void` ABI method.
1815
+ *
1816
+ * @param params The params for the smart contract call
1817
+ * @returns The call result
1818
+ */
1819
+ registerBridge: async (params) => {
1820
+ const result = await this.appClient.send.call(BridgeParamsFactory.registerBridge(params));
1821
+ return {
1822
+ ...result,
1823
+ return: result.return,
1824
+ };
1825
+ },
1826
+ /**
1827
+ * Makes a call to the Bridge smart contract using the `addBridgeToken(byte,byte[32])void` ABI method.
1828
+ *
1829
+ * @param params The params for the smart contract call
1830
+ * @returns The call result
1831
+ */
1832
+ addBridgeToken: async (params) => {
1833
+ const result = await this.appClient.send.call(BridgeParamsFactory.addBridgeToken(params));
1834
+ return {
1835
+ ...result,
1836
+ return: result.return,
1837
+ };
1838
+ },
1839
+ /**
1840
+ * Makes a call to the Bridge smart contract using the `removeBridgeToken(byte,byte[32])void` ABI method.
1841
+ *
1842
+ * @param params The params for the smart contract call
1843
+ * @returns The call result
1844
+ */
1845
+ removeBridgeToken: async (params) => {
1846
+ const result = await this.appClient.send.call(BridgeParamsFactory.removeBridgeToken(params));
1847
+ return {
1848
+ ...result,
1849
+ return: result.return,
1850
+ };
1851
+ },
1852
+ /**
1853
+ * Makes a call to the Bridge smart contract using the `withdrawGasTokens(uint64)void` ABI method.
1854
+ *
1855
+ * @param params The params for the smart contract call
1856
+ * @returns The call result
1857
+ */
1858
+ withdrawGasTokens: async (params) => {
1859
+ const result = await this.appClient.send.call(BridgeParamsFactory.withdrawGasTokens(params));
1860
+ return {
1861
+ ...result,
1862
+ return: result.return,
1863
+ };
1864
+ },
1865
+ /**
1866
+ * Makes a call to the Bridge smart contract using the `withdrawBridgingFeeInTokens(uint64)void` ABI method.
1867
+ *
1868
+ * @param params The params for the smart contract call
1869
+ * @returns The call result
1870
+ */
1871
+ withdrawBridgingFeeInTokens: async (params) => {
1872
+ const result = await this.appClient.send.call(BridgeParamsFactory.withdrawBridgingFeeInTokens(params));
1873
+ return {
1874
+ ...result,
1875
+ return: result.return,
1876
+ };
1877
+ },
1878
+ /**
1879
+ * Makes a call to the Bridge smart contract using the `getBridgingCostInTokens(byte,uint64)uint64` ABI method.
1880
+ *
1881
+ * This method is a readonly method; calling it with onComplete of NoOp will result in a simulated transaction rather than a real transaction.
1882
+ *
1883
+ * @param params The params for the smart contract call
1884
+ * @returns The call result
1885
+ */
1886
+ getBridgingCostInTokens: async (params) => {
1887
+ const result = await this.appClient.send.call(BridgeParamsFactory.getBridgingCostInTokens(params));
1888
+ return {
1889
+ ...result,
1890
+ return: result.return,
1891
+ };
1892
+ },
1893
+ /**
1894
+ * Makes a call to the Bridge smart contract using the `hashMessage(uint64,byte[32],byte,byte,byte[32],byte[32])byte[32]` ABI method.
1895
+ *
1896
+ * This method is a readonly method; calling it with onComplete of NoOp will result in a simulated transaction rather than a real transaction.
1897
+ *
1898
+ * @param params The params for the smart contract call
1899
+ * @returns The call result
1900
+ */
1901
+ hashMessage: async (params) => {
1902
+ const result = await this.appClient.send.call(BridgeParamsFactory.hashMessage(params));
1903
+ return {
1904
+ ...result,
1905
+ return: result.return,
1906
+ };
1907
+ },
1908
+ /**
1909
+ * Makes a call to the Bridge smart contract using the `isOtherBridgeTokenSupported(byte,byte[32])bool` ABI method.
1910
+ *
1911
+ * This method is a readonly method; calling it with onComplete of NoOp will result in a simulated transaction rather than a real transaction.
1912
+ *
1913
+ * @param params The params for the smart contract call
1914
+ * @returns The call result
1915
+ */
1916
+ isOtherBridgeTokenSupported: async (params) => {
1917
+ const result = await this.appClient.send.call(BridgeParamsFactory.isOtherBridgeTokenSupported(params));
1918
+ return {
1919
+ ...result,
1920
+ return: result.return,
1921
+ };
1922
+ },
1923
+ /**
1924
+ * Makes a call to the Bridge smart contract using the `getTransactionCost(byte)uint64` ABI method.
1925
+ *
1926
+ * This method is a readonly method; calling it with onComplete of NoOp will result in a simulated transaction rather than a real transaction.
1927
+ *
1928
+ * @param params The params for the smart contract call
1929
+ * @returns The call result
1930
+ */
1931
+ getTransactionCost: async (params) => {
1932
+ const result = await this.appClient.send.call(BridgeParamsFactory.getTransactionCost(params));
1933
+ return {
1934
+ ...result,
1935
+ return: result.return,
1936
+ };
1937
+ },
1938
+ /**
1939
+ * Makes a call to the Bridge smart contract using the `getReceiveTokensCost()uint64` ABI method.
1940
+ *
1941
+ * This method is a readonly method; calling it with onComplete of NoOp will result in a simulated transaction rather than a real transaction.
1942
+ *
1943
+ * @param params The params for the smart contract call
1944
+ * @returns The call result
1945
+ */
1946
+ getReceiveTokensCost: async (params = { args: [] }) => {
1947
+ const result = await this.appClient.send.call(BridgeParamsFactory.getReceiveTokensCost(params));
1948
+ return {
1949
+ ...result,
1950
+ return: result.return,
1951
+ };
1952
+ },
1953
+ /**
1954
+ * Makes a call to the Bridge smart contract using the `getSendTransactionStorageCost()uint64` ABI method.
1955
+ *
1956
+ * This method is a readonly method; calling it with onComplete of NoOp will result in a simulated transaction rather than a real transaction.
1957
+ *
1958
+ * @param params The params for the smart contract call
1959
+ * @returns The call result
1960
+ */
1961
+ getSendTransactionStorageCost: async (params = { args: [] }) => {
1962
+ const result = await this.appClient.send.call(BridgeParamsFactory.getSendTransactionStorageCost(params));
1963
+ return {
1964
+ ...result,
1965
+ return: result.return,
1966
+ };
1967
+ },
1968
+ /**
1969
+ * Makes a call to the Bridge smart contract using the `swap(axfer,uint64,address,uint64,uint64)void` ABI method.
1970
+ *
1971
+ * @param params The params for the smart contract call
1972
+ * @returns The call result
1973
+ */
1974
+ swap: async (params) => {
1975
+ const result = await this.appClient.send.call(BridgeParamsFactory.swap(params));
1976
+ return {
1977
+ ...result,
1978
+ return: result.return,
1979
+ };
1980
+ },
1981
+ /**
1982
+ * Makes a call to the Bridge smart contract using the `addPool(uint64,uint64)void` ABI method.
1983
+ *
1984
+ * @param params The params for the smart contract call
1985
+ * @returns The call result
1986
+ */
1987
+ addPool: async (params) => {
1988
+ const result = await this.appClient.send.call(BridgeParamsFactory.addPool(params));
1989
+ return { ...result, return: result.return };
1990
+ },
1991
+ /**
1992
+ * Makes a call to the Bridge smart contract using the `removePool(uint64)void` ABI method.
1993
+ *
1994
+ * @param params The params for the smart contract call
1995
+ * @returns The call result
1996
+ */
1997
+ removePool: async (params) => {
1998
+ const result = await this.appClient.send.call(BridgeParamsFactory.removePool(params));
1999
+ return { ...result, return: result.return };
2000
+ },
2001
+ /**
2002
+ * Makes a call to the Bridge smart contract using the `stopSwap()void` ABI method.
2003
+ *
2004
+ * @param params The params for the smart contract call
2005
+ * @returns The call result
2006
+ */
2007
+ stopSwap: async (params = { args: [] }) => {
2008
+ const result = await this.appClient.send.call(BridgeParamsFactory.stopSwap(params));
2009
+ return { ...result, return: result.return };
2010
+ },
2011
+ /**
2012
+ * Makes a call to the Bridge smart contract using the `startSwap()void` ABI method.
2013
+ *
2014
+ * @param params The params for the smart contract call
2015
+ * @returns The call result
2016
+ */
2017
+ startSwap: async (params = { args: [] }) => {
2018
+ const result = await this.appClient.send.call(BridgeParamsFactory.startSwap(params));
2019
+ return { ...result, return: result.return };
2020
+ },
2021
+ /**
2022
+ * Makes a call to the Bridge smart contract using the `setStopAuthority(address)void` ABI method.
2023
+ *
2024
+ * @param params The params for the smart contract call
2025
+ * @returns The call result
2026
+ */
2027
+ setStopAuthority: async (params) => {
2028
+ const result = await this.appClient.send.call(BridgeParamsFactory.setStopAuthority(params));
2029
+ return {
2030
+ ...result,
2031
+ return: result.return,
2032
+ };
2033
+ },
2034
+ /**
2035
+ * Makes a call to the Bridge smart contract using the `setRebalancer(address)void` ABI method.
2036
+ *
2037
+ * @param params The params for the smart contract call
2038
+ * @returns The call result
2039
+ */
2040
+ setRebalancer: async (params) => {
2041
+ const result = await this.appClient.send.call(BridgeParamsFactory.setRebalancer(params));
2042
+ return { ...result, return: result.return };
2043
+ },
2044
+ /**
2045
+ * Makes a call to the Bridge smart contract using the `getGasUsage(byte)uint64` ABI method.
2046
+ *
2047
+ * This method is a readonly method; calling it with onComplete of NoOp will result in a simulated transaction rather than a real transaction.
2048
+ *
2049
+ * @param params The params for the smart contract call
2050
+ * @returns The call result
2051
+ */
2052
+ getGasUsage: async (params) => {
2053
+ const result = await this.appClient.send.call(BridgeParamsFactory.getGasUsage(params));
2054
+ return { ...result, return: result.return };
2055
+ },
2056
+ /**
2057
+ * Makes a call to the Bridge smart contract using the `setGasUsage(byte,uint64)void` ABI method.
2058
+ *
2059
+ * @param params The params for the smart contract call
2060
+ * @returns The call result
2061
+ */
2062
+ setGasUsage: async (params) => {
2063
+ const result = await this.appClient.send.call(BridgeParamsFactory.setGasUsage(params));
2064
+ return {
2065
+ ...result,
2066
+ return: result.return,
2067
+ };
2068
+ },
2069
+ /**
2070
+ * Makes a call to the Bridge smart contract using the `setGasOracle(uint64)void` ABI method.
2071
+ *
2072
+ * @param params The params for the smart contract call
2073
+ * @returns The call result
2074
+ */
2075
+ setGasOracle: async (params) => {
2076
+ const result = await this.appClient.send.call(BridgeParamsFactory.setGasOracle(params));
2077
+ return { ...result, return: result.return };
2078
+ },
2079
+ /**
2080
+ * Makes a call to the Bridge smart contract using the `getTransactionRelayerCost(byte)uint64` ABI method.
2081
+ *
2082
+ * This method is a readonly method; calling it with onComplete of NoOp will result in a simulated transaction rather than a real transaction.
2083
+ *
2084
+ * @param params The params for the smart contract call
2085
+ * @returns The call result
2086
+ */
2087
+ getTransactionRelayerCost: async (params) => {
2088
+ const result = await this.appClient.send.call(BridgeParamsFactory.getTransactionRelayerCost(params));
2089
+ return {
2090
+ ...result,
2091
+ return: result.return,
2092
+ };
2093
+ },
2094
+ /**
2095
+ * Makes a call to the Bridge smart contract using the `transferOwnership(address)void` ABI method.
2096
+ *
2097
+ * @param params The params for the smart contract call
2098
+ * @returns The call result
2099
+ */
2100
+ transferOwnership: async (params) => {
2101
+ const result = await this.appClient.send.call(BridgeParamsFactory.transferOwnership(params));
2102
+ return {
2103
+ ...result,
2104
+ return: result.return,
2105
+ };
2106
+ },
2107
+ };
2108
+ /**
2109
+ * Clone this app client with different params
2110
+ *
2111
+ * @param params The params to use for the the cloned app client. Omit a param to keep the original value. Set a param to override the original value. Setting to undefined will clear the original value.
2112
+ * @returns A new app client with the altered params
2113
+ */
2114
+ clone(params) {
2115
+ return new BridgeClient(this.appClient.clone(params));
2116
+ }
2117
+ /**
2118
+ * Makes a readonly (simulated) call to the Bridge smart contract using the `getBridgingCostInTokens(byte,uint64)uint64` ABI method.
2119
+ *
2120
+ * This method is a readonly method; calling it with onComplete of NoOp will result in a simulated transaction rather than a real transaction.
2121
+ *
2122
+ * @param params The params for the smart contract call
2123
+ * @returns The call result
2124
+ */
2125
+ async getBridgingCostInTokens(params) {
2126
+ const result = await this.appClient.send.call(BridgeParamsFactory.getBridgingCostInTokens(params));
2127
+ return result.return;
2128
+ }
2129
+ /**
2130
+ * Makes a readonly (simulated) call to the Bridge smart contract using the `hashMessage(uint64,byte[32],byte,byte,byte[32],byte[32])byte[32]` ABI method.
2131
+ *
2132
+ * This method is a readonly method; calling it with onComplete of NoOp will result in a simulated transaction rather than a real transaction.
2133
+ *
2134
+ * @param params The params for the smart contract call
2135
+ * @returns The call result
2136
+ */
2137
+ async hashMessage(params) {
2138
+ const result = await this.appClient.send.call(BridgeParamsFactory.hashMessage(params));
2139
+ return result.return;
2140
+ }
2141
+ /**
2142
+ * Makes a readonly (simulated) call to the Bridge smart contract using the `isOtherBridgeTokenSupported(byte,byte[32])bool` ABI method.
2143
+ *
2144
+ * This method is a readonly method; calling it with onComplete of NoOp will result in a simulated transaction rather than a real transaction.
2145
+ *
2146
+ * @param params The params for the smart contract call
2147
+ * @returns The call result
2148
+ */
2149
+ async isOtherBridgeTokenSupported(params) {
2150
+ const result = await this.appClient.send.call(BridgeParamsFactory.isOtherBridgeTokenSupported(params));
2151
+ return result.return;
2152
+ }
2153
+ /**
2154
+ * Makes a readonly (simulated) call to the Bridge smart contract using the `getTransactionCost(byte)uint64` ABI method.
2155
+ *
2156
+ * This method is a readonly method; calling it with onComplete of NoOp will result in a simulated transaction rather than a real transaction.
2157
+ *
2158
+ * @param params The params for the smart contract call
2159
+ * @returns The call result
2160
+ */
2161
+ async getTransactionCost(params) {
2162
+ const result = await this.appClient.send.call(BridgeParamsFactory.getTransactionCost(params));
2163
+ return result.return;
2164
+ }
2165
+ /**
2166
+ * Makes a readonly (simulated) call to the Bridge smart contract using the `getReceiveTokensCost()uint64` ABI method.
2167
+ *
2168
+ * This method is a readonly method; calling it with onComplete of NoOp will result in a simulated transaction rather than a real transaction.
2169
+ *
2170
+ * @param params The params for the smart contract call
2171
+ * @returns The call result
2172
+ */
2173
+ async getReceiveTokensCost(params = { args: [] }) {
2174
+ const result = await this.appClient.send.call(BridgeParamsFactory.getReceiveTokensCost(params));
2175
+ return result.return;
2176
+ }
2177
+ /**
2178
+ * Makes a readonly (simulated) call to the Bridge smart contract using the `getSendTransactionStorageCost()uint64` ABI method.
2179
+ *
2180
+ * This method is a readonly method; calling it with onComplete of NoOp will result in a simulated transaction rather than a real transaction.
2181
+ *
2182
+ * @param params The params for the smart contract call
2183
+ * @returns The call result
2184
+ */
2185
+ async getSendTransactionStorageCost(params = { args: [] }) {
2186
+ const result = await this.appClient.send.call(BridgeParamsFactory.getSendTransactionStorageCost(params));
2187
+ return result.return;
2188
+ }
2189
+ /**
2190
+ * Makes a readonly (simulated) call to the Bridge smart contract using the `getGasUsage(byte)uint64` ABI method.
2191
+ *
2192
+ * This method is a readonly method; calling it with onComplete of NoOp will result in a simulated transaction rather than a real transaction.
2193
+ *
2194
+ * @param params The params for the smart contract call
2195
+ * @returns The call result
2196
+ */
2197
+ async getGasUsage(params) {
2198
+ const result = await this.appClient.send.call(BridgeParamsFactory.getGasUsage(params));
2199
+ return result.return;
2200
+ }
2201
+ /**
2202
+ * Makes a readonly (simulated) call to the Bridge smart contract using the `getTransactionRelayerCost(byte)uint64` ABI method.
2203
+ *
2204
+ * This method is a readonly method; calling it with onComplete of NoOp will result in a simulated transaction rather than a real transaction.
2205
+ *
2206
+ * @param params The params for the smart contract call
2207
+ * @returns The call result
2208
+ */
2209
+ async getTransactionRelayerCost(params) {
2210
+ const result = await this.appClient.send.call(BridgeParamsFactory.getTransactionRelayerCost(params));
2211
+ return result.return;
2212
+ }
2213
+ /**
2214
+ * Methods to access state for the current Bridge app
2215
+ */
2216
+ state = {
2217
+ /**
2218
+ * Methods to access global state for the current Bridge app
2219
+ */
2220
+ global: {
2221
+ /**
2222
+ * Get all current keyed values from global state
2223
+ */
2224
+ getAll: async () => {
2225
+ const result = await this.appClient.state.global.getAll();
2226
+ return {
2227
+ chainId: result.chainId,
2228
+ messenger: result.messenger,
2229
+ stopAuthority: result.stopAuthority,
2230
+ rebalancer: result.rebalancer,
2231
+ canSwap: result.canSwap,
2232
+ gasOracle: result.gasOracle,
2233
+ owner: result.owner,
2234
+ };
2235
+ },
2236
+ /**
2237
+ * Get the current value of the chainId key in global state
2238
+ */
2239
+ chainId: async () => {
2240
+ return (await this.appClient.state.global.getValue("chainId"));
2241
+ },
2242
+ /**
2243
+ * Get the current value of the messenger key in global state
2244
+ */
2245
+ messenger: async () => {
2246
+ return (await this.appClient.state.global.getValue("messenger"));
2247
+ },
2248
+ /**
2249
+ * Get the current value of the stopAuthority key in global state
2250
+ */
2251
+ stopAuthority: async () => {
2252
+ return (await this.appClient.state.global.getValue("stopAuthority"));
2253
+ },
2254
+ /**
2255
+ * Get the current value of the rebalancer key in global state
2256
+ */
2257
+ rebalancer: async () => {
2258
+ return (await this.appClient.state.global.getValue("rebalancer"));
2259
+ },
2260
+ /**
2261
+ * Get the current value of the canSwap key in global state
2262
+ */
2263
+ canSwap: async () => {
2264
+ return (await this.appClient.state.global.getValue("canSwap"));
2265
+ },
2266
+ /**
2267
+ * Get the current value of the gasOracle key in global state
2268
+ */
2269
+ gasOracle: async () => {
2270
+ return (await this.appClient.state.global.getValue("gasOracle"));
2271
+ },
2272
+ /**
2273
+ * Get the current value of the owner key in global state
2274
+ */
2275
+ owner: async () => {
2276
+ return (await this.appClient.state.global.getValue("owner"));
2277
+ },
2278
+ },
2279
+ /**
2280
+ * Methods to access box state for the current Bridge app
2281
+ */
2282
+ box: {
2283
+ /**
2284
+ * Get all current keyed values from box state
2285
+ */
2286
+ getAll: async () => {
2287
+ const result = await this.appClient.state.box.getAll();
2288
+ return {};
2289
+ },
2290
+ /**
2291
+ * Get values from the processedMessages map in box state
2292
+ */
2293
+ processedMessages: {
2294
+ /**
2295
+ * Get all current values of the processedMessages map in box state
2296
+ */
2297
+ getMap: async () => {
2298
+ return (await this.appClient.state.box.getMap("processedMessages"));
2299
+ },
2300
+ /**
2301
+ * Get a current value of the processedMessages map by key from box state
2302
+ */
2303
+ value: async (key) => {
2304
+ return (await this.appClient.state.box.getMapValue("processedMessages", key));
2305
+ },
2306
+ },
2307
+ /**
2308
+ * Get values from the sentMessages map in box state
2309
+ */
2310
+ sentMessages: {
2311
+ /**
2312
+ * Get all current values of the sentMessages map in box state
2313
+ */
2314
+ getMap: async () => {
2315
+ return (await this.appClient.state.box.getMap("sentMessages"));
2316
+ },
2317
+ /**
2318
+ * Get a current value of the sentMessages map by key from box state
2319
+ */
2320
+ value: async (key) => {
2321
+ return (await this.appClient.state.box.getMapValue("sentMessages", key));
2322
+ },
2323
+ },
2324
+ /**
2325
+ * Get values from the otherBridges map in box state
2326
+ */
2327
+ otherBridges: {
2328
+ /**
2329
+ * Get all current values of the otherBridges map in box state
2330
+ */
2331
+ getMap: async () => {
2332
+ return (await this.appClient.state.box.getMap("otherBridges"));
2333
+ },
2334
+ /**
2335
+ * Get a current value of the otherBridges map by key from box state
2336
+ */
2337
+ value: async (key) => {
2338
+ return (await this.appClient.state.box.getMapValue("otherBridges", key));
2339
+ },
2340
+ },
2341
+ /**
2342
+ * Get values from the otherBridgeTokens map in box state
2343
+ */
2344
+ otherBridgeTokens: {
2345
+ /**
2346
+ * Get all current values of the otherBridgeTokens map in box state
2347
+ */
2348
+ getMap: async () => {
2349
+ return (await this.appClient.state.box.getMap("otherBridgeTokens"));
2350
+ },
2351
+ /**
2352
+ * Get a current value of the otherBridgeTokens map by key from box state
2353
+ */
2354
+ value: async (key) => {
2355
+ return (await this.appClient.state.box.getMapValue("otherBridgeTokens", key));
2356
+ },
2357
+ },
2358
+ /**
2359
+ * Get values from the pools map in box state
2360
+ */
2361
+ pools: {
2362
+ /**
2363
+ * Get all current values of the pools map in box state
2364
+ */
2365
+ getMap: async () => {
2366
+ return (await this.appClient.state.box.getMap("pools"));
2367
+ },
2368
+ /**
2369
+ * Get a current value of the pools map by key from box state
2370
+ */
2371
+ value: async (key) => {
2372
+ return (await this.appClient.state.box.getMapValue("pools", key));
2373
+ },
2374
+ },
2375
+ /**
2376
+ * Get values from the fromGasOracleScalingFactor map in box state
2377
+ */
2378
+ fromGasOracleScalingFactor: {
2379
+ /**
2380
+ * Get all current values of the fromGasOracleScalingFactor map in box state
2381
+ */
2382
+ getMap: async () => {
2383
+ return (await this.appClient.state.box.getMap("fromGasOracleScalingFactor"));
2384
+ },
2385
+ /**
2386
+ * Get a current value of the fromGasOracleScalingFactor map by key from box state
2387
+ */
2388
+ value: async (key) => {
2389
+ return (await this.appClient.state.box.getMapValue("fromGasOracleScalingFactor", key));
2390
+ },
2391
+ },
2392
+ /**
2393
+ * Get values from the bridgingFeeConversionScalingFactor map in box state
2394
+ */
2395
+ bridgingFeeConversionScalingFactor: {
2396
+ /**
2397
+ * Get all current values of the bridgingFeeConversionScalingFactor map in box state
2398
+ */
2399
+ getMap: async () => {
2400
+ return (await this.appClient.state.box.getMap("bridgingFeeConversionScalingFactor"));
2401
+ },
2402
+ /**
2403
+ * Get a current value of the bridgingFeeConversionScalingFactor map by key from box state
2404
+ */
2405
+ value: async (key) => {
2406
+ return (await this.appClient.state.box.getMapValue("bridgingFeeConversionScalingFactor", key));
2407
+ },
2408
+ },
2409
+ /**
2410
+ * Get values from the gasUsage map in box state
2411
+ */
2412
+ gasUsage: {
2413
+ /**
2414
+ * Get all current values of the gasUsage map in box state
2415
+ */
2416
+ getMap: async () => {
2417
+ return (await this.appClient.state.box.getMap("gasUsage"));
2418
+ },
2419
+ /**
2420
+ * Get a current value of the gasUsage map by key from box state
2421
+ */
2422
+ value: async (key) => {
2423
+ return (await this.appClient.state.box.getMapValue("gasUsage", key));
2424
+ },
2425
+ },
2426
+ },
2427
+ };
2428
+ newGroup() {
2429
+ const client = this;
2430
+ const composer = this.algorand.newGroup();
2431
+ let promiseChain = Promise.resolve();
2432
+ const resultMappers = [];
2433
+ return {
2434
+ /**
2435
+ * Add a optInAsset(uint64)void method call against the Bridge contract
2436
+ */
2437
+ optInAsset(params) {
2438
+ promiseChain = promiseChain.then(async () => composer.addAppCallMethodCall(await client.params.optInAsset(params)));
2439
+ resultMappers.push(undefined);
2440
+ return this;
2441
+ },
2442
+ /**
2443
+ * Add a swapAndBridge(pay,axfer,byte[32],byte,byte[32],byte[32],uint64)void method call against the Bridge contract
2444
+ */
2445
+ swapAndBridge(params) {
2446
+ promiseChain = promiseChain.then(async () => composer.addAppCallMethodCall(await client.params.swapAndBridge(params)));
2447
+ resultMappers.push(undefined);
2448
+ return this;
2449
+ },
2450
+ /**
2451
+ * Add a swapAndBridgeWithStable(axfer,byte[32],byte,byte[32],byte[32],uint64,uint64)void method call against the Bridge contract
2452
+ */
2453
+ swapAndBridgeWithStable(params) {
2454
+ promiseChain = promiseChain.then(async () => composer.addAppCallMethodCall(await client.params.swapAndBridgeWithStable(params)));
2455
+ resultMappers.push(undefined);
2456
+ return this;
2457
+ },
2458
+ /**
2459
+ * Add a receiveTokens(pay,uint64,byte[32],byte,byte[32],byte[32],uint64)void method call against the Bridge contract
2460
+ */
2461
+ receiveTokens(params) {
2462
+ promiseChain = promiseChain.then(async () => composer.addAppCallMethodCall(await client.params.receiveTokens(params)));
2463
+ resultMappers.push(undefined);
2464
+ return this;
2465
+ },
2466
+ /**
2467
+ * Add a registerBridge(byte,byte[32])void method call against the Bridge contract
2468
+ */
2469
+ registerBridge(params) {
2470
+ promiseChain = promiseChain.then(async () => composer.addAppCallMethodCall(await client.params.registerBridge(params)));
2471
+ resultMappers.push(undefined);
2472
+ return this;
2473
+ },
2474
+ /**
2475
+ * Add a addBridgeToken(byte,byte[32])void method call against the Bridge contract
2476
+ */
2477
+ addBridgeToken(params) {
2478
+ promiseChain = promiseChain.then(async () => composer.addAppCallMethodCall(await client.params.addBridgeToken(params)));
2479
+ resultMappers.push(undefined);
2480
+ return this;
2481
+ },
2482
+ /**
2483
+ * Add a removeBridgeToken(byte,byte[32])void method call against the Bridge contract
2484
+ */
2485
+ removeBridgeToken(params) {
2486
+ promiseChain = promiseChain.then(async () => composer.addAppCallMethodCall(await client.params.removeBridgeToken(params)));
2487
+ resultMappers.push(undefined);
2488
+ return this;
2489
+ },
2490
+ /**
2491
+ * Add a withdrawGasTokens(uint64)void method call against the Bridge contract
2492
+ */
2493
+ withdrawGasTokens(params) {
2494
+ promiseChain = promiseChain.then(async () => composer.addAppCallMethodCall(await client.params.withdrawGasTokens(params)));
2495
+ resultMappers.push(undefined);
2496
+ return this;
2497
+ },
2498
+ /**
2499
+ * Add a withdrawBridgingFeeInTokens(uint64)void method call against the Bridge contract
2500
+ */
2501
+ withdrawBridgingFeeInTokens(params) {
2502
+ promiseChain = promiseChain.then(async () => composer.addAppCallMethodCall(await client.params.withdrawBridgingFeeInTokens(params)));
2503
+ resultMappers.push(undefined);
2504
+ return this;
2505
+ },
2506
+ /**
2507
+ * Add a getBridgingCostInTokens(byte,uint64)uint64 method call against the Bridge contract
2508
+ */
2509
+ getBridgingCostInTokens(params) {
2510
+ promiseChain = promiseChain.then(async () => composer.addAppCallMethodCall(await client.params.getBridgingCostInTokens(params)));
2511
+ resultMappers.push((v) => client.decodeReturnValue("getBridgingCostInTokens(byte,uint64)uint64", v));
2512
+ return this;
2513
+ },
2514
+ /**
2515
+ * Add a hashMessage(uint64,byte[32],byte,byte,byte[32],byte[32])byte[32] method call against the Bridge contract
2516
+ */
2517
+ hashMessage(params) {
2518
+ promiseChain = promiseChain.then(async () => composer.addAppCallMethodCall(await client.params.hashMessage(params)));
2519
+ resultMappers.push((v) => client.decodeReturnValue("hashMessage(uint64,byte[32],byte,byte,byte[32],byte[32])byte[32]", v));
2520
+ return this;
2521
+ },
2522
+ /**
2523
+ * Add a isOtherBridgeTokenSupported(byte,byte[32])bool method call against the Bridge contract
2524
+ */
2525
+ isOtherBridgeTokenSupported(params) {
2526
+ promiseChain = promiseChain.then(async () => composer.addAppCallMethodCall(await client.params.isOtherBridgeTokenSupported(params)));
2527
+ resultMappers.push((v) => client.decodeReturnValue("isOtherBridgeTokenSupported(byte,byte[32])bool", v));
2528
+ return this;
2529
+ },
2530
+ /**
2531
+ * Add a getTransactionCost(byte)uint64 method call against the Bridge contract
2532
+ */
2533
+ getTransactionCost(params) {
2534
+ promiseChain = promiseChain.then(async () => composer.addAppCallMethodCall(await client.params.getTransactionCost(params)));
2535
+ resultMappers.push((v) => client.decodeReturnValue("getTransactionCost(byte)uint64", v));
2536
+ return this;
2537
+ },
2538
+ /**
2539
+ * Add a getReceiveTokensCost()uint64 method call against the Bridge contract
2540
+ */
2541
+ getReceiveTokensCost(params) {
2542
+ promiseChain = promiseChain.then(async () => composer.addAppCallMethodCall(await client.params.getReceiveTokensCost(params)));
2543
+ resultMappers.push((v) => client.decodeReturnValue("getReceiveTokensCost()uint64", v));
2544
+ return this;
2545
+ },
2546
+ /**
2547
+ * Add a getSendTransactionStorageCost()uint64 method call against the Bridge contract
2548
+ */
2549
+ getSendTransactionStorageCost(params) {
2550
+ promiseChain = promiseChain.then(async () => composer.addAppCallMethodCall(await client.params.getSendTransactionStorageCost(params)));
2551
+ resultMappers.push((v) => client.decodeReturnValue("getSendTransactionStorageCost()uint64", v));
2552
+ return this;
2553
+ },
2554
+ /**
2555
+ * Add a swap(axfer,uint64,address,uint64,uint64)void method call against the Bridge contract
2556
+ */
2557
+ swap(params) {
2558
+ promiseChain = promiseChain.then(async () => composer.addAppCallMethodCall(await client.params.swap(params)));
2559
+ resultMappers.push(undefined);
2560
+ return this;
2561
+ },
2562
+ /**
2563
+ * Add a addPool(uint64,uint64)void method call against the Bridge contract
2564
+ */
2565
+ addPool(params) {
2566
+ promiseChain = promiseChain.then(async () => composer.addAppCallMethodCall(await client.params.addPool(params)));
2567
+ resultMappers.push(undefined);
2568
+ return this;
2569
+ },
2570
+ /**
2571
+ * Add a removePool(uint64)void method call against the Bridge contract
2572
+ */
2573
+ removePool(params) {
2574
+ promiseChain = promiseChain.then(async () => composer.addAppCallMethodCall(await client.params.removePool(params)));
2575
+ resultMappers.push(undefined);
2576
+ return this;
2577
+ },
2578
+ /**
2579
+ * Add a stopSwap()void method call against the Bridge contract
2580
+ */
2581
+ stopSwap(params) {
2582
+ promiseChain = promiseChain.then(async () => composer.addAppCallMethodCall(await client.params.stopSwap(params)));
2583
+ resultMappers.push(undefined);
2584
+ return this;
2585
+ },
2586
+ /**
2587
+ * Add a startSwap()void method call against the Bridge contract
2588
+ */
2589
+ startSwap(params) {
2590
+ promiseChain = promiseChain.then(async () => composer.addAppCallMethodCall(await client.params.startSwap(params)));
2591
+ resultMappers.push(undefined);
2592
+ return this;
2593
+ },
2594
+ /**
2595
+ * Add a setStopAuthority(address)void method call against the Bridge contract
2596
+ */
2597
+ setStopAuthority(params) {
2598
+ promiseChain = promiseChain.then(async () => composer.addAppCallMethodCall(await client.params.setStopAuthority(params)));
2599
+ resultMappers.push(undefined);
2600
+ return this;
2601
+ },
2602
+ /**
2603
+ * Add a setRebalancer(address)void method call against the Bridge contract
2604
+ */
2605
+ setRebalancer(params) {
2606
+ promiseChain = promiseChain.then(async () => composer.addAppCallMethodCall(await client.params.setRebalancer(params)));
2607
+ resultMappers.push(undefined);
2608
+ return this;
2609
+ },
2610
+ /**
2611
+ * Add a getGasUsage(byte)uint64 method call against the Bridge contract
2612
+ */
2613
+ getGasUsage(params) {
2614
+ promiseChain = promiseChain.then(async () => composer.addAppCallMethodCall(await client.params.getGasUsage(params)));
2615
+ resultMappers.push((v) => client.decodeReturnValue("getGasUsage(byte)uint64", v));
2616
+ return this;
2617
+ },
2618
+ /**
2619
+ * Add a setGasUsage(byte,uint64)void method call against the Bridge contract
2620
+ */
2621
+ setGasUsage(params) {
2622
+ promiseChain = promiseChain.then(async () => composer.addAppCallMethodCall(await client.params.setGasUsage(params)));
2623
+ resultMappers.push(undefined);
2624
+ return this;
2625
+ },
2626
+ /**
2627
+ * Add a setGasOracle(uint64)void method call against the Bridge contract
2628
+ */
2629
+ setGasOracle(params) {
2630
+ promiseChain = promiseChain.then(async () => composer.addAppCallMethodCall(await client.params.setGasOracle(params)));
2631
+ resultMappers.push(undefined);
2632
+ return this;
2633
+ },
2634
+ /**
2635
+ * Add a getTransactionRelayerCost(byte)uint64 method call against the Bridge contract
2636
+ */
2637
+ getTransactionRelayerCost(params) {
2638
+ promiseChain = promiseChain.then(async () => composer.addAppCallMethodCall(await client.params.getTransactionRelayerCost(params)));
2639
+ resultMappers.push((v) => client.decodeReturnValue("getTransactionRelayerCost(byte)uint64", v));
2640
+ return this;
2641
+ },
2642
+ /**
2643
+ * Add a transferOwnership(address)void method call against the Bridge contract
2644
+ */
2645
+ transferOwnership(params) {
2646
+ promiseChain = promiseChain.then(async () => composer.addAppCallMethodCall(await client.params.transferOwnership(params)));
2647
+ resultMappers.push(undefined);
2648
+ return this;
2649
+ },
2650
+ /**
2651
+ * Add a clear state call to the Bridge contract
2652
+ */
2653
+ clearState(params) {
2654
+ promiseChain = promiseChain.then(() => composer.addAppCall(client.params.clearState(params)));
2655
+ return this;
2656
+ },
2657
+ addTransaction(txn, signer) {
2658
+ promiseChain = promiseChain.then(() => composer.addTransaction(txn, signer));
2659
+ return this;
2660
+ },
2661
+ async composer() {
2662
+ await promiseChain;
2663
+ return composer;
2664
+ },
2665
+ async simulate(options) {
2666
+ await promiseChain;
2667
+ const result = await (!options ? composer.simulate() : composer.simulate(options));
2668
+ return {
2669
+ ...result,
2670
+ returns: result.returns?.map((val, i) => resultMappers[i] !== undefined ? resultMappers[i](val) : val.returnValue),
2671
+ };
2672
+ },
2673
+ async send(params) {
2674
+ await promiseChain;
2675
+ const result = await composer.send(params);
2676
+ return {
2677
+ ...result,
2678
+ returns: result.returns?.map((val, i) => resultMappers[i] !== undefined ? resultMappers[i](val) : val.returnValue),
2679
+ };
2680
+ },
2681
+ };
2682
+ }
2683
+ }
2684
+ exports.BridgeClient = BridgeClient;
2685
+ //# sourceMappingURL=BridgeClient.js.map