@layerzerolabs/lz-v2-stellar-sdk 0.2.13 → 0.2.18

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 (107) hide show
  1. package/.turbo/turbo-build.log +1 -0
  2. package/.turbo/turbo-test.log +1009 -0
  3. package/dist/generated/bml.d.ts +104 -37
  4. package/dist/generated/bml.js +83 -42
  5. package/dist/generated/counter.d.ts +334 -175
  6. package/dist/generated/counter.js +109 -63
  7. package/dist/generated/dvn.d.ts +1985 -0
  8. package/dist/generated/dvn.js +326 -0
  9. package/dist/generated/dvn_fee_lib.d.ts +690 -0
  10. package/dist/generated/dvn_fee_lib.js +163 -0
  11. package/dist/generated/endpoint.d.ts +155 -46
  12. package/dist/generated/endpoint.js +93 -50
  13. package/dist/generated/executor.d.ts +1841 -0
  14. package/dist/generated/executor.js +312 -0
  15. package/dist/generated/executor_fee_lib.d.ts +1083 -0
  16. package/dist/generated/executor_fee_lib.js +255 -0
  17. package/dist/generated/executor_helper.d.ts +981 -0
  18. package/dist/generated/executor_helper.js +236 -0
  19. package/dist/generated/oft_std.d.ts +1722 -0
  20. package/dist/generated/oft_std.js +316 -0
  21. package/dist/generated/price_feed.d.ts +1077 -0
  22. package/dist/generated/price_feed.js +210 -0
  23. package/dist/generated/sml.d.ts +171 -56
  24. package/dist/generated/sml.js +111 -62
  25. package/dist/generated/treasury.d.ts +896 -0
  26. package/dist/generated/treasury.js +219 -0
  27. package/dist/generated/uln302.d.ts +175 -75
  28. package/dist/generated/uln302.js +126 -82
  29. package/dist/generated/upgrader.d.ts +70 -0
  30. package/dist/generated/upgrader.js +19 -0
  31. package/dist/index.d.ts +10 -0
  32. package/dist/index.js +14 -0
  33. package/dist/wasm/blocked-message-lib.d.ts +1 -0
  34. package/dist/wasm/blocked-message-lib.js +2 -0
  35. package/dist/wasm/counter.d.ts +1 -0
  36. package/dist/wasm/counter.js +2 -0
  37. package/dist/wasm/dvn-fee-lib.d.ts +1 -0
  38. package/dist/wasm/dvn-fee-lib.js +2 -0
  39. package/dist/wasm/dvn.d.ts +1 -0
  40. package/dist/wasm/dvn.js +2 -0
  41. package/dist/wasm/endpoint-v2.d.ts +1 -0
  42. package/dist/wasm/endpoint-v2.js +2 -0
  43. package/dist/wasm/executor-fee-lib.d.ts +1 -0
  44. package/dist/wasm/executor-fee-lib.js +2 -0
  45. package/dist/wasm/executor-helper.d.ts +1 -0
  46. package/dist/wasm/executor-helper.js +2 -0
  47. package/dist/wasm/executor.d.ts +1 -0
  48. package/dist/wasm/executor.js +2 -0
  49. package/dist/wasm/layerzero-views.d.ts +1 -0
  50. package/dist/wasm/layerzero-views.js +2 -0
  51. package/dist/wasm/oft-std.d.ts +1 -0
  52. package/dist/wasm/oft-std.js +2 -0
  53. package/dist/wasm/price-feed.d.ts +1 -0
  54. package/dist/wasm/price-feed.js +2 -0
  55. package/dist/wasm/simple-message-lib.d.ts +1 -0
  56. package/dist/wasm/simple-message-lib.js +2 -0
  57. package/dist/wasm/treasury.d.ts +1 -0
  58. package/dist/wasm/treasury.js +2 -0
  59. package/dist/wasm/uln302.d.ts +1 -0
  60. package/dist/wasm/uln302.js +2 -0
  61. package/dist/wasm/upgrader.d.ts +1 -0
  62. package/dist/wasm/upgrader.js +2 -0
  63. package/dist/wasm.d.ts +15 -0
  64. package/dist/wasm.js +15 -0
  65. package/package.json +12 -9
  66. package/src/generated/bml.ts +117 -66
  67. package/src/generated/counter.ts +338 -191
  68. package/src/generated/dvn.ts +2036 -0
  69. package/src/generated/dvn_fee_lib.ts +693 -0
  70. package/src/generated/endpoint.ts +177 -80
  71. package/src/generated/executor.ts +228 -127
  72. package/src/generated/executor_fee_lib.ts +1072 -0
  73. package/src/generated/executor_helper.ts +163 -57
  74. package/src/generated/oft_std.ts +800 -246
  75. package/src/generated/price_feed.ts +1108 -0
  76. package/src/generated/sml.ts +194 -91
  77. package/src/generated/treasury.ts +943 -0
  78. package/src/generated/uln302.ts +211 -113
  79. package/src/generated/upgrader.ts +102 -0
  80. package/src/index.ts +17 -0
  81. package/src/wasm/blocked-message-lib.ts +2 -0
  82. package/src/wasm/counter.ts +2 -0
  83. package/src/wasm/dvn-fee-lib.ts +2 -0
  84. package/src/wasm/dvn.ts +2 -0
  85. package/src/wasm/endpoint-v2.ts +2 -0
  86. package/src/wasm/executor-fee-lib.ts +2 -0
  87. package/src/wasm/executor-helper.ts +2 -0
  88. package/src/wasm/executor.ts +2 -0
  89. package/src/wasm/layerzero-views.ts +2 -0
  90. package/src/wasm/oft-std.ts +2 -0
  91. package/src/wasm/price-feed.ts +2 -0
  92. package/src/wasm/simple-message-lib.ts +2 -0
  93. package/src/wasm/treasury.ts +2 -0
  94. package/src/wasm/uln302.ts +2 -0
  95. package/src/wasm/upgrader.ts +2 -0
  96. package/src/wasm.ts +15 -0
  97. package/test/counter-sml.test.ts +376 -0
  98. package/test/counter-uln.test.ts +493 -0
  99. package/test/{oft.test.ts → oft-sml.test.ts} +187 -323
  100. package/test/suites/constants.ts +22 -2
  101. package/test/suites/dummyContractClient.ts +169 -0
  102. package/test/suites/globalSetup.ts +450 -0
  103. package/test/suites/localnet.ts +23 -6
  104. package/test/upgrader.test.ts +300 -0
  105. package/test/utils.ts +558 -85
  106. package/vitest.config.ts +21 -0
  107. package/test/index.test.ts +0 -376
@@ -0,0 +1,1108 @@
1
+ import { Buffer } from "buffer";
2
+ import { Address } from '@stellar/stellar-sdk';
3
+ import {
4
+ AssembledTransaction,
5
+ Client as ContractClient,
6
+ ClientOptions as ContractClientOptions,
7
+ MethodOptions,
8
+ Result,
9
+ Spec as ContractSpec,
10
+ } from '@stellar/stellar-sdk/contract';
11
+ import type {
12
+ u32,
13
+ i32,
14
+ u64,
15
+ i64,
16
+ u128,
17
+ i128,
18
+ u256,
19
+ i256,
20
+ Option,
21
+ Typepoint,
22
+ Duration,
23
+ } from '@stellar/stellar-sdk/contract';
24
+ export * from '@stellar/stellar-sdk'
25
+ export * as contract from '@stellar/stellar-sdk/contract'
26
+ export * as rpc from '@stellar/stellar-sdk/rpc'
27
+
28
+ export type MigrationData = void;
29
+
30
+
31
+ export type PriceFeedStorage = {tag: "PriceRatioDenominator", values: void} | {tag: "PriceUpdater", values: readonly [string]} | {tag: "DefaultModelPrice", values: readonly [u32]} | {tag: "ArbitrumPriceExt", values: void} | {tag: "NativePriceUSD", values: void} | {tag: "ArbitrumCompressionPercent", values: void} | {tag: "EidToModelType", values: readonly [u32]};
32
+
33
+ export const PriceFeedError = {
34
+ 1: {message:"InvalidDenominator"},
35
+ 2: {message:"NoPrice"},
36
+ 3: {message:"NotAnOpStack"},
37
+ 4: {message:"OnlyPriceUpdater"},
38
+ 5: {message:"Overflow"}
39
+ }
40
+
41
+
42
+
43
+
44
+
45
+ /**
46
+ * Arbitrum-specific price extension
47
+ */
48
+ export interface ArbitrumPriceExt {
49
+ /**
50
+ * Gas cost per byte of L1 calldata (for Arbitrum's L1 data posting)
51
+ */
52
+ gas_per_l1_calldata_byte: u32;
53
+ /**
54
+ * Gas overhead per L2 transaction
55
+ */
56
+ gas_per_l2_tx: u64;
57
+ }
58
+
59
+
60
+ /**
61
+ * Parameter for updating a single price
62
+ */
63
+ export interface UpdatePrice {
64
+ /**
65
+ * Destination endpoint ID
66
+ */
67
+ eid: u32;
68
+ /**
69
+ * Price information for the destination
70
+ */
71
+ price: Price;
72
+ }
73
+
74
+
75
+ /**
76
+ * Parameter for updating Arbitrum price with extension
77
+ */
78
+ export interface UpdatePriceExt {
79
+ /**
80
+ * Destination endpoint ID (should be an Arbitrum endpoint)
81
+ */
82
+ eid: u32;
83
+ /**
84
+ * Arbitrum-specific pricing extension
85
+ */
86
+ extend: ArbitrumPriceExt;
87
+ /**
88
+ * Price information for the destination
89
+ */
90
+ price: Price;
91
+ }
92
+
93
+ /**
94
+ * Fee model type for different chain architectures
95
+ */
96
+ export enum ModelType {
97
+ Default = 0,
98
+ ArbStack = 1,
99
+ OpStack = 2,
100
+ }
101
+
102
+
103
+ /**
104
+ * Parameter for setting EID to model type mapping
105
+ */
106
+ export interface SetEidToModelTypeParam {
107
+ /**
108
+ * Destination endpoint ID
109
+ */
110
+ dst_eid: u32;
111
+ /**
112
+ * Fee model type for this destination
113
+ */
114
+ model_type: ModelType;
115
+ }
116
+
117
+ /**
118
+ * BufferReaderError: 1000-1009
119
+ */
120
+ export const BufferReaderError = {
121
+ 1000: {message:"InvalidLength"},
122
+ 1001: {message:"InvalidAddressPayload"}
123
+ }
124
+
125
+ /**
126
+ * BufferWriterError: 1010-1019
127
+ */
128
+ export const BufferWriterError = {
129
+ 1010: {message:"InvalidAddressPayload"}
130
+ }
131
+
132
+ /**
133
+ * TtlConfigurableError: 1020-1029
134
+ */
135
+ export const TtlConfigurableError = {
136
+ 1020: {message:"InvalidTtlConfig"},
137
+ 1021: {message:"TtlConfigFrozen"},
138
+ 1022: {message:"TtlConfigAlreadyFrozen"}
139
+ }
140
+
141
+ /**
142
+ * OwnableError: 1030-1039
143
+ */
144
+ export const OwnableError = {
145
+ 1030: {message:"OwnerAlreadySet"},
146
+ 1031: {message:"OwnerNotSet"}
147
+ }
148
+
149
+ /**
150
+ * BytesExtError: 1040-1049
151
+ */
152
+ export const BytesExtError = {
153
+ 1040: {message:"LengthMismatch"}
154
+ }
155
+
156
+ /**
157
+ * UpgradeableError: 1050-1059
158
+ */
159
+ export const UpgradeableError = {
160
+ 1050: {message:"MigrationNotAllowed"}
161
+ }
162
+
163
+ /**
164
+ * MultisigError: 1060-1069
165
+ */
166
+ export const MultisigError = {
167
+ 1060: {message:"AlreadyInitialized"},
168
+ 1061: {message:"InvalidSigner"},
169
+ 1062: {message:"SignatureError"},
170
+ 1063: {message:"SignerAlreadyExists"},
171
+ 1064: {message:"SignerNotFound"},
172
+ 1065: {message:"TotalSignersLessThanThreshold"},
173
+ 1066: {message:"UnsortedSigners"},
174
+ 1067: {message:"ZeroThreshold"}
175
+ }
176
+
177
+
178
+
179
+ export type MultisigStorage = {tag: "Signers", values: void} | {tag: "Threshold", values: void};
180
+
181
+
182
+
183
+ export type OwnableStorage = {tag: "Owner", values: void};
184
+
185
+
186
+ /**
187
+ * TTL configuration: threshold (when to extend) and extend_to (target TTL).
188
+ */
189
+ export interface TtlConfig {
190
+ /**
191
+ * Target TTL after extension (in ledgers).
192
+ */
193
+ extend_to: u32;
194
+ /**
195
+ * TTL threshold that triggers extension (in ledgers).
196
+ */
197
+ threshold: u32;
198
+ }
199
+
200
+
201
+
202
+ export type TtlConfigStorage = {tag: "Frozen", values: void} | {tag: "Instance", values: void} | {tag: "Persistent", values: void};
203
+
204
+ export type UpgradeableStorage = {tag: "Migrating", values: void};
205
+
206
+ /**
207
+ * WorkerError: 1200-1299
208
+ */
209
+ export const WorkerError = {
210
+ 1200: {message:"AdminAlreadyExists"},
211
+ 1201: {message:"AdminNotFound"},
212
+ 1202: {message:"AlreadyOnAllowlist"},
213
+ 1203: {message:"AlreadyOnDenylist"},
214
+ 1204: {message:"AttemptingToRemoveOnlyAdmin"},
215
+ 1205: {message:"DepositAddressNotSet"},
216
+ 1206: {message:"MessageLibAlreadySupported"},
217
+ 1207: {message:"MessageLibNotSupported"},
218
+ 1208: {message:"NoAdminsProvided"},
219
+ 1209: {message:"NotAllowed"},
220
+ 1210: {message:"NotOnAllowlist"},
221
+ 1211: {message:"NotOnDenylist"},
222
+ 1212: {message:"PauseStatusUnchanged"},
223
+ 1213: {message:"PriceFeedNotSet"},
224
+ 1214: {message:"ReInitialize"},
225
+ 1215: {message:"Unauthorized"},
226
+ 1216: {message:"UnsupportedMessageLib"},
227
+ 1217: {message:"WorkerFeeLibNotSet"},
228
+ 1218: {message:"WorkerIsPaused"}
229
+ }
230
+
231
+
232
+
233
+
234
+
235
+
236
+
237
+
238
+
239
+
240
+
241
+
242
+
243
+ /**
244
+ * Parameters for DVN fee calculation.
245
+ *
246
+ * Contains all inputs needed by the fee library to calculate verification fees
247
+ * for cross-chain messages. Includes message parameters, common configuration,
248
+ * and destination-specific settings.
249
+ */
250
+ export interface DvnFeeParams {
251
+ /**
252
+ * Number of block confirmations required.
253
+ */
254
+ confirmations: u64;
255
+ /**
256
+ * Default fee multiplier in basis points (used if no dst-specific multiplier).
257
+ */
258
+ default_multiplier_bps: u32;
259
+ /**
260
+ * Destination endpoint ID (chain identifier).
261
+ */
262
+ dst_eid: u32;
263
+ /**
264
+ * Minimum fee margin in USD (scaled).
265
+ */
266
+ floor_margin_usd: u128;
267
+ /**
268
+ * ============================================================================================
269
+ * Destination-Specific Configuration
270
+ * ============================================================================================
271
+ * Gas estimate for verification on destination chain.
272
+ */
273
+ gas: u128;
274
+ /**
275
+ * Destination-specific fee multiplier in basis points (0 = use default).
276
+ */
277
+ multiplier_bps: u32;
278
+ /**
279
+ * DVN options
280
+ */
281
+ options: Buffer;
282
+ /**
283
+ * ============================================================================================
284
+ * Common Configuration
285
+ * ============================================================================================
286
+ * Price feed contract address for gas price and exchange rate data.
287
+ */
288
+ price_feed: string;
289
+ /**
290
+ * Number of required signatures (quorum).
291
+ */
292
+ quorum: u32;
293
+ /**
294
+ * ============================================================================================
295
+ * Message Parameters
296
+ * ============================================================================================
297
+ * The OApp sender address.
298
+ */
299
+ sender: string;
300
+ }
301
+
302
+
303
+ /**
304
+ * Parameters for executor fee calculation.
305
+ *
306
+ * Contains all inputs needed by the fee library to calculate execution fees
307
+ * for cross-chain messages. Includes message parameters, common configuration,
308
+ * and destination-specific settings.
309
+ */
310
+ export interface FeeParams {
311
+ /**
312
+ * Size of the message calldata in bytes.
313
+ */
314
+ calldata_size: u32;
315
+ /**
316
+ * Default fee multiplier in basis points (used if no dst-specific multiplier).
317
+ */
318
+ default_multiplier_bps: u32;
319
+ /**
320
+ * Destination endpoint ID (chain identifier).
321
+ */
322
+ dst_eid: u32;
323
+ /**
324
+ * Minimum fee margin in USD (scaled).
325
+ */
326
+ floor_margin_usd: u128;
327
+ /**
328
+ * Base gas for each lzCompose call on destination chain.
329
+ */
330
+ lz_compose_base_gas: u64;
331
+ /**
332
+ * ============================================================================================
333
+ * Destination-Specific Configuration
334
+ * ============================================================================================
335
+ * Base gas for lzReceive execution on destination chain.
336
+ */
337
+ lz_receive_base_gas: u64;
338
+ /**
339
+ * Destination-specific fee multiplier in basis points (0 = use default).
340
+ */
341
+ multiplier_bps: u32;
342
+ /**
343
+ * Maximum native token value that can be sent.
344
+ */
345
+ native_cap: u128;
346
+ /**
347
+ * Encoded executor options (lzReceive gas, lzCompose, nativeDrop, etc.).
348
+ */
349
+ options: Buffer;
350
+ /**
351
+ * ============================================================================================
352
+ * Common Configuration
353
+ * ============================================================================================
354
+ * Price feed contract address for gas price and exchange rate data.
355
+ */
356
+ price_feed: string;
357
+ /**
358
+ * ============================================================================================
359
+ * Message Parameters
360
+ * ============================================================================================
361
+ * The OApp sender address.
362
+ */
363
+ sender: string;
364
+ }
365
+
366
+
367
+ /**
368
+ * Gas price information for a destination endpoint.
369
+ *
370
+ * Contains the exchange rate and gas costs needed for cross-chain fee calculations.
371
+ */
372
+ export interface Price {
373
+ /**
374
+ * Gas cost per byte of calldata on the destination chain.
375
+ */
376
+ gas_per_byte: u32;
377
+ /**
378
+ * Gas price in the smallest unit (wei for EVM, stroops for Stellar).
379
+ */
380
+ gas_price_in_unit: u64;
381
+ /**
382
+ * Price ratio = (remote native token price / local native token price) * PRICE_RATIO_DENOMINATOR.
383
+ * Used to convert destination chain gas costs to source chain native token.
384
+ */
385
+ price_ratio: u128;
386
+ }
387
+
388
+
389
+ /**
390
+ * Fee estimation result with detailed breakdown.
391
+ *
392
+ * Contains the calculated fee and all intermediate values used in the calculation.
393
+ */
394
+ export interface FeeEstimate {
395
+ /**
396
+ * Source chain native token price in USD (scaled).
397
+ */
398
+ native_price_usd: u128;
399
+ /**
400
+ * Price ratio used for the calculation.
401
+ */
402
+ price_ratio: u128;
403
+ /**
404
+ * Denominator for the price ratio (typically 10^20).
405
+ */
406
+ price_ratio_denominator: u128;
407
+ /**
408
+ * Total gas fee in source chain native token units.
409
+ */
410
+ total_gas_fee: i128;
411
+ }
412
+
413
+ export type WorkerStorage = {tag: "Paused", values: void} | {tag: "DepositAddress", values: void} | {tag: "PriceFeed", values: void} | {tag: "WorkerFeeLib", values: void} | {tag: "DefaultMultiplierBps", values: void} | {tag: "SupportedOptionTypes", values: readonly [u32]} | {tag: "MessageLibs", values: void} | {tag: "Allowlist", values: readonly [string]} | {tag: "Denylist", values: readonly [string]} | {tag: "AllowlistSize", values: void} | {tag: "Admins", values: void};
414
+
415
+ export interface Client {
416
+ /**
417
+ * Construct and simulate a upgrade transaction. Returns an `AssembledTransaction` object which will have a `result` field containing the result of the simulation. If this transaction changes contract state, you will need to call `signAndSend()` on the returned object.
418
+ */
419
+ upgrade: ({new_wasm_hash}: {new_wasm_hash: Buffer}, txnOptions?: {
420
+ /**
421
+ * The fee to pay for the transaction. Default: BASE_FEE
422
+ */
423
+ fee?: number;
424
+
425
+ /**
426
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
427
+ */
428
+ timeoutInSeconds?: number;
429
+
430
+ /**
431
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
432
+ */
433
+ simulate?: boolean;
434
+ }) => Promise<AssembledTransaction<null>>
435
+
436
+ /**
437
+ * Construct and simulate a migrate transaction. Returns an `AssembledTransaction` object which will have a `result` field containing the result of the simulation. If this transaction changes contract state, you will need to call `signAndSend()` on the returned object.
438
+ */
439
+ migrate: ({migration_data}: {migration_data: MigrationData}, txnOptions?: {
440
+ /**
441
+ * The fee to pay for the transaction. Default: BASE_FEE
442
+ */
443
+ fee?: number;
444
+
445
+ /**
446
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
447
+ */
448
+ timeoutInSeconds?: number;
449
+
450
+ /**
451
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
452
+ */
453
+ simulate?: boolean;
454
+ }) => Promise<AssembledTransaction<null>>
455
+
456
+ /**
457
+ * Construct and simulate a authorizer transaction. Returns an `AssembledTransaction` object which will have a `result` field containing the result of the simulation. If this transaction changes contract state, you will need to call `signAndSend()` on the returned object.
458
+ */
459
+ authorizer: (txnOptions?: {
460
+ /**
461
+ * The fee to pay for the transaction. Default: BASE_FEE
462
+ */
463
+ fee?: number;
464
+
465
+ /**
466
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
467
+ */
468
+ timeoutInSeconds?: number;
469
+
470
+ /**
471
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
472
+ */
473
+ simulate?: boolean;
474
+ }) => Promise<AssembledTransaction<string>>
475
+
476
+ /**
477
+ * Construct and simulate a estimate_fee_by_eid transaction. Returns an `AssembledTransaction` object which will have a `result` field containing the result of the simulation. If this transaction changes contract state, you will need to call `signAndSend()` on the returned object.
478
+ * Estimate fee with detailed breakdown by endpoint ID
479
+ * Corresponds to estimateFeeByEid in PriceFeed.sol
480
+ */
481
+ estimate_fee_by_eid: ({fee_lib, dst_eid, calldata_size, gas}: {fee_lib: string, dst_eid: u32, calldata_size: u32, gas: u128}, txnOptions?: {
482
+ /**
483
+ * The fee to pay for the transaction. Default: BASE_FEE
484
+ */
485
+ fee?: number;
486
+
487
+ /**
488
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
489
+ */
490
+ timeoutInSeconds?: number;
491
+
492
+ /**
493
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
494
+ */
495
+ simulate?: boolean;
496
+ }) => Promise<AssembledTransaction<FeeEstimate>>
497
+
498
+ /**
499
+ * Construct and simulate a native_token_price_usd transaction. Returns an `AssembledTransaction` object which will have a `result` field containing the result of the simulation. If this transaction changes contract state, you will need to call `signAndSend()` on the returned object.
500
+ * Get the native token price in USD
501
+ */
502
+ native_token_price_usd: (txnOptions?: {
503
+ /**
504
+ * The fee to pay for the transaction. Default: BASE_FEE
505
+ */
506
+ fee?: number;
507
+
508
+ /**
509
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
510
+ */
511
+ timeoutInSeconds?: number;
512
+
513
+ /**
514
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
515
+ */
516
+ simulate?: boolean;
517
+ }) => Promise<AssembledTransaction<u128>>
518
+
519
+ /**
520
+ * Construct and simulate a get_price transaction. Returns an `AssembledTransaction` object which will have a `result` field containing the result of the simulation. If this transaction changes contract state, you will need to call `signAndSend()` on the returned object.
521
+ * Get the price for a destination EID.
522
+ */
523
+ get_price: ({dst_eid}: {dst_eid: u32}, txnOptions?: {
524
+ /**
525
+ * The fee to pay for the transaction. Default: BASE_FEE
526
+ */
527
+ fee?: number;
528
+
529
+ /**
530
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
531
+ */
532
+ timeoutInSeconds?: number;
533
+
534
+ /**
535
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
536
+ */
537
+ simulate?: boolean;
538
+ }) => Promise<AssembledTransaction<Option<Price>>>
539
+
540
+ /**
541
+ * Construct and simulate a get_price_ratio_denominator transaction. Returns an `AssembledTransaction` object which will have a `result` field containing the result of the simulation. If this transaction changes contract state, you will need to call `signAndSend()` on the returned object.
542
+ * Get the price ratio denominator.
543
+ */
544
+ get_price_ratio_denominator: (txnOptions?: {
545
+ /**
546
+ * The fee to pay for the transaction. Default: BASE_FEE
547
+ */
548
+ fee?: number;
549
+
550
+ /**
551
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
552
+ */
553
+ timeoutInSeconds?: number;
554
+
555
+ /**
556
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
557
+ */
558
+ simulate?: boolean;
559
+ }) => Promise<AssembledTransaction<u128>>
560
+
561
+ /**
562
+ * Construct and simulate a set_price_updater transaction. Returns an `AssembledTransaction` object which will have a `result` field containing the result of the simulation. If this transaction changes contract state, you will need to call `signAndSend()` on the returned object.
563
+ * Set price updater status (owner only)
564
+ */
565
+ set_price_updater: ({updater, active}: {updater: string, active: boolean}, txnOptions?: {
566
+ /**
567
+ * The fee to pay for the transaction. Default: BASE_FEE
568
+ */
569
+ fee?: number;
570
+
571
+ /**
572
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
573
+ */
574
+ timeoutInSeconds?: number;
575
+
576
+ /**
577
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
578
+ */
579
+ simulate?: boolean;
580
+ }) => Promise<AssembledTransaction<null>>
581
+
582
+ /**
583
+ * Construct and simulate a set_price_ratio_denominator transaction. Returns an `AssembledTransaction` object which will have a `result` field containing the result of the simulation. If this transaction changes contract state, you will need to call `signAndSend()` on the returned object.
584
+ * Set the price ratio denominator (owner only)
585
+ */
586
+ set_price_ratio_denominator: ({denominator}: {denominator: u128}, txnOptions?: {
587
+ /**
588
+ * The fee to pay for the transaction. Default: BASE_FEE
589
+ */
590
+ fee?: number;
591
+
592
+ /**
593
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
594
+ */
595
+ timeoutInSeconds?: number;
596
+
597
+ /**
598
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
599
+ */
600
+ simulate?: boolean;
601
+ }) => Promise<AssembledTransaction<null>>
602
+
603
+ /**
604
+ * Construct and simulate a set_arbitrum_compression_percent transaction. Returns an `AssembledTransaction` object which will have a `result` field containing the result of the simulation. If this transaction changes contract state, you will need to call `signAndSend()` on the returned object.
605
+ * Set the Arbitrum compression percentage (owner only)
606
+ */
607
+ set_arbitrum_compression_percent: ({compression_percent}: {compression_percent: u128}, txnOptions?: {
608
+ /**
609
+ * The fee to pay for the transaction. Default: BASE_FEE
610
+ */
611
+ fee?: number;
612
+
613
+ /**
614
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
615
+ */
616
+ timeoutInSeconds?: number;
617
+
618
+ /**
619
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
620
+ */
621
+ simulate?: boolean;
622
+ }) => Promise<AssembledTransaction<null>>
623
+
624
+ /**
625
+ * Construct and simulate a set_eid_to_model_type transaction. Returns an `AssembledTransaction` object which will have a `result` field containing the result of the simulation. If this transaction changes contract state, you will need to call `signAndSend()` on the returned object.
626
+ * Set the fee model type for destination EIDs (owner only)
627
+ */
628
+ set_eid_to_model_type: ({params}: {params: Array<SetEidToModelTypeParam>}, txnOptions?: {
629
+ /**
630
+ * The fee to pay for the transaction. Default: BASE_FEE
631
+ */
632
+ fee?: number;
633
+
634
+ /**
635
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
636
+ */
637
+ timeoutInSeconds?: number;
638
+
639
+ /**
640
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
641
+ */
642
+ simulate?: boolean;
643
+ }) => Promise<AssembledTransaction<null>>
644
+
645
+ /**
646
+ * Construct and simulate a set_price transaction. Returns an `AssembledTransaction` object which will have a `result` field containing the result of the simulation. If this transaction changes contract state, you will need to call `signAndSend()` on the returned object.
647
+ * Set prices for multiple destinations (price updater or owner)
648
+ */
649
+ set_price: ({price_updater, prices}: {price_updater: string, prices: Array<UpdatePrice>}, txnOptions?: {
650
+ /**
651
+ * The fee to pay for the transaction. Default: BASE_FEE
652
+ */
653
+ fee?: number;
654
+
655
+ /**
656
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
657
+ */
658
+ timeoutInSeconds?: number;
659
+
660
+ /**
661
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
662
+ */
663
+ simulate?: boolean;
664
+ }) => Promise<AssembledTransaction<null>>
665
+
666
+ /**
667
+ * Construct and simulate a set_price_for_arbitrum transaction. Returns an `AssembledTransaction` object which will have a `result` field containing the result of the simulation. If this transaction changes contract state, you will need to call `signAndSend()` on the returned object.
668
+ * Set price for Arbitrum with extension (price updater or owner)
669
+ * Corresponds to setPriceForArbitrum in PriceFeed.sol
670
+ */
671
+ set_price_for_arbitrum: ({price_updater, update}: {price_updater: string, update: UpdatePriceExt}, txnOptions?: {
672
+ /**
673
+ * The fee to pay for the transaction. Default: BASE_FEE
674
+ */
675
+ fee?: number;
676
+
677
+ /**
678
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
679
+ */
680
+ timeoutInSeconds?: number;
681
+
682
+ /**
683
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
684
+ */
685
+ simulate?: boolean;
686
+ }) => Promise<AssembledTransaction<null>>
687
+
688
+ /**
689
+ * Construct and simulate a set_native_token_price_usd transaction. Returns an `AssembledTransaction` object which will have a `result` field containing the result of the simulation. If this transaction changes contract state, you will need to call `signAndSend()` on the returned object.
690
+ * Set the native token price in USD (price updater or owner).
691
+ *
692
+ * Kept as a standalone contract function (not part of the canonical `worker::ILayerZeroPriceFeed` interface).
693
+ */
694
+ set_native_token_price_usd: ({price_updater, native_token_price_usd}: {price_updater: string, native_token_price_usd: u128}, txnOptions?: {
695
+ /**
696
+ * The fee to pay for the transaction. Default: BASE_FEE
697
+ */
698
+ fee?: number;
699
+
700
+ /**
701
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
702
+ */
703
+ timeoutInSeconds?: number;
704
+
705
+ /**
706
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
707
+ */
708
+ simulate?: boolean;
709
+ }) => Promise<AssembledTransaction<null>>
710
+
711
+ /**
712
+ * Construct and simulate a is_price_updater transaction. Returns an `AssembledTransaction` object which will have a `result` field containing the result of the simulation. If this transaction changes contract state, you will need to call `signAndSend()` on the returned object.
713
+ * Check if an address is an active price updater
714
+ */
715
+ is_price_updater: ({updater}: {updater: string}, txnOptions?: {
716
+ /**
717
+ * The fee to pay for the transaction. Default: BASE_FEE
718
+ */
719
+ fee?: number;
720
+
721
+ /**
722
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
723
+ */
724
+ timeoutInSeconds?: number;
725
+
726
+ /**
727
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
728
+ */
729
+ simulate?: boolean;
730
+ }) => Promise<AssembledTransaction<boolean>>
731
+
732
+ /**
733
+ * Construct and simulate a arbitrum_compression_percent transaction. Returns an `AssembledTransaction` object which will have a `result` field containing the result of the simulation. If this transaction changes contract state, you will need to call `signAndSend()` on the returned object.
734
+ * Get the Arbitrum compression percent
735
+ */
736
+ arbitrum_compression_percent: (txnOptions?: {
737
+ /**
738
+ * The fee to pay for the transaction. Default: BASE_FEE
739
+ */
740
+ fee?: number;
741
+
742
+ /**
743
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
744
+ */
745
+ timeoutInSeconds?: number;
746
+
747
+ /**
748
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
749
+ */
750
+ simulate?: boolean;
751
+ }) => Promise<AssembledTransaction<u128>>
752
+
753
+ /**
754
+ * Construct and simulate a arbitrum_price_ext transaction. Returns an `AssembledTransaction` object which will have a `result` field containing the result of the simulation. If this transaction changes contract state, you will need to call `signAndSend()` on the returned object.
755
+ * Get the Arbitrum price extension
756
+ */
757
+ arbitrum_price_ext: (txnOptions?: {
758
+ /**
759
+ * The fee to pay for the transaction. Default: BASE_FEE
760
+ */
761
+ fee?: number;
762
+
763
+ /**
764
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
765
+ */
766
+ timeoutInSeconds?: number;
767
+
768
+ /**
769
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
770
+ */
771
+ simulate?: boolean;
772
+ }) => Promise<AssembledTransaction<ArbitrumPriceExt>>
773
+
774
+ /**
775
+ * Construct and simulate a eid_to_model_type transaction. Returns an `AssembledTransaction` object which will have a `result` field containing the result of the simulation. If this transaction changes contract state, you will need to call `signAndSend()` on the returned object.
776
+ * Get the model type for a destination EID
777
+ */
778
+ eid_to_model_type: ({dst_eid}: {dst_eid: u32}, txnOptions?: {
779
+ /**
780
+ * The fee to pay for the transaction. Default: BASE_FEE
781
+ */
782
+ fee?: number;
783
+
784
+ /**
785
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
786
+ */
787
+ timeoutInSeconds?: number;
788
+
789
+ /**
790
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
791
+ */
792
+ simulate?: boolean;
793
+ }) => Promise<AssembledTransaction<ModelType>>
794
+
795
+ /**
796
+ * Construct and simulate a set_ttl_configs transaction. Returns an `AssembledTransaction` object which will have a `result` field containing the result of the simulation. If this transaction changes contract state, you will need to call `signAndSend()` on the returned object.
797
+ * Sets TTL configs for instance and persistent storage.
798
+ *
799
+ * - `None` values remove the corresponding config (disables auto-extension for that type)
800
+ * - Validates that `threshold <= extend_to <= MAX_TTL`
801
+ *
802
+ * # Arguments
803
+ * - `instance` - TTL config for instance storage
804
+ * - `persistent` - TTL config for persistent storage
805
+ *
806
+ * # Panics
807
+ * - `TtlConfigFrozen` if configs are frozen
808
+ * - `InvalidTtlConfig` if validation fails
809
+ */
810
+ set_ttl_configs: ({instance, persistent}: {instance: Option<TtlConfig>, persistent: Option<TtlConfig>}, txnOptions?: {
811
+ /**
812
+ * The fee to pay for the transaction. Default: BASE_FEE
813
+ */
814
+ fee?: number;
815
+
816
+ /**
817
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
818
+ */
819
+ timeoutInSeconds?: number;
820
+
821
+ /**
822
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
823
+ */
824
+ simulate?: boolean;
825
+ }) => Promise<AssembledTransaction<null>>
826
+
827
+ /**
828
+ * Construct and simulate a ttl_configs transaction. Returns an `AssembledTransaction` object which will have a `result` field containing the result of the simulation. If this transaction changes contract state, you will need to call `signAndSend()` on the returned object.
829
+ * Returns the current TTL configs as (instance_config, persistent_config).
830
+ */
831
+ ttl_configs: (txnOptions?: {
832
+ /**
833
+ * The fee to pay for the transaction. Default: BASE_FEE
834
+ */
835
+ fee?: number;
836
+
837
+ /**
838
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
839
+ */
840
+ timeoutInSeconds?: number;
841
+
842
+ /**
843
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
844
+ */
845
+ simulate?: boolean;
846
+ }) => Promise<AssembledTransaction<readonly [Option<TtlConfig>, Option<TtlConfig>]>>
847
+
848
+ /**
849
+ * Construct and simulate a freeze_ttl_configs transaction. Returns an `AssembledTransaction` object which will have a `result` field containing the result of the simulation. If this transaction changes contract state, you will need to call `signAndSend()` on the returned object.
850
+ * Permanently freezes TTL configs, preventing any future modifications.
851
+ *
852
+ * This is irreversible and provides immutability guarantees to users.
853
+ * Emits `TtlConfigsFrozen` event.
854
+ *
855
+ * # Panics
856
+ * - `TtlConfigAlreadyFrozen` if already frozen
857
+ */
858
+ freeze_ttl_configs: (txnOptions?: {
859
+ /**
860
+ * The fee to pay for the transaction. Default: BASE_FEE
861
+ */
862
+ fee?: number;
863
+
864
+ /**
865
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
866
+ */
867
+ timeoutInSeconds?: number;
868
+
869
+ /**
870
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
871
+ */
872
+ simulate?: boolean;
873
+ }) => Promise<AssembledTransaction<null>>
874
+
875
+ /**
876
+ * Construct and simulate a is_ttl_configs_frozen transaction. Returns an `AssembledTransaction` object which will have a `result` field containing the result of the simulation. If this transaction changes contract state, you will need to call `signAndSend()` on the returned object.
877
+ * Returns whether TTL configs are frozen.
878
+ */
879
+ is_ttl_configs_frozen: (txnOptions?: {
880
+ /**
881
+ * The fee to pay for the transaction. Default: BASE_FEE
882
+ */
883
+ fee?: number;
884
+
885
+ /**
886
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
887
+ */
888
+ timeoutInSeconds?: number;
889
+
890
+ /**
891
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
892
+ */
893
+ simulate?: boolean;
894
+ }) => Promise<AssembledTransaction<boolean>>
895
+
896
+ /**
897
+ * Construct and simulate a extend_instance_ttl transaction. Returns an `AssembledTransaction` object which will have a `result` field containing the result of the simulation. If this transaction changes contract state, you will need to call `signAndSend()` on the returned object.
898
+ * Extends the instance TTL.
899
+ *
900
+ * # Arguments
901
+ *
902
+ * * `threshold` - The threshold to extend the TTL (if current TTL is below this, extend).
903
+ * * `extend_to` - The TTL to extend to.
904
+ */
905
+ extend_instance_ttl: ({threshold, extend_to}: {threshold: u32, extend_to: u32}, txnOptions?: {
906
+ /**
907
+ * The fee to pay for the transaction. Default: BASE_FEE
908
+ */
909
+ fee?: number;
910
+
911
+ /**
912
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
913
+ */
914
+ timeoutInSeconds?: number;
915
+
916
+ /**
917
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
918
+ */
919
+ simulate?: boolean;
920
+ }) => Promise<AssembledTransaction<null>>
921
+
922
+ /**
923
+ * Construct and simulate a owner transaction. Returns an `AssembledTransaction` object which will have a `result` field containing the result of the simulation. If this transaction changes contract state, you will need to call `signAndSend()` on the returned object.
924
+ * Returns the current owner address, or None if no owner is set.
925
+ */
926
+ owner: (txnOptions?: {
927
+ /**
928
+ * The fee to pay for the transaction. Default: BASE_FEE
929
+ */
930
+ fee?: number;
931
+
932
+ /**
933
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
934
+ */
935
+ timeoutInSeconds?: number;
936
+
937
+ /**
938
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
939
+ */
940
+ simulate?: boolean;
941
+ }) => Promise<AssembledTransaction<Option<string>>>
942
+
943
+ /**
944
+ * Construct and simulate a transfer_ownership transaction. Returns an `AssembledTransaction` object which will have a `result` field containing the result of the simulation. If this transaction changes contract state, you will need to call `signAndSend()` on the returned object.
945
+ * Transfers ownership to a new address. Requires current owner authorization.
946
+ */
947
+ transfer_ownership: ({new_owner}: {new_owner: string}, txnOptions?: {
948
+ /**
949
+ * The fee to pay for the transaction. Default: BASE_FEE
950
+ */
951
+ fee?: number;
952
+
953
+ /**
954
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
955
+ */
956
+ timeoutInSeconds?: number;
957
+
958
+ /**
959
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
960
+ */
961
+ simulate?: boolean;
962
+ }) => Promise<AssembledTransaction<null>>
963
+
964
+ /**
965
+ * Construct and simulate a renounce_ownership transaction. Returns an `AssembledTransaction` object which will have a `result` field containing the result of the simulation. If this transaction changes contract state, you will need to call `signAndSend()` on the returned object.
966
+ * Permanently renounces ownership. Requires current owner authorization.
967
+ */
968
+ renounce_ownership: (txnOptions?: {
969
+ /**
970
+ * The fee to pay for the transaction. Default: BASE_FEE
971
+ */
972
+ fee?: number;
973
+
974
+ /**
975
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
976
+ */
977
+ timeoutInSeconds?: number;
978
+
979
+ /**
980
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
981
+ */
982
+ simulate?: boolean;
983
+ }) => Promise<AssembledTransaction<null>>
984
+
985
+ }
986
+ export class Client extends ContractClient {
987
+ static async deploy<T = Client>(
988
+ /** Constructor/Initialization Args for the contract's `__constructor` method */
989
+ {owner, price_updater}: {owner: string, price_updater: string},
990
+ /** Options for initializing a Client as well as for calling a method, with extras specific to deploying. */
991
+ options: MethodOptions &
992
+ Omit<ContractClientOptions, "contractId"> & {
993
+ /** The hash of the Wasm blob, which must already be installed on-chain. */
994
+ wasmHash: Buffer | string;
995
+ /** Salt used to generate the contract's ID. Passed through to {@link Operation.createCustomContract}. Default: random. */
996
+ salt?: Buffer | Uint8Array;
997
+ /** The format used to decode `wasmHash`, if it's provided as a string. */
998
+ format?: "hex" | "base64";
999
+ }
1000
+ ): Promise<AssembledTransaction<T>> {
1001
+ return ContractClient.deploy({owner, price_updater}, options)
1002
+ }
1003
+ constructor(public readonly options: ContractClientOptions) {
1004
+ super(
1005
+ new ContractSpec([ "AAAAAgAAAAAAAAAAAAAAEFByaWNlRmVlZFN0b3JhZ2UAAAAHAAAAAAAAAAAAAAAVUHJpY2VSYXRpb0Rlbm9taW5hdG9yAAAAAAAAAQAAAAAAAAAMUHJpY2VVcGRhdGVyAAAAAQAAABMAAAABAAAAAAAAABFEZWZhdWx0TW9kZWxQcmljZQAAAAAAAAEAAAAEAAAAAAAAAAAAAAAQQXJiaXRydW1QcmljZUV4dAAAAAAAAAAAAAAADk5hdGl2ZVByaWNlVVNEAAAAAAAAAAAAAAAAABpBcmJpdHJ1bUNvbXByZXNzaW9uUGVyY2VudAAAAAAAAQAAAAAAAAAORWlkVG9Nb2RlbFR5cGUAAAAAAAEAAAAE",
1006
+ "AAAABAAAAAAAAAAAAAAADlByaWNlRmVlZEVycm9yAAAAAAAFAAAAAAAAABJJbnZhbGlkRGVub21pbmF0b3IAAAAAAAEAAAAAAAAAB05vUHJpY2UAAAAAAgAAAAAAAAAMTm90QW5PcFN0YWNrAAAAAwAAAAAAAAAQT25seVByaWNlVXBkYXRlcgAAAAQAAAAAAAAACE92ZXJmbG93AAAABQ==",
1007
+ "AAAABQAAAAAAAAAAAAAAD1ByaWNlVXBkYXRlclNldAAAAAABAAAAEXByaWNlX3VwZGF0ZXJfc2V0AAAAAAAAAgAAAAAAAAAHdXBkYXRlcgAAAAATAAAAAAAAAAAAAAAGYWN0aXZlAAAAAAABAAAAAAAAAAI=",
1008
+ "AAAABQAAAAAAAAAAAAAADFByaWNlVXBkYXRlZAAAAAEAAAANcHJpY2VfdXBkYXRlZAAAAAAAAAIAAAAAAAAAB2RzdF9laWQAAAAABAAAAAAAAAAAAAAABXByaWNlAAAAAAAH0AAAAAVQcmljZQAAAAAAAAAAAAAC",
1009
+ "AAAABQAAAAAAAAAAAAAAF0FyYml0cnVtUHJpY2VFeHRVcGRhdGVkAAAAAAEAAAAaYXJiaXRydW1fcHJpY2VfZXh0X3VwZGF0ZWQAAAAAAAIAAAAAAAAAB2RzdF9laWQAAAAABAAAAAAAAAAAAAAAEmFyYml0cnVtX3ByaWNlX2V4dAAAAAAH0AAAABBBcmJpdHJ1bVByaWNlRXh0AAAAAAAAAAI=",
1010
+ "AAAAAAAAAAAAAAAHdXBncmFkZQAAAAABAAAAAAAAAA1uZXdfd2FzbV9oYXNoAAAAAAAD7gAAACAAAAAA",
1011
+ "AAAAAAAAAAAAAAAHbWlncmF0ZQAAAAABAAAAAAAAAA5taWdyYXRpb25fZGF0YQAAAAAH0AAAAA1NaWdyYXRpb25EYXRhAAAAAAAAAA==",
1012
+ "AAAAAAAAAAAAAAAKYXV0aG9yaXplcgAAAAAAAAAAAAEAAAAT",
1013
+ "AAAAAAAAAAAAAAANX19jb25zdHJ1Y3RvcgAAAAAAAAIAAAAAAAAABW93bmVyAAAAAAAAEwAAAAAAAAANcHJpY2VfdXBkYXRlcgAAAAAAABMAAAAA",
1014
+ "AAAAAAAAAGRFc3RpbWF0ZSBmZWUgd2l0aCBkZXRhaWxlZCBicmVha2Rvd24gYnkgZW5kcG9pbnQgSUQKQ29ycmVzcG9uZHMgdG8gZXN0aW1hdGVGZWVCeUVpZCBpbiBQcmljZUZlZWQuc29sAAAAE2VzdGltYXRlX2ZlZV9ieV9laWQAAAAABAAAAAAAAAAHZmVlX2xpYgAAAAATAAAAAAAAAAdkc3RfZWlkAAAAAAQAAAAAAAAADWNhbGxkYXRhX3NpemUAAAAAAAAEAAAAAAAAAANnYXMAAAAACgAAAAEAAAfQAAAAC0ZlZUVzdGltYXRlAA==",
1015
+ "AAAAAAAAACFHZXQgdGhlIG5hdGl2ZSB0b2tlbiBwcmljZSBpbiBVU0QAAAAAAAAWbmF0aXZlX3Rva2VuX3ByaWNlX3VzZAAAAAAAAAAAAAEAAAAK",
1016
+ "AAAAAAAAACRHZXQgdGhlIHByaWNlIGZvciBhIGRlc3RpbmF0aW9uIEVJRC4AAAAJZ2V0X3ByaWNlAAAAAAAAAQAAAAAAAAAHZHN0X2VpZAAAAAAEAAAAAQAAA+gAAAfQAAAABVByaWNlAAAA",
1017
+ "AAAAAAAAACBHZXQgdGhlIHByaWNlIHJhdGlvIGRlbm9taW5hdG9yLgAAABtnZXRfcHJpY2VfcmF0aW9fZGVub21pbmF0b3IAAAAAAAAAAAEAAAAK",
1018
+ "AAAAAAAAACVTZXQgcHJpY2UgdXBkYXRlciBzdGF0dXMgKG93bmVyIG9ubHkpAAAAAAAAEXNldF9wcmljZV91cGRhdGVyAAAAAAAAAgAAAAAAAAAHdXBkYXRlcgAAAAATAAAAAAAAAAZhY3RpdmUAAAAAAAEAAAAA",
1019
+ "AAAAAAAAACxTZXQgdGhlIHByaWNlIHJhdGlvIGRlbm9taW5hdG9yIChvd25lciBvbmx5KQAAABtzZXRfcHJpY2VfcmF0aW9fZGVub21pbmF0b3IAAAAAAQAAAAAAAAALZGVub21pbmF0b3IAAAAACgAAAAA=",
1020
+ "AAAAAAAAADRTZXQgdGhlIEFyYml0cnVtIGNvbXByZXNzaW9uIHBlcmNlbnRhZ2UgKG93bmVyIG9ubHkpAAAAIHNldF9hcmJpdHJ1bV9jb21wcmVzc2lvbl9wZXJjZW50AAAAAQAAAAAAAAATY29tcHJlc3Npb25fcGVyY2VudAAAAAAKAAAAAA==",
1021
+ "AAAAAAAAADhTZXQgdGhlIGZlZSBtb2RlbCB0eXBlIGZvciBkZXN0aW5hdGlvbiBFSURzIChvd25lciBvbmx5KQAAABVzZXRfZWlkX3RvX21vZGVsX3R5cGUAAAAAAAABAAAAAAAAAAZwYXJhbXMAAAAAA+oAAAfQAAAAFlNldEVpZFRvTW9kZWxUeXBlUGFyYW0AAAAAAAA=",
1022
+ "AAAAAAAAAD1TZXQgcHJpY2VzIGZvciBtdWx0aXBsZSBkZXN0aW5hdGlvbnMgKHByaWNlIHVwZGF0ZXIgb3Igb3duZXIpAAAAAAAACXNldF9wcmljZQAAAAAAAAIAAAAAAAAADXByaWNlX3VwZGF0ZXIAAAAAAAATAAAAAAAAAAZwcmljZXMAAAAAA+oAAAfQAAAAC1VwZGF0ZVByaWNlAAAAAAA=",
1023
+ "AAAAAAAAAHJTZXQgcHJpY2UgZm9yIEFyYml0cnVtIHdpdGggZXh0ZW5zaW9uIChwcmljZSB1cGRhdGVyIG9yIG93bmVyKQpDb3JyZXNwb25kcyB0byBzZXRQcmljZUZvckFyYml0cnVtIGluIFByaWNlRmVlZC5zb2wAAAAAABZzZXRfcHJpY2VfZm9yX2FyYml0cnVtAAAAAAACAAAAAAAAAA1wcmljZV91cGRhdGVyAAAAAAAAEwAAAAAAAAAGdXBkYXRlAAAAAAfQAAAADlVwZGF0ZVByaWNlRXh0AAAAAAAA",
1024
+ "AAAAAAAAAKhTZXQgdGhlIG5hdGl2ZSB0b2tlbiBwcmljZSBpbiBVU0QgKHByaWNlIHVwZGF0ZXIgb3Igb3duZXIpLgoKS2VwdCBhcyBhIHN0YW5kYWxvbmUgY29udHJhY3QgZnVuY3Rpb24gKG5vdCBwYXJ0IG9mIHRoZSBjYW5vbmljYWwgYHdvcmtlcjo6SUxheWVyWmVyb1ByaWNlRmVlZGAgaW50ZXJmYWNlKS4AAAAac2V0X25hdGl2ZV90b2tlbl9wcmljZV91c2QAAAAAAAIAAAAAAAAADXByaWNlX3VwZGF0ZXIAAAAAAAATAAAAAAAAABZuYXRpdmVfdG9rZW5fcHJpY2VfdXNkAAAAAAAKAAAAAA==",
1025
+ "AAAAAAAAAC5DaGVjayBpZiBhbiBhZGRyZXNzIGlzIGFuIGFjdGl2ZSBwcmljZSB1cGRhdGVyAAAAAAAQaXNfcHJpY2VfdXBkYXRlcgAAAAEAAAAAAAAAB3VwZGF0ZXIAAAAAEwAAAAEAAAAB",
1026
+ "AAAAAAAAACRHZXQgdGhlIEFyYml0cnVtIGNvbXByZXNzaW9uIHBlcmNlbnQAAAAcYXJiaXRydW1fY29tcHJlc3Npb25fcGVyY2VudAAAAAAAAAABAAAACg==",
1027
+ "AAAAAAAAACBHZXQgdGhlIEFyYml0cnVtIHByaWNlIGV4dGVuc2lvbgAAABJhcmJpdHJ1bV9wcmljZV9leHQAAAAAAAAAAAABAAAH0AAAABBBcmJpdHJ1bVByaWNlRXh0",
1028
+ "AAAAAAAAAChHZXQgdGhlIG1vZGVsIHR5cGUgZm9yIGEgZGVzdGluYXRpb24gRUlEAAAAEWVpZF90b19tb2RlbF90eXBlAAAAAAAAAQAAAAAAAAAHZHN0X2VpZAAAAAAEAAAAAQAAB9AAAAAJTW9kZWxUeXBlAAAA",
1029
+ "AAAAAQAAACFBcmJpdHJ1bS1zcGVjaWZpYyBwcmljZSBleHRlbnNpb24AAAAAAAAAAAAAEEFyYml0cnVtUHJpY2VFeHQAAAACAAAAQUdhcyBjb3N0IHBlciBieXRlIG9mIEwxIGNhbGxkYXRhIChmb3IgQXJiaXRydW0ncyBMMSBkYXRhIHBvc3RpbmcpAAAAAAAAGGdhc19wZXJfbDFfY2FsbGRhdGFfYnl0ZQAAAAQAAAAfR2FzIG92ZXJoZWFkIHBlciBMMiB0cmFuc2FjdGlvbgAAAAANZ2FzX3Blcl9sMl90eAAAAAAAAAY=",
1030
+ "AAAAAQAAACVQYXJhbWV0ZXIgZm9yIHVwZGF0aW5nIGEgc2luZ2xlIHByaWNlAAAAAAAAAAAAAAtVcGRhdGVQcmljZQAAAAACAAAAF0Rlc3RpbmF0aW9uIGVuZHBvaW50IElEAAAAAANlaWQAAAAABAAAACVQcmljZSBpbmZvcm1hdGlvbiBmb3IgdGhlIGRlc3RpbmF0aW9uAAAAAAAABXByaWNlAAAAAAAH0AAAAAVQcmljZQAAAA==",
1031
+ "AAAAAQAAADRQYXJhbWV0ZXIgZm9yIHVwZGF0aW5nIEFyYml0cnVtIHByaWNlIHdpdGggZXh0ZW5zaW9uAAAAAAAAAA5VcGRhdGVQcmljZUV4dAAAAAAAAwAAADhEZXN0aW5hdGlvbiBlbmRwb2ludCBJRCAoc2hvdWxkIGJlIGFuIEFyYml0cnVtIGVuZHBvaW50KQAAAANlaWQAAAAABAAAACNBcmJpdHJ1bS1zcGVjaWZpYyBwcmljaW5nIGV4dGVuc2lvbgAAAAAGZXh0ZW5kAAAAAAfQAAAAEEFyYml0cnVtUHJpY2VFeHQAAAAlUHJpY2UgaW5mb3JtYXRpb24gZm9yIHRoZSBkZXN0aW5hdGlvbgAAAAAAAAVwcmljZQAAAAAAB9AAAAAFUHJpY2UAAAA=",
1032
+ "AAAAAwAAADBGZWUgbW9kZWwgdHlwZSBmb3IgZGlmZmVyZW50IGNoYWluIGFyY2hpdGVjdHVyZXMAAAAAAAAACU1vZGVsVHlwZQAAAAAAAAMAAAAAAAAAB0RlZmF1bHQAAAAAAAAAAAAAAAAIQXJiU3RhY2sAAAABAAAAAAAAAAdPcFN0YWNrAAAAAAI=",
1033
+ "AAAAAQAAAC9QYXJhbWV0ZXIgZm9yIHNldHRpbmcgRUlEIHRvIG1vZGVsIHR5cGUgbWFwcGluZwAAAAAAAAAAFlNldEVpZFRvTW9kZWxUeXBlUGFyYW0AAAAAAAIAAAAXRGVzdGluYXRpb24gZW5kcG9pbnQgSUQAAAAAB2RzdF9laWQAAAAABAAAACNGZWUgbW9kZWwgdHlwZSBmb3IgdGhpcyBkZXN0aW5hdGlvbgAAAAAKbW9kZWxfdHlwZQAAAAAH0AAAAAlNb2RlbFR5cGUAAAA=",
1034
+ "AAAAAAAAAY9TZXRzIFRUTCBjb25maWdzIGZvciBpbnN0YW5jZSBhbmQgcGVyc2lzdGVudCBzdG9yYWdlLgoKLSBgTm9uZWAgdmFsdWVzIHJlbW92ZSB0aGUgY29ycmVzcG9uZGluZyBjb25maWcgKGRpc2FibGVzIGF1dG8tZXh0ZW5zaW9uIGZvciB0aGF0IHR5cGUpCi0gVmFsaWRhdGVzIHRoYXQgYHRocmVzaG9sZCA8PSBleHRlbmRfdG8gPD0gTUFYX1RUTGAKCiMgQXJndW1lbnRzCi0gYGluc3RhbmNlYCAtIFRUTCBjb25maWcgZm9yIGluc3RhbmNlIHN0b3JhZ2UKLSBgcGVyc2lzdGVudGAgLSBUVEwgY29uZmlnIGZvciBwZXJzaXN0ZW50IHN0b3JhZ2UKCiMgUGFuaWNzCi0gYFR0bENvbmZpZ0Zyb3plbmAgaWYgY29uZmlncyBhcmUgZnJvemVuCi0gYEludmFsaWRUdGxDb25maWdgIGlmIHZhbGlkYXRpb24gZmFpbHMAAAAAD3NldF90dGxfY29uZmlncwAAAAACAAAAAAAAAAhpbnN0YW5jZQAAA+gAAAfQAAAACVR0bENvbmZpZwAAAAAAAAAAAAAKcGVyc2lzdGVudAAAAAAD6AAAB9AAAAAJVHRsQ29uZmlnAAAAAAAAAA==",
1035
+ "AAAAAAAAAEhSZXR1cm5zIHRoZSBjdXJyZW50IFRUTCBjb25maWdzIGFzIChpbnN0YW5jZV9jb25maWcsIHBlcnNpc3RlbnRfY29uZmlnKS4AAAALdHRsX2NvbmZpZ3MAAAAAAAAAAAEAAAPtAAAAAgAAA+gAAAfQAAAACVR0bENvbmZpZwAAAAAAA+gAAAfQAAAACVR0bENvbmZpZwAAAA==",
1036
+ "AAAAAAAAAOFQZXJtYW5lbnRseSBmcmVlemVzIFRUTCBjb25maWdzLCBwcmV2ZW50aW5nIGFueSBmdXR1cmUgbW9kaWZpY2F0aW9ucy4KClRoaXMgaXMgaXJyZXZlcnNpYmxlIGFuZCBwcm92aWRlcyBpbW11dGFiaWxpdHkgZ3VhcmFudGVlcyB0byB1c2Vycy4KRW1pdHMgYFR0bENvbmZpZ3NGcm96ZW5gIGV2ZW50LgoKIyBQYW5pY3MKLSBgVHRsQ29uZmlnQWxyZWFkeUZyb3plbmAgaWYgYWxyZWFkeSBmcm96ZW4AAAAAAAASZnJlZXplX3R0bF9jb25maWdzAAAAAAAAAAAAAA==",
1037
+ "AAAAAAAAACdSZXR1cm5zIHdoZXRoZXIgVFRMIGNvbmZpZ3MgYXJlIGZyb3plbi4AAAAAFWlzX3R0bF9jb25maWdzX2Zyb3plbgAAAAAAAAAAAAABAAAAAQ==",
1038
+ "AAAAAAAAAKVFeHRlbmRzIHRoZSBpbnN0YW5jZSBUVEwuCgojIEFyZ3VtZW50cwoKKiBgdGhyZXNob2xkYCAtIFRoZSB0aHJlc2hvbGQgdG8gZXh0ZW5kIHRoZSBUVEwgKGlmIGN1cnJlbnQgVFRMIGlzIGJlbG93IHRoaXMsIGV4dGVuZCkuCiogYGV4dGVuZF90b2AgLSBUaGUgVFRMIHRvIGV4dGVuZCB0by4AAAAAAAATZXh0ZW5kX2luc3RhbmNlX3R0bAAAAAACAAAAAAAAAAl0aHJlc2hvbGQAAAAAAAAEAAAAAAAAAAlleHRlbmRfdG8AAAAAAAAEAAAAAA==",
1039
+ "AAAAAAAAAD5SZXR1cm5zIHRoZSBjdXJyZW50IG93bmVyIGFkZHJlc3MsIG9yIE5vbmUgaWYgbm8gb3duZXIgaXMgc2V0LgAAAAAABW93bmVyAAAAAAAAAAAAAAEAAAPoAAAAEw==",
1040
+ "AAAAAAAAAEtUcmFuc2ZlcnMgb3duZXJzaGlwIHRvIGEgbmV3IGFkZHJlc3MuIFJlcXVpcmVzIGN1cnJlbnQgb3duZXIgYXV0aG9yaXphdGlvbi4AAAAAEnRyYW5zZmVyX293bmVyc2hpcAAAAAAAAQAAAAAAAAAJbmV3X293bmVyAAAAAAAAEwAAAAA=",
1041
+ "AAAAAAAAAEZQZXJtYW5lbnRseSByZW5vdW5jZXMgb3duZXJzaGlwLiBSZXF1aXJlcyBjdXJyZW50IG93bmVyIGF1dGhvcml6YXRpb24uAAAAAAAScmVub3VuY2Vfb3duZXJzaGlwAAAAAAAAAAAAAA==",
1042
+ "AAAABAAAABxCdWZmZXJSZWFkZXJFcnJvcjogMTAwMC0xMDA5AAAAAAAAABFCdWZmZXJSZWFkZXJFcnJvcgAAAAAAAAIAAAAAAAAADUludmFsaWRMZW5ndGgAAAAAAAPoAAAAAAAAABVJbnZhbGlkQWRkcmVzc1BheWxvYWQAAAAAAAPp",
1043
+ "AAAABAAAABxCdWZmZXJXcml0ZXJFcnJvcjogMTAxMC0xMDE5AAAAAAAAABFCdWZmZXJXcml0ZXJFcnJvcgAAAAAAAAEAAAAAAAAAFUludmFsaWRBZGRyZXNzUGF5bG9hZAAAAAAAA/I=",
1044
+ "AAAABAAAAB9UdGxDb25maWd1cmFibGVFcnJvcjogMTAyMC0xMDI5AAAAAAAAAAAUVHRsQ29uZmlndXJhYmxlRXJyb3IAAAADAAAAAAAAABBJbnZhbGlkVHRsQ29uZmlnAAAD/AAAAAAAAAAPVHRsQ29uZmlnRnJvemVuAAAAA/0AAAAAAAAAFlR0bENvbmZpZ0FscmVhZHlGcm96ZW4AAAAAA/4=",
1045
+ "AAAABAAAABdPd25hYmxlRXJyb3I6IDEwMzAtMTAzOQAAAAAAAAAADE93bmFibGVFcnJvcgAAAAIAAAAAAAAAD093bmVyQWxyZWFkeVNldAAAAAQGAAAAAAAAAAtPd25lck5vdFNldAAAAAQH",
1046
+ "AAAABAAAABhCeXRlc0V4dEVycm9yOiAxMDQwLTEwNDkAAAAAAAAADUJ5dGVzRXh0RXJyb3IAAAAAAAABAAAAAAAAAA5MZW5ndGhNaXNtYXRjaAAAAAAEEA==",
1047
+ "AAAABAAAABtVcGdyYWRlYWJsZUVycm9yOiAxMDUwLTEwNTkAAAAAAAAAABBVcGdyYWRlYWJsZUVycm9yAAAAAQAAAAAAAAATTWlncmF0aW9uTm90QWxsb3dlZAAAAAQa",
1048
+ "AAAABAAAABhNdWx0aXNpZ0Vycm9yOiAxMDYwLTEwNjkAAAAAAAAADU11bHRpc2lnRXJyb3IAAAAAAAAIAAAAAAAAABJBbHJlYWR5SW5pdGlhbGl6ZWQAAAAABCQAAAAAAAAADUludmFsaWRTaWduZXIAAAAAAAQlAAAAAAAAAA5TaWduYXR1cmVFcnJvcgAAAAAEJgAAAAAAAAATU2lnbmVyQWxyZWFkeUV4aXN0cwAAAAQnAAAAAAAAAA5TaWduZXJOb3RGb3VuZAAAAAAEKAAAAAAAAAAdVG90YWxTaWduZXJzTGVzc1RoYW5UaHJlc2hvbGQAAAAAAAQpAAAAAAAAAA9VbnNvcnRlZFNpZ25lcnMAAAAEKgAAAAAAAAANWmVyb1RocmVzaG9sZAAAAAAABCs=",
1049
+ "AAAABQAAADBFdmVudCBlbWl0dGVkIHdoZW4gYSBzaWduZXIgaXMgYWRkZWQgb3IgcmVtb3ZlZC4AAAAAAAAACVNpZ25lclNldAAAAAAAAAEAAAAKc2lnbmVyX3NldAAAAAAAAgAAAAAAAAAGc2lnbmVyAAAAAAPuAAAAFAAAAAEAAAAAAAAABmFjdGl2ZQAAAAAAAQAAAAAAAAAC",
1050
+ "AAAABQAAADZFdmVudCBlbWl0dGVkIHdoZW4gdGhlIHNpZ25hdHVyZSB0aHJlc2hvbGQgaXMgY2hhbmdlZC4AAAAAAAAAAAAMVGhyZXNob2xkU2V0AAAAAQAAAA10aHJlc2hvbGRfc2V0AAAAAAAAAQAAAAAAAAAJdGhyZXNob2xkAAAAAAAABAAAAAAAAAAC",
1051
+ "AAAAAgAAAAAAAAAAAAAAD011bHRpc2lnU3RvcmFnZQAAAAACAAAAAAAAAAAAAAAHU2lnbmVycwAAAAAAAAAAAAAAAAlUaHJlc2hvbGQAAAA=",
1052
+ "AAAABQAAACxFdmVudCBlbWl0dGVkIHdoZW4gb3duZXJzaGlwIGlzIHRyYW5zZmVycmVkLgAAAAAAAAAUT3duZXJzaGlwVHJhbnNmZXJyZWQAAAABAAAAFW93bmVyc2hpcF90cmFuc2ZlcnJlZAAAAAAAAAIAAAAAAAAACW9sZF9vd25lcgAAAAAAABMAAAAAAAAAAAAAAAluZXdfb3duZXIAAAAAAAATAAAAAAAAAAI=",
1053
+ "AAAABQAAACpFdmVudCBlbWl0dGVkIHdoZW4gb3duZXJzaGlwIGlzIHJlbm91bmNlZC4AAAAAAAAAAAAST3duZXJzaGlwUmVub3VuY2VkAAAAAAABAAAAE293bmVyc2hpcF9yZW5vdW5jZWQAAAAAAQAAAAAAAAAJb2xkX293bmVyAAAAAAAAEwAAAAAAAAAC",
1054
+ "AAAAAgAAAAAAAAAAAAAADk93bmFibGVTdG9yYWdlAAAAAAABAAAAAAAAAAAAAAAFT3duZXIAAAA=",
1055
+ "AAAAAQAAAElUVEwgY29uZmlndXJhdGlvbjogdGhyZXNob2xkICh3aGVuIHRvIGV4dGVuZCkgYW5kIGV4dGVuZF90byAodGFyZ2V0IFRUTCkuAAAAAAAAAAAAAAlUdGxDb25maWcAAAAAAAACAAAAKFRhcmdldCBUVEwgYWZ0ZXIgZXh0ZW5zaW9uIChpbiBsZWRnZXJzKS4AAAAJZXh0ZW5kX3RvAAAAAAAABAAAADNUVEwgdGhyZXNob2xkIHRoYXQgdHJpZ2dlcnMgZXh0ZW5zaW9uIChpbiBsZWRnZXJzKS4AAAAACXRocmVzaG9sZAAAAAAAAAQ=",
1056
+ "AAAABQAAACdFdmVudCBlbWl0dGVkIHdoZW4gVFRMIGNvbmZpZ3MgYXJlIHNldC4AAAAAAAAAAA1UdGxDb25maWdzU2V0AAAAAAAAAQAAAA90dGxfY29uZmlnc19zZXQAAAAAAgAAAAAAAAAIaW5zdGFuY2UAAAPoAAAH0AAAAAlUdGxDb25maWcAAAAAAAAAAAAAAAAAAApwZXJzaXN0ZW50AAAAAAPoAAAH0AAAAAlUdGxDb25maWcAAAAAAAAAAAAAAg==",
1057
+ "AAAABQAAACpFdmVudCBlbWl0dGVkIHdoZW4gVFRMIGNvbmZpZ3MgYXJlIGZyb3plbi4AAAAAAAAAAAAQVHRsQ29uZmlnc0Zyb3plbgAAAAEAAAASdHRsX2NvbmZpZ3NfZnJvemVuAAAAAAAAAAAAAg==",
1058
+ "AAAAAgAAAAAAAAAAAAAAEFR0bENvbmZpZ1N0b3JhZ2UAAAADAAAAAAAAAAAAAAAGRnJvemVuAAAAAAAAAAAAAAAAAAhJbnN0YW5jZQAAAAAAAAAAAAAAClBlcnNpc3RlbnQAAA==",
1059
+ "AAAAAgAAAAAAAAAAAAAAElVwZ3JhZGVhYmxlU3RvcmFnZQAAAAAAAQAAAAAAAAAAAAAACU1pZ3JhdGluZwAAAA==",
1060
+ "AAAABAAAABZXb3JrZXJFcnJvcjogMTIwMC0xMjk5AAAAAAAAAAAAC1dvcmtlckVycm9yAAAAABMAAAAAAAAAEkFkbWluQWxyZWFkeUV4aXN0cwAAAAAEsAAAAAAAAAANQWRtaW5Ob3RGb3VuZAAAAAAABLEAAAAAAAAAEkFscmVhZHlPbkFsbG93bGlzdAAAAAAEsgAAAAAAAAARQWxyZWFkeU9uRGVueWxpc3QAAAAAAASzAAAAAAAAABtBdHRlbXB0aW5nVG9SZW1vdmVPbmx5QWRtaW4AAAAEtAAAAAAAAAAURGVwb3NpdEFkZHJlc3NOb3RTZXQAAAS1AAAAAAAAABpNZXNzYWdlTGliQWxyZWFkeVN1cHBvcnRlZAAAAAAEtgAAAAAAAAAWTWVzc2FnZUxpYk5vdFN1cHBvcnRlZAAAAAAEtwAAAAAAAAAQTm9BZG1pbnNQcm92aWRlZAAABLgAAAAAAAAACk5vdEFsbG93ZWQAAAAABLkAAAAAAAAADk5vdE9uQWxsb3dsaXN0AAAAAAS6AAAAAAAAAA1Ob3RPbkRlbnlsaXN0AAAAAAAEuwAAAAAAAAAUUGF1c2VTdGF0dXNVbmNoYW5nZWQAAAS8AAAAAAAAAA9QcmljZUZlZWROb3RTZXQAAAAEvQAAAAAAAAAMUmVJbml0aWFsaXplAAAEvgAAAAAAAAAMVW5hdXRob3JpemVkAAAEvwAAAAAAAAAVVW5zdXBwb3J0ZWRNZXNzYWdlTGliAAAAAAAEwAAAAAAAAAASV29ya2VyRmVlTGliTm90U2V0AAAAAATBAAAAAAAAAA5Xb3JrZXJJc1BhdXNlZAAAAAAEwg==",
1061
+ "AAAABQAAAAAAAAAAAAAACFNldEFkbWluAAAAAQAAAAlzZXRfYWRtaW4AAAAAAAACAAAAAAAAAAVhZG1pbgAAAAAAABMAAAAAAAAAAAAAAAZhY3RpdmUAAAAAAAEAAAAAAAAAAg==",
1062
+ "AAAABQAAAAAAAAAAAAAAFlNldFN1cHBvcnRlZE1lc3NhZ2VMaWIAAAAAAAEAAAAZc2V0X3N1cHBvcnRlZF9tZXNzYWdlX2xpYgAAAAAAAAIAAAAAAAAAC21lc3NhZ2VfbGliAAAAABMAAAAAAAAAAAAAAAlzdXBwb3J0ZWQAAAAAAAABAAAAAAAAAAI=",
1063
+ "AAAABQAAAAAAAAAAAAAADFNldEFsbG93bGlzdAAAAAEAAAANc2V0X2FsbG93bGlzdAAAAAAAAAIAAAAAAAAABG9hcHAAAAATAAAAAAAAAAAAAAAHYWxsb3dlZAAAAAABAAAAAAAAAAI=",
1064
+ "AAAABQAAAAAAAAAAAAAAC1NldERlbnlsaXN0AAAAAAEAAAAMc2V0X2RlbnlsaXN0AAAAAgAAAAAAAAAEb2FwcAAAABMAAAAAAAAAAAAAAAZkZW5pZWQAAAAAAAEAAAAAAAAAAg==",
1065
+ "AAAABQAAAAAAAAAAAAAABlBhdXNlZAAAAAAAAQAAAAZwYXVzZWQAAAAAAAEAAAAAAAAABnBhdXNlcgAAAAAAEwAAAAAAAAAC",
1066
+ "AAAABQAAAAAAAAAAAAAACFVucGF1c2VkAAAAAQAAAAh1bnBhdXNlZAAAAAEAAAAAAAAACHVucGF1c2VyAAAAEwAAAAAAAAAC",
1067
+ "AAAABQAAAAAAAAAAAAAAF1NldERlZmF1bHRNdWx0aXBsaWVyQnBzAAAAAAEAAAAac2V0X2RlZmF1bHRfbXVsdGlwbGllcl9icHMAAAAAAAEAAAAAAAAADm11bHRpcGxpZXJfYnBzAAAAAAAEAAAAAAAAAAI=",
1068
+ "AAAABQAAAAAAAAAAAAAAEVNldERlcG9zaXRBZGRyZXNzAAAAAAAAAQAAABNzZXRfZGVwb3NpdF9hZGRyZXNzAAAAAAEAAAAAAAAAD2RlcG9zaXRfYWRkcmVzcwAAAAATAAAAAAAAAAI=",
1069
+ "AAAABQAAAAAAAAAAAAAADFNldFByaWNlRmVlZAAAAAEAAAAOc2V0X3ByaWNlX2ZlZWQAAAAAAAEAAAAAAAAACnByaWNlX2ZlZWQAAAAAABMAAAAAAAAAAg==",
1070
+ "AAAABQAAAAAAAAAAAAAAF1NldFN1cHBvcnRlZE9wdGlvblR5cGVzAAAAAAEAAAAac2V0X3N1cHBvcnRlZF9vcHRpb25fdHlwZXMAAAAAAAIAAAAAAAAAB2RzdF9laWQAAAAABAAAAAAAAAAAAAAADG9wdGlvbl90eXBlcwAAAA4AAAAAAAAAAg==",
1071
+ "AAAABQAAAAAAAAAAAAAAD1NldFdvcmtlckZlZUxpYgAAAAABAAAAEnNldF93b3JrZXJfZmVlX2xpYgAAAAAAAQAAAAAAAAAHZmVlX2xpYgAAAAATAAAAAAAAAAI=",
1072
+ "AAAAAQAAAOFQYXJhbWV0ZXJzIGZvciBEVk4gZmVlIGNhbGN1bGF0aW9uLgoKQ29udGFpbnMgYWxsIGlucHV0cyBuZWVkZWQgYnkgdGhlIGZlZSBsaWJyYXJ5IHRvIGNhbGN1bGF0ZSB2ZXJpZmljYXRpb24gZmVlcwpmb3IgY3Jvc3MtY2hhaW4gbWVzc2FnZXMuIEluY2x1ZGVzIG1lc3NhZ2UgcGFyYW1ldGVycywgY29tbW9uIGNvbmZpZ3VyYXRpb24sCmFuZCBkZXN0aW5hdGlvbi1zcGVjaWZpYyBzZXR0aW5ncy4AAAAAAAAAAAAADER2bkZlZVBhcmFtcwAAAAoAAAAnTnVtYmVyIG9mIGJsb2NrIGNvbmZpcm1hdGlvbnMgcmVxdWlyZWQuAAAAAA1jb25maXJtYXRpb25zAAAAAAAABgAAAExEZWZhdWx0IGZlZSBtdWx0aXBsaWVyIGluIGJhc2lzIHBvaW50cyAodXNlZCBpZiBubyBkc3Qtc3BlY2lmaWMgbXVsdGlwbGllcikuAAAAFmRlZmF1bHRfbXVsdGlwbGllcl9icHMAAAAAAAQAAAArRGVzdGluYXRpb24gZW5kcG9pbnQgSUQgKGNoYWluIGlkZW50aWZpZXIpLgAAAAAHZHN0X2VpZAAAAAAEAAAAI01pbmltdW0gZmVlIG1hcmdpbiBpbiBVU0QgKHNjYWxlZCkuAAAAABBmbG9vcl9tYXJnaW5fdXNkAAAACgAAARA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQpEZXN0aW5hdGlvbi1TcGVjaWZpYyBDb25maWd1cmF0aW9uCj09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CkdhcyBlc3RpbWF0ZSBmb3IgdmVyaWZpY2F0aW9uIG9uIGRlc3RpbmF0aW9uIGNoYWluLgAAAANnYXMAAAAACgAAAEZEZXN0aW5hdGlvbi1zcGVjaWZpYyBmZWUgbXVsdGlwbGllciBpbiBiYXNpcyBwb2ludHMgKDAgPSB1c2UgZGVmYXVsdCkuAAAAAAAObXVsdGlwbGllcl9icHMAAAAAAAQAAAALRFZOIG9wdGlvbnMAAAAAB29wdGlvbnMAAAAADgAAARA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQpDb21tb24gQ29uZmlndXJhdGlvbgo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQpQcmljZSBmZWVkIGNvbnRyYWN0IGFkZHJlc3MgZm9yIGdhcyBwcmljZSBhbmQgZXhjaGFuZ2UgcmF0ZSBkYXRhLgAAAApwcmljZV9mZWVkAAAAAAATAAAAJ051bWJlciBvZiByZXF1aXJlZCBzaWduYXR1cmVzIChxdW9ydW0pLgAAAAAGcXVvcnVtAAAAAAAEAAAA5T09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09Ck1lc3NhZ2UgUGFyYW1ldGVycwo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQpUaGUgT0FwcCBzZW5kZXIgYWRkcmVzcy4AAAAAAAAGc2VuZGVyAAAAAAAT",
1073
+ "AAAAAQAAAONQYXJhbWV0ZXJzIGZvciBleGVjdXRvciBmZWUgY2FsY3VsYXRpb24uCgpDb250YWlucyBhbGwgaW5wdXRzIG5lZWRlZCBieSB0aGUgZmVlIGxpYnJhcnkgdG8gY2FsY3VsYXRlIGV4ZWN1dGlvbiBmZWVzCmZvciBjcm9zcy1jaGFpbiBtZXNzYWdlcy4gSW5jbHVkZXMgbWVzc2FnZSBwYXJhbWV0ZXJzLCBjb21tb24gY29uZmlndXJhdGlvbiwKYW5kIGRlc3RpbmF0aW9uLXNwZWNpZmljIHNldHRpbmdzLgAAAAAAAAAACUZlZVBhcmFtcwAAAAAAAAsAAAAmU2l6ZSBvZiB0aGUgbWVzc2FnZSBjYWxsZGF0YSBpbiBieXRlcy4AAAAAAA1jYWxsZGF0YV9zaXplAAAAAAAABAAAAExEZWZhdWx0IGZlZSBtdWx0aXBsaWVyIGluIGJhc2lzIHBvaW50cyAodXNlZCBpZiBubyBkc3Qtc3BlY2lmaWMgbXVsdGlwbGllcikuAAAAFmRlZmF1bHRfbXVsdGlwbGllcl9icHMAAAAAAAQAAAArRGVzdGluYXRpb24gZW5kcG9pbnQgSUQgKGNoYWluIGlkZW50aWZpZXIpLgAAAAAHZHN0X2VpZAAAAAAEAAAAI01pbmltdW0gZmVlIG1hcmdpbiBpbiBVU0QgKHNjYWxlZCkuAAAAABBmbG9vcl9tYXJnaW5fdXNkAAAACgAAADZCYXNlIGdhcyBmb3IgZWFjaCBsekNvbXBvc2UgY2FsbCBvbiBkZXN0aW5hdGlvbiBjaGFpbi4AAAAAABNsel9jb21wb3NlX2Jhc2VfZ2FzAAAAAAYAAAETPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KRGVzdGluYXRpb24tU3BlY2lmaWMgQ29uZmlndXJhdGlvbgo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQpCYXNlIGdhcyBmb3IgbHpSZWNlaXZlIGV4ZWN1dGlvbiBvbiBkZXN0aW5hdGlvbiBjaGFpbi4AAAAAE2x6X3JlY2VpdmVfYmFzZV9nYXMAAAAABgAAAEZEZXN0aW5hdGlvbi1zcGVjaWZpYyBmZWUgbXVsdGlwbGllciBpbiBiYXNpcyBwb2ludHMgKDAgPSB1c2UgZGVmYXVsdCkuAAAAAAAObXVsdGlwbGllcl9icHMAAAAAAAQAAAAsTWF4aW11bSBuYXRpdmUgdG9rZW4gdmFsdWUgdGhhdCBjYW4gYmUgc2VudC4AAAAKbmF0aXZlX2NhcAAAAAAACgAAAEZFbmNvZGVkIGV4ZWN1dG9yIG9wdGlvbnMgKGx6UmVjZWl2ZSBnYXMsIGx6Q29tcG9zZSwgbmF0aXZlRHJvcCwgZXRjLikuAAAAAAAHb3B0aW9ucwAAAAAOAAABED09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09CkNvbW1vbiBDb25maWd1cmF0aW9uCj09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09ClByaWNlIGZlZWQgY29udHJhY3QgYWRkcmVzcyBmb3IgZ2FzIHByaWNlIGFuZCBleGNoYW5nZSByYXRlIGRhdGEuAAAACnByaWNlX2ZlZWQAAAAAABMAAADlPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KTWVzc2FnZSBQYXJhbWV0ZXJzCj09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09ClRoZSBPQXBwIHNlbmRlciBhZGRyZXNzLgAAAAAAAAZzZW5kZXIAAAAAABM=",
1074
+ "AAAAAQAAAIRHYXMgcHJpY2UgaW5mb3JtYXRpb24gZm9yIGEgZGVzdGluYXRpb24gZW5kcG9pbnQuCgpDb250YWlucyB0aGUgZXhjaGFuZ2UgcmF0ZSBhbmQgZ2FzIGNvc3RzIG5lZWRlZCBmb3IgY3Jvc3MtY2hhaW4gZmVlIGNhbGN1bGF0aW9ucy4AAAAAAAAABVByaWNlAAAAAAAAAwAAADdHYXMgY29zdCBwZXIgYnl0ZSBvZiBjYWxsZGF0YSBvbiB0aGUgZGVzdGluYXRpb24gY2hhaW4uAAAAAAxnYXNfcGVyX2J5dGUAAAAEAAAAQkdhcyBwcmljZSBpbiB0aGUgc21hbGxlc3QgdW5pdCAod2VpIGZvciBFVk0sIHN0cm9vcHMgZm9yIFN0ZWxsYXIpLgAAAAAAEWdhc19wcmljZV9pbl91bml0AAAAAAAABgAAAKlQcmljZSByYXRpbyA9IChyZW1vdGUgbmF0aXZlIHRva2VuIHByaWNlIC8gbG9jYWwgbmF0aXZlIHRva2VuIHByaWNlKSAqIFBSSUNFX1JBVElPX0RFTk9NSU5BVE9SLgpVc2VkIHRvIGNvbnZlcnQgZGVzdGluYXRpb24gY2hhaW4gZ2FzIGNvc3RzIHRvIHNvdXJjZSBjaGFpbiBuYXRpdmUgdG9rZW4uAAAAAAAAC3ByaWNlX3JhdGlvAAAAAAo=",
1075
+ "AAAAAQAAAIBGZWUgZXN0aW1hdGlvbiByZXN1bHQgd2l0aCBkZXRhaWxlZCBicmVha2Rvd24uCgpDb250YWlucyB0aGUgY2FsY3VsYXRlZCBmZWUgYW5kIGFsbCBpbnRlcm1lZGlhdGUgdmFsdWVzIHVzZWQgaW4gdGhlIGNhbGN1bGF0aW9uLgAAAAAAAAALRmVlRXN0aW1hdGUAAAAABAAAADBTb3VyY2UgY2hhaW4gbmF0aXZlIHRva2VuIHByaWNlIGluIFVTRCAoc2NhbGVkKS4AAAAQbmF0aXZlX3ByaWNlX3VzZAAAAAoAAAAlUHJpY2UgcmF0aW8gdXNlZCBmb3IgdGhlIGNhbGN1bGF0aW9uLgAAAAAAAAtwcmljZV9yYXRpbwAAAAAKAAAAMkRlbm9taW5hdG9yIGZvciB0aGUgcHJpY2UgcmF0aW8gKHR5cGljYWxseSAxMF4yMCkuAAAAAAAXcHJpY2VfcmF0aW9fZGVub21pbmF0b3IAAAAACgAAADFUb3RhbCBnYXMgZmVlIGluIHNvdXJjZSBjaGFpbiBuYXRpdmUgdG9rZW4gdW5pdHMuAAAAAAAADXRvdGFsX2dhc19mZWUAAAAAAAAL",
1076
+ "AAAAAgAAAAAAAAAAAAAADVdvcmtlclN0b3JhZ2UAAAAAAAALAAAAAAAAAAAAAAAGUGF1c2VkAAAAAAAAAAAAAAAAAA5EZXBvc2l0QWRkcmVzcwAAAAAAAAAAAAAAAAAJUHJpY2VGZWVkAAAAAAAAAAAAAAAAAAAMV29ya2VyRmVlTGliAAAAAAAAAAAAAAAURGVmYXVsdE11bHRpcGxpZXJCcHMAAAABAAAAAAAAABRTdXBwb3J0ZWRPcHRpb25UeXBlcwAAAAEAAAAEAAAAAAAAAAAAAAALTWVzc2FnZUxpYnMAAAAAAQAAAAAAAAAJQWxsb3dsaXN0AAAAAAAAAQAAABMAAAABAAAAAAAAAAhEZW55bGlzdAAAAAEAAAATAAAAAAAAAAAAAAANQWxsb3dsaXN0U2l6ZQAAAAAAAAAAAAAAAAAABkFkbWlucwAA" ]),
1077
+ options
1078
+ )
1079
+ }
1080
+ public readonly fromJSON = {
1081
+ upgrade: this.txFromJSON<null>,
1082
+ migrate: this.txFromJSON<null>,
1083
+ authorizer: this.txFromJSON<string>,
1084
+ estimate_fee_by_eid: this.txFromJSON<FeeEstimate>,
1085
+ native_token_price_usd: this.txFromJSON<u128>,
1086
+ get_price: this.txFromJSON<Option<Price>>,
1087
+ get_price_ratio_denominator: this.txFromJSON<u128>,
1088
+ set_price_updater: this.txFromJSON<null>,
1089
+ set_price_ratio_denominator: this.txFromJSON<null>,
1090
+ set_arbitrum_compression_percent: this.txFromJSON<null>,
1091
+ set_eid_to_model_type: this.txFromJSON<null>,
1092
+ set_price: this.txFromJSON<null>,
1093
+ set_price_for_arbitrum: this.txFromJSON<null>,
1094
+ set_native_token_price_usd: this.txFromJSON<null>,
1095
+ is_price_updater: this.txFromJSON<boolean>,
1096
+ arbitrum_compression_percent: this.txFromJSON<u128>,
1097
+ arbitrum_price_ext: this.txFromJSON<ArbitrumPriceExt>,
1098
+ eid_to_model_type: this.txFromJSON<ModelType>,
1099
+ set_ttl_configs: this.txFromJSON<null>,
1100
+ ttl_configs: this.txFromJSON<readonly [Option<TtlConfig>, Option<TtlConfig>]>,
1101
+ freeze_ttl_configs: this.txFromJSON<null>,
1102
+ is_ttl_configs_frozen: this.txFromJSON<boolean>,
1103
+ extend_instance_ttl: this.txFromJSON<null>,
1104
+ owner: this.txFromJSON<Option<string>>,
1105
+ transfer_ownership: this.txFromJSON<null>,
1106
+ renounce_ownership: this.txFromJSON<null>
1107
+ }
1108
+ }