@layerzerolabs/protocol-stellar-v2 0.2.15 → 0.2.19

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 (262) hide show
  1. package/.turbo/turbo-build.log +365 -297
  2. package/.turbo/turbo-lint.log +142 -110
  3. package/.turbo/turbo-test.log +1273 -1222
  4. package/Cargo.lock +20 -5
  5. package/Cargo.toml +4 -1
  6. package/contracts/ERROR_SPEC.md +44 -0
  7. package/contracts/common-macros/src/auth.rs +113 -0
  8. package/contracts/common-macros/src/contract_ttl.rs +84 -0
  9. package/contracts/common-macros/src/lib.rs +181 -30
  10. package/contracts/common-macros/src/lz_contract.rs +83 -0
  11. package/contracts/common-macros/src/tests/{ownable.rs → auth.rs} +48 -15
  12. package/contracts/common-macros/src/tests/contract_ttl.rs +662 -0
  13. package/contracts/common-macros/src/tests/mod.rs +2 -2
  14. package/contracts/common-macros/src/tests/snapshots/common_macros__tests__auth__snapshot_generated_multisig_code.snap +20 -0
  15. package/contracts/common-macros/src/tests/snapshots/common_macros__tests__auth__snapshot_generated_ownable_code.snap +24 -0
  16. package/contracts/common-macros/src/tests/snapshots/{common_macros__tests__ownable__snapshot_only_owner_preserves_function_signature.snap → common_macros__tests__auth__snapshot_only_auth_preserves_function_signature.snap} +4 -4
  17. package/contracts/common-macros/src/tests/snapshots/{common_macros__tests__contract_impl__snapshot_generated_contract_impl_code.snap → common_macros__tests__contract_ttl__snapshot_generated_contractimpl_code.snap} +3 -3
  18. package/contracts/common-macros/src/tests/snapshots/common_macros__tests__contract_ttl__snapshot_generated_contracttrait_code.snap +69 -0
  19. package/contracts/common-macros/src/tests/snapshots/common_macros__tests__ttl_configurable__snapshot_generated_ttl_configurable_code.snap +7 -21
  20. package/contracts/common-macros/src/tests/snapshots/common_macros__tests__upgradeable__snapshot_generated_upgradeable_code.snap +2 -2
  21. package/contracts/common-macros/src/ttl_configurable.rs +19 -34
  22. package/contracts/common-macros/src/ttl_extendable.rs +36 -0
  23. package/contracts/common-macros/src/upgradeable.rs +5 -5
  24. package/contracts/common-macros/src/utils.rs +9 -0
  25. package/contracts/endpoint-v2/src/constants.rs +4 -4
  26. package/contracts/endpoint-v2/src/endpoint_v2.rs +38 -40
  27. package/contracts/endpoint-v2/src/errors.rs +4 -3
  28. package/contracts/endpoint-v2/src/events.rs +1 -1
  29. package/contracts/endpoint-v2/src/message_lib_manager.rs +18 -5
  30. package/contracts/endpoint-v2/src/messaging_channel.rs +11 -1
  31. package/contracts/endpoint-v2/src/messaging_composer.rs +11 -1
  32. package/contracts/endpoint-v2/src/storage.rs +1 -1
  33. package/contracts/endpoint-v2/src/tests/endpoint_v2/pay_messaging_fees.rs +3 -3
  34. package/contracts/endpoint-v2/src/tests/endpoint_v2/quote.rs +1 -1
  35. package/contracts/endpoint-v2/src/tests/endpoint_v2/require_oapp_auth.rs +2 -2
  36. package/contracts/endpoint-v2/src/tests/endpoint_v2/send.rs +3 -3
  37. package/contracts/endpoint-v2/src/tests/endpoint_v2/set_zro.rs +4 -4
  38. package/contracts/endpoint-v2/src/tests/message_lib_manager/require_receive_lib_for_eid.rs +3 -3
  39. package/contracts/endpoint-v2/src/tests/message_lib_manager/require_registered.rs +1 -1
  40. package/contracts/endpoint-v2/src/tests/message_lib_manager/require_send_lib_for_eid.rs +3 -3
  41. package/contracts/endpoint-v2/src/tests/message_lib_manager/require_supported_eid.rs +1 -1
  42. package/contracts/endpoint-v2/src/tests/messaging_channel/clear_payload.rs +4 -4
  43. package/contracts/endpoint-v2/src/tests/messaging_channel/inbound.rs +1 -1
  44. package/contracts/layerzero-views/src/layerzero_view.rs +3 -6
  45. package/contracts/macro-integration-tests/tests/runtime/ownable/mod.rs +2 -2
  46. package/contracts/macro-integration-tests/tests/runtime/ownable/{only_owner_guard.rs → only_auth_guard.rs} +1 -1
  47. package/contracts/macro-integration-tests/tests/runtime/ttl_configurable/configuration.rs +1 -1
  48. package/contracts/macro-integration-tests/tests/runtime/ttl_configurable/freeze.rs +1 -1
  49. package/contracts/macro-integration-tests/tests/runtime/ttl_configurable/mod.rs +0 -1
  50. package/contracts/macro-integration-tests/tests/ui/ownable/fail/{only_owner_missing_env.rs → only_auth_missing_env.rs} +3 -3
  51. package/contracts/macro-integration-tests/tests/ui/ownable/fail/{only_owner_missing_env.stderr → only_auth_missing_env.stderr} +4 -4
  52. package/contracts/macro-integration-tests/tests/ui/ownable/pass/namespacing_and_imports.rs +2 -3
  53. package/contracts/macro-integration-tests/tests/ui/ownable/pass/{only_owner_env_param_variants.rs → only_auth_env_param_variants.rs} +9 -9
  54. package/contracts/macro-integration-tests/tests/ui/ttl_configurable/pass/minimal_contract.rs +6 -6
  55. package/contracts/message-libs/message-lib-common/src/errors.rs +7 -2
  56. package/contracts/message-libs/message-lib-common/src/tests/packet_codec_v1/decode_packet_header.rs +3 -3
  57. package/contracts/message-libs/message-lib-common/src/tests/worker_options/append_lz_receive_option.rs +1 -2
  58. package/contracts/message-libs/message-lib-common/src/tests/worker_options/append_native_drop_option.rs +1 -2
  59. package/contracts/message-libs/message-lib-common/src/tests/worker_options/convert_legacy_options.rs +9 -9
  60. package/contracts/message-libs/message-lib-common/src/tests/worker_options/extract_type_3_options.rs +1 -1
  61. package/contracts/message-libs/message-lib-common/src/tests/worker_options/left_pad_to_bytes32.rs +1 -1
  62. package/contracts/message-libs/message-lib-common/src/tests/worker_options/split_worker_options.rs +2 -2
  63. package/contracts/message-libs/simple-message-lib/src/simple_message_lib.rs +7 -9
  64. package/contracts/message-libs/treasury/src/errors.rs +2 -2
  65. package/contracts/message-libs/treasury/src/events.rs +1 -1
  66. package/contracts/message-libs/treasury/src/interfaces/zro_fee_lib.rs +2 -2
  67. package/contracts/message-libs/treasury/src/storage.rs +1 -1
  68. package/contracts/message-libs/treasury/src/tests/treasury_tests.rs +1 -1
  69. package/contracts/message-libs/treasury/src/treasury.rs +14 -16
  70. package/contracts/message-libs/uln-302/src/receive_uln.rs +13 -2
  71. package/contracts/message-libs/uln-302/src/send_uln.rs +24 -4
  72. package/contracts/message-libs/uln-302/src/uln302.rs +6 -24
  73. package/contracts/oapps/counter/Cargo.toml +14 -1
  74. package/contracts/oapps/counter/integration_tests/mod.rs +4 -1
  75. package/contracts/oapps/counter/integration_tests/{setup.rs → setup_sml.rs} +48 -80
  76. package/contracts/oapps/counter/integration_tests/setup_uln.rs +997 -0
  77. package/contracts/oapps/counter/integration_tests/signing.rs +62 -0
  78. package/contracts/oapps/counter/integration_tests/test_with_sml.rs +24 -55
  79. package/contracts/oapps/counter/integration_tests/test_with_uln.rs +314 -0
  80. package/contracts/oapps/counter/integration_tests/utils.rs +196 -53
  81. package/contracts/oapps/counter/src/counter.rs +67 -43
  82. package/contracts/oapps/counter/src/tests/mod.rs +0 -13
  83. package/contracts/oapps/counter/src/tests/test_counter.rs +5 -7
  84. package/contracts/oapps/oapp/src/errors.rs +5 -1
  85. package/contracts/oapps/oapp/src/macro_tests/test_macros.rs +93 -78
  86. package/contracts/oapps/oapp/src/oapp_core.rs +36 -21
  87. package/contracts/oapps/oapp/src/oapp_options_type3.rs +48 -12
  88. package/contracts/oapps/oapp/src/oapp_receiver.rs +106 -41
  89. package/contracts/oapps/oapp/src/oapp_sender.rs +26 -34
  90. package/contracts/oapps/oapp/src/tests/test_oapp_core.rs +9 -8
  91. package/contracts/oapps/oapp/src/tests/test_oapp_options_type3.rs +25 -17
  92. package/contracts/oapps/oapp/src/tests/test_oapp_receiver.rs +7 -7
  93. package/contracts/oapps/oapp/src/tests/test_oapp_sender.rs +14 -15
  94. package/contracts/oapps/oapp-macros/src/generators.rs +128 -0
  95. package/contracts/oapps/oapp-macros/src/lib.rs +113 -56
  96. package/contracts/oapps/oft/Cargo.toml +10 -7
  97. package/contracts/oapps/{oft-std → oft}/integration-tests/extensions/test_oft_fee.rs +3 -4
  98. package/contracts/oapps/{oft-std → oft}/integration-tests/extensions/test_pausable.rs +2 -3
  99. package/contracts/oapps/{oft-std → oft}/integration-tests/extensions/test_rate_limiter.rs +1 -1
  100. package/contracts/oapps/oft/integration-tests/mod.rs +1 -1
  101. package/contracts/oapps/oft/integration-tests/setup.rs +29 -110
  102. package/contracts/oapps/oft/integration-tests/utils.rs +254 -21
  103. package/contracts/oapps/oft/src/extensions/oft_fee.rs +13 -14
  104. package/contracts/oapps/oft/src/extensions/pausable.rs +4 -4
  105. package/contracts/oapps/oft/src/extensions/rate_limiter.rs +5 -5
  106. package/contracts/oapps/oft/src/lib.rs +11 -13
  107. package/contracts/oapps/oft/src/oft.rs +147 -225
  108. package/contracts/oapps/oft/src/oft_types/lock_unlock.rs +9 -13
  109. package/contracts/oapps/oft/src/oft_types/mint_burn.rs +31 -14
  110. package/contracts/oapps/oft/src/oft_types/mod.rs +13 -0
  111. package/contracts/oapps/{oft-std → oft-core}/Cargo.toml +6 -4
  112. package/contracts/oapps/{oft-std → oft-core}/integration-tests/mod.rs +1 -1
  113. package/contracts/oapps/{oft-std → oft-core}/integration-tests/setup.rs +129 -30
  114. package/contracts/oapps/{oft → oft-core}/integration-tests/test_with_sml.rs +3 -3
  115. package/contracts/oapps/oft-core/integration-tests/utils.rs +201 -0
  116. package/contracts/oapps/oft-core/src/errors.rs +13 -0
  117. package/contracts/oapps/oft-core/src/lib.rs +18 -0
  118. package/contracts/oapps/oft-core/src/oft_core.rs +439 -0
  119. package/contracts/oapps/{oft → oft-core}/src/storage.rs +2 -0
  120. package/contracts/oapps/{oft → oft-core}/src/tests/mod.rs +0 -2
  121. package/contracts/oapps/{oft → oft-core}/src/tests/test_decimals.rs +2 -2
  122. package/contracts/oapps/{oft → oft-core}/src/tests/test_lz_receive.rs +7 -7
  123. package/contracts/oapps/{oft → oft-core}/src/tests/test_oft_msg_codec.rs +4 -5
  124. package/contracts/oapps/{oft → oft-core}/src/tests/test_resolve_address.rs +3 -3
  125. package/contracts/oapps/{oft → oft-core}/src/tests/test_utils.rs +78 -37
  126. package/contracts/oapps/oft-core/src/types.rs +58 -0
  127. package/contracts/oapps/{oft → oft-core}/src/utils.rs +1 -1
  128. package/contracts/upgrader/src/lib.rs +4 -4
  129. package/contracts/utils/src/auth.rs +44 -0
  130. package/contracts/utils/src/errors.rs +31 -5
  131. package/contracts/utils/src/lib.rs +3 -0
  132. package/contracts/utils/src/multisig.rs +211 -0
  133. package/contracts/utils/src/ownable.rs +137 -13
  134. package/contracts/utils/src/tests/buffer_reader.rs +6 -6
  135. package/contracts/utils/src/tests/buffer_writer.rs +6 -6
  136. package/contracts/utils/src/tests/bytes_ext.rs +2 -4
  137. package/contracts/utils/src/tests/mod.rs +1 -0
  138. package/contracts/utils/src/tests/multisig.rs +731 -0
  139. package/contracts/utils/src/tests/option_ext.rs +2 -5
  140. package/contracts/utils/src/tests/ownable.rs +456 -7
  141. package/contracts/utils/src/tests/ttl_configurable.rs +27 -16
  142. package/contracts/utils/src/tests/upgradeable.rs +4 -2
  143. package/contracts/utils/src/ttl_configurable.rs +23 -8
  144. package/contracts/utils/src/ttl_extendable.rs +27 -0
  145. package/contracts/utils/src/upgradeable.rs +2 -0
  146. package/contracts/workers/dvn/Cargo.toml +1 -1
  147. package/contracts/workers/dvn/src/auth.rs +7 -7
  148. package/contracts/workers/dvn/src/dvn.rs +10 -38
  149. package/contracts/workers/dvn/src/errors.rs +0 -7
  150. package/contracts/workers/dvn/src/events.rs +1 -14
  151. package/contracts/workers/dvn/src/interfaces/dvn.rs +2 -2
  152. package/contracts/workers/dvn/src/interfaces/mod.rs +0 -2
  153. package/contracts/workers/dvn/src/storage.rs +3 -13
  154. package/contracts/workers/dvn/src/tests/auth.rs +4 -4
  155. package/contracts/workers/dvn/src/tests/dvn.rs +1 -2
  156. package/contracts/workers/dvn/src/tests/multisig/set_signer.rs +7 -8
  157. package/contracts/workers/dvn/src/tests/multisig/set_threshold.rs +11 -8
  158. package/contracts/workers/dvn/src/tests/multisig/verify_signatures.rs +11 -12
  159. package/contracts/workers/dvn/src/tests/setup.rs +5 -5
  160. package/contracts/workers/dvn-fee-lib/Cargo.toml +1 -1
  161. package/contracts/workers/dvn-fee-lib/src/dvn_fee_lib.rs +3 -6
  162. package/contracts/workers/executor/src/auth.rs +80 -16
  163. package/contracts/workers/executor/src/executor.rs +5 -31
  164. package/contracts/workers/executor/src/storage.rs +2 -9
  165. package/contracts/workers/executor-fee-lib/Cargo.toml +1 -1
  166. package/contracts/workers/executor-fee-lib/src/executor_fee_lib.rs +3 -6
  167. package/contracts/workers/executor-helper/Cargo.toml +1 -1
  168. package/contracts/workers/executor-helper/src/executor_helper.rs +53 -73
  169. package/contracts/workers/price-feed/Cargo.toml +1 -1
  170. package/contracts/workers/price-feed/src/price_feed.rs +7 -10
  171. package/contracts/workers/worker/src/errors.rs +4 -0
  172. package/contracts/workers/worker/src/tests/worker.rs +7 -6
  173. package/contracts/workers/worker/src/worker.rs +20 -16
  174. package/package.json +7 -5
  175. package/sdk/.turbo/turbo-build.log +1 -0
  176. package/sdk/.turbo/turbo-test.log +1019 -0
  177. package/sdk/dist/generated/bml.d.ts +95 -8
  178. package/sdk/dist/generated/bml.js +95 -36
  179. package/sdk/dist/generated/counter.d.ts +289 -44
  180. package/sdk/dist/generated/counter.js +119 -49
  181. package/sdk/dist/generated/dvn.d.ts +312 -229
  182. package/sdk/dist/generated/dvn.js +144 -83
  183. package/sdk/dist/generated/dvn_fee_lib.d.ts +258 -63
  184. package/sdk/dist/generated/dvn_fee_lib.js +95 -26
  185. package/sdk/dist/generated/endpoint.d.ts +219 -24
  186. package/sdk/dist/generated/endpoint.js +108 -41
  187. package/sdk/dist/generated/executor.d.ts +239 -87
  188. package/sdk/dist/generated/executor.js +135 -63
  189. package/sdk/dist/generated/executor_fee_lib.d.ts +278 -74
  190. package/sdk/dist/generated/executor_fee_lib.js +135 -59
  191. package/sdk/dist/generated/executor_helper.d.ts +163 -21
  192. package/sdk/dist/generated/executor_helper.js +124 -52
  193. package/sdk/dist/generated/oft.d.ts +1842 -0
  194. package/sdk/dist/generated/oft.js +345 -0
  195. package/sdk/dist/generated/price_feed.d.ts +258 -63
  196. package/sdk/dist/generated/price_feed.js +95 -26
  197. package/sdk/dist/generated/sml.d.ts +235 -34
  198. package/sdk/dist/generated/sml.js +126 -53
  199. package/sdk/dist/generated/treasury.d.ts +1016 -0
  200. package/sdk/dist/generated/treasury.js +248 -0
  201. package/sdk/dist/generated/uln302.d.ts +235 -34
  202. package/sdk/dist/generated/uln302.js +126 -53
  203. package/sdk/dist/generated/upgrader.d.ts +17 -2
  204. package/sdk/dist/generated/upgrader.js +19 -1
  205. package/sdk/dist/index.d.ts +2 -1
  206. package/sdk/dist/index.js +2 -1
  207. package/sdk/package.json +6 -3
  208. package/sdk/src/index.ts +2 -1
  209. package/sdk/test/counter-sml.test.ts +376 -0
  210. package/sdk/test/counter-uln.test.ts +493 -0
  211. package/sdk/test/{oft.test.ts → oft-sml.test.ts} +196 -321
  212. package/sdk/test/suites/constants.ts +22 -2
  213. package/sdk/test/suites/globalSetup.ts +450 -0
  214. package/sdk/test/suites/localnet.ts +23 -6
  215. package/sdk/test/upgrader.test.ts +7 -16
  216. package/sdk/test/utils.ts +558 -85
  217. package/sdk/turbo.json +8 -0
  218. package/sdk/vitest.config.ts +21 -0
  219. package/tools/ts-bindings-gen/Cargo.toml +2 -0
  220. package/tools/ts-bindings-gen/src/main.rs +52 -4
  221. package/contracts/common-macros/src/contract_impl.rs +0 -52
  222. package/contracts/common-macros/src/ownable.rs +0 -41
  223. package/contracts/common-macros/src/tests/contract_impl.rs +0 -386
  224. package/contracts/common-macros/src/tests/snapshots/common_macros__tests__ownable__snapshot_generated_ownable_code.snap +0 -12
  225. package/contracts/macro-integration-tests/tests/runtime/ttl_configurable/extend_instance_ttl.rs +0 -50
  226. package/contracts/oapps/oapp-macros/src/oapp_core.rs +0 -41
  227. package/contracts/oapps/oapp-macros/src/oapp_full.rs +0 -21
  228. package/contracts/oapps/oapp-macros/src/oapp_options_type3.rs +0 -31
  229. package/contracts/oapps/oapp-macros/src/oapp_receiver.rs +0 -48
  230. package/contracts/oapps/oapp-macros/src/oapp_sender.rs +0 -21
  231. package/contracts/oapps/oapp-macros/src/util.rs +0 -107
  232. package/contracts/oapps/oft/src/constants.rs +0 -5
  233. package/contracts/oapps/oft/src/default_oft_impl.rs +0 -152
  234. package/contracts/oapps/oft/src/errors.rs +0 -8
  235. package/contracts/oapps/oft/src/interfaces/mint_burn_token.rs +0 -23
  236. package/contracts/oapps/oft/src/interfaces/mod.rs +0 -3
  237. package/contracts/oapps/oft/src/tests/extensions/mod.rs +0 -11
  238. package/contracts/oapps/oft/src/tests/extensions/setup.rs +0 -903
  239. package/contracts/oapps/oft/src/tests/extensions/test_oft_fee.rs +0 -749
  240. package/contracts/oapps/oft/src/tests/extensions/test_pausable.rs +0 -432
  241. package/contracts/oapps/oft/src/tests/extensions/test_rate_limiter.rs +0 -1078
  242. package/contracts/oapps/oft/src/types.rs +0 -38
  243. package/contracts/oapps/oft-std/integration-tests/utils.rs +0 -427
  244. package/contracts/oapps/oft-std/src/lib.rs +0 -16
  245. package/contracts/oapps/oft-std/src/oft.rs +0 -156
  246. package/contracts/workers/dvn/src/interfaces/multisig.rs +0 -56
  247. package/contracts/workers/dvn/src/multisig.rs +0 -157
  248. package/sdk/dist/generated/oft_std.d.ts +0 -1544
  249. package/sdk/dist/generated/oft_std.js +0 -271
  250. package/sdk/test/index.test.ts +0 -375
  251. /package/contracts/oapps/{oft-std → oft}/integration-tests/extensions/mod.rs +0 -0
  252. /package/contracts/oapps/{oft → oft-core}/src/codec/mod.rs +0 -0
  253. /package/contracts/oapps/{oft → oft-core}/src/codec/oft_compose_msg_codec.rs +0 -0
  254. /package/contracts/oapps/{oft → oft-core}/src/codec/oft_msg_codec.rs +0 -0
  255. /package/contracts/oapps/{oft → oft-core}/src/events.rs +0 -0
  256. /package/contracts/oapps/{oft → oft-core}/src/tests/test_oft_compose_msg_codec.rs +0 -0
  257. /package/contracts/oapps/{oft → oft-core}/src/tests/test_oft_version.rs +0 -0
  258. /package/contracts/oapps/{oft → oft-core}/src/tests/test_quote_oft.rs +0 -0
  259. /package/contracts/oapps/{oft → oft-core}/src/tests/test_quote_send.rs +0 -0
  260. /package/contracts/oapps/{oft → oft-core}/src/tests/test_send.rs +0 -0
  261. /package/contracts/oapps/{oft → oft-core}/src/tests/test_token.rs +0 -0
  262. /package/sdk/test/suites/{testUpgradeable.ts → dummyContractClient.ts} +0 -0
@@ -0,0 +1,1016 @@
1
+ import { Buffer } from "buffer";
2
+ import { AssembledTransaction, Client as ContractClient, ClientOptions as ContractClientOptions, MethodOptions } from '@stellar/stellar-sdk/contract';
3
+ import type { u32, u64, i128, Option } from '@stellar/stellar-sdk/contract';
4
+ export * from '@stellar/stellar-sdk';
5
+ export * as contract from '@stellar/stellar-sdk/contract';
6
+ export * as rpc from '@stellar/stellar-sdk/rpc';
7
+ export type MigrationData = void;
8
+ /**
9
+ * Embedded WASM bytecode (base64-encoded)
10
+ * Size: 27240 bytes (26.60 KB)
11
+ */
12
+ export declare const WASM_BASE64 = "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Rg0BIARB0ABqIAVqIARBMGogBWopAwA3AwAgBUEIaiEFDAALCyAEQdAAaiAIQo7U6rWQ17IBIARB0ABqQQQQrYCAgAAQgoCAgAAQqICAgAAgBCgCUEEBRg0EIAQpA2giAkJ/Vw0CIAQpA2AhAwwHCyAEQdAAaiAFakICNwMAIAVBCGohBQwACwtCg4CAgDAQoYCAgAAAC0KDgICAwAAQoYCAgAAACxCugICAAAALQoOAgIAgEKGAgIAAAAsACyADIAIQrICAgAAhAiAEQfAAaiSAgICAACACC30CAX8BfgJAAkACQAJAIAGnQf8BcSICQcUARg0AIAJBC0cNAiAAIAFCP4c3AxggACABQgiHNwMQDAELIAEQiYCAgAAhAyABEIqAgIAAIQEgACADNwMYIAAgATcDEAtCACEBDAELIABCg5CAgIABNwMIQgEhAQsgACABNwMAC4sBAgJ/AX4jgICAgABBEGsiACSAgICAACAAQQRqEJaAgIAAAkAgACgCBEEBRw0AIAAoAgggACgCDBCXgICAAAtBACEBAkBBARCkgICAACICQgIQmYCAgABFDQBBASEBAkACQCACQgIQgICAgACnQf8BcQ4CAQIACwALQQAhAQsgAEEQaiSAgICAACABC4oBAgJ/AX4jgICAgABBEGsiACSAgICAACAAQQRqEJaAgIAAAkAgACgCBEEBRw0AIAAoAgggACgCDBCXgICAAAtBACEBAkACQEEAEKSAgIAAIgJCAhCZgICAAEUNACACQgIQgICAgAAiAkL/AYNCBFINASACQiCIpyEBCyAAQRBqJICAgIAAIAEPCwALkwECAX8CfiOAgICAAEEQayIBJICAgIAAIAFBBGoQloCAgAACQCABKAIEQQFHDQAgASgCCCABKAIMEJeAgIAAC0IAIQICQAJAQQIQpICAgAAiA0ICEJmAgIAARQ0AIANCAhCAgICAACICQv8Bg0LNAFINASAAIAI3AwhCASECCyAAIAI3AwAgAUEQaiSAgICAAA8LAAtFAAJAIABCgICAgICAgMAAfEL//////////wBWDQAgACAAhSABIABCP4eFhEIAUg0AIABCCIZCC4QPCyABIAAQjICAgAALGgAgAK1CIIZCBIQgAa1CIIZCBIQQjoCAgAALCQAQ0oCAgAAAC0EAAkACQCAAQv8Bg0LNAFINAEEAEKKAgIAAQgIQmYCAgAANASAAELCAgIAAQgIPCwALQoOAgICQgQEQoYCAgAAACw4AQQAgAEICEM6AgIAAC9IBAgF/AX4jgICAgABBEGsiASSAgICAAAJAAkAgAEL/AYNCBFINABCagICAACABEJaAgIAAAkAgASgCAEEBRw0AIAEoAgQgASgCCBCXgICAAAsgAEKAgICAkOIJWg0BQQAQpICAgAAgAEKEgICA8P8PgyIAQgIQg4CAgAAaQYCAwIAAQREQsoCAgAAQs4CAgAAhAiABIAA3AwAgAkGggMCAAEEBIAFBARC0gICAABCEgICAABogAUEQaiSAgICAAEICDwsAC0KDgICAEBChgICAAAALRQIBfwF+I4CAgIAAQRBrIgIkgICAgAAgAiAAIAEQ04CAgAACQCACKAIAQQFHDQAACyACKQMIIQMgAkEQaiSAgICAACADC2MDAX8BfgF/I4CAgIAAQRBrIgEkgICAgAAgASAANwMAQgIhAkEBIQMCQANAIANFDQEgA0F/aiEDIAAhAgwACwsgASACNwMIIAFBCGpBARCtgICAACEAIAFBEGokgICAgAAgAAsuAAJAIAEgA0YNAAALIACtQiCGQgSEIAKtQiCGQgSEIAGtQiCGQgSEEI2AgIAAC8ABAgJ/AX4jgICAgABBEGsiASSAgICAAAJAQQEgAKdB/wFxIgJBAEdBAXQgAkEBRhsiAkECRg0AEJqAgIAAIAEQloCAgAACQCABKAIAQQFHDQAgASgCBCABKAIIEJeAgIAAC0EBEKSAgIAAIAKtIgBCAhCDgICAABpBqIDAgABBDxCygICAABCzgICAACEDIAEgADcDACADQcSAwIAAQQEgAUEBELSAgIAAEISAgIAAGiABQRBqJICAgIAAQgIPCwAL4wECAX8CfiOAgICAAEEQayIBJICAgIAAAkACQCAAQgJRDQAgAEL/AYNCzQBSDQELEJqAgIAAIAEQloCAgAACQCABKAIAQQFHDQAgASgCBCABKAIIEJeAgIAAC0ECEKSAgIAAIQICQAJAIABCAlINACACQgIQhYCAgAAaQgAhAgwBCyACIABCAhCDgICAABpCASECC0HMgMCAAEEPELKAgIAAELOAgIAAIQMgASACIAAQt4CAgAA3AwAgA0HogMCAAEEBIAFBARC0gICAABCEgICAABogAUEQaiSAgICAAEICDwsACw0AIAFCAiAAp0EBcRsLiQMDAX8CfgF/I4CAgIAAQcAAayIDJICAgIAAAkAgAEL/AYNCzQBSDQAgAUL/AYNCzQBSDQAgAyACEKiAgIAAIAMoAgBBAUYNACADKQMYIQIgAykDECEEEJqAgIAAIAMQloCAgAACQCADKAIAQQFHDQAgAygCBCADKAIIEJeAgIAACxCGgICAACEFIAMgBCACEKyAgIAANwM4IAMgATcDMCADIAU3AyhBACEGAkADQAJAIAZBGEcNAEEAIQYCQANAIAZBGEYNASADIAZqIANBKGogBmopAwA3AwAgBkEIaiEGDAALCyAAQo7u6pW+tt7zACADQQMQrYCAgAAQgoCAgABC/wGDQgJSDQJB8IDAgABBDxCygICAABCzgICAACEFIAQgAhCsgICAACECIAMgADcDECADIAE3AwggAyACNwMAIAVBjIHAgABBAyADQQMQtICAgAAQhICAgAAaIANBwABqJICAgIAAQgIPCyADIAZqQgI3AwAgBkEIaiEGDAALCxCugICAAAALAAsPABCqgICAAK1CIIZCBIQLCQAQqYCAgACtCz4CAX8BfiOAgICAAEEQayIAJICAgIAAIAAQq4CAgAAgACkDACAAKQMIELeAgIAAIQEgAEEQaiSAgICAACABCwgAEJuAgIAAC+IEAQV/I4CAgIAAQdAAayICJICAgIAAIAJBKGogABC+gICAAAJAIAIoAihBAkYNACACQQhqQQhqIAJBKGpBCGoiAygCADYCACACIAIpAig3AwggAkEoaiABEL6AgIAAIAIoAihBAkYNACACQRhqQQhqIAMoAgA2AgAgAiACKQIoNwMYIAJBKGoQloCAgAACQCACKAIoQQFHDQAgAigCLCACKAIwEJeAgIAACxCagICAAAJAAkACQBCVgICAAA0AEL+AgIAAIgNBgPuAAyADQYD7gANJGyEEIAIgAkEYajYCLCACIAJBCGo2AihBACEDA0AgA0EIRg0DAkAgAkEoaiADaigCACIFKAIAQQFxRQ0AIAUoAggiBiAESw0DIAUoAgQgBksNAwsgA0EEaiEDDAALC0KDgICA0P8AEKGAgIAAAAtCg4CAgMD/ABChgICAAAALAkACQCACKAIIQQFHDQBBASACKAIMIAIoAhAQwICAgAAMAQtBARCYgICAAEICEIWAgIAAGgsCQAJAIAIoAhhBAUcNAEECIAIoAhwgAigCIBDAgICAAAwBC0ECEJiAgIAAQgIQhYCAgAAaCyACQShqQQhqIAJBCGpBCGooAgA2AgAgAkE8aiACQRhqQQhqKAIANgIAIAIgAikDCDcDKCACIAIpAxg3AjRBgIPAgABBDxCygICAABCzgICAACEAIAJBKGoQwYCAgAAhASACIAJBNGoQwYCAgAA3A0ggAiABNwNAIABBpIPAgABBAiACQcAAakECELSAgIAAEISAgIAAGiACQdAAaiSAgICAAEICDwsAC2gBAX8jgICAgABBEGsiAiSAgICAAAJAAkAgAUICUQ0AIAJBBGogARDUgICAAAJAIAIoAgRFDQAgAEECNgIADAILIAAgAikCCDcCBCAAQQE2AgAMAQsgAEEANgIACyACQRBqJICAgIAACzMBAn4Qj4CAgAAhAAJAEJCAgIAAQiCIIgEgAEIgiCIAVA0AIAGnIACnaw8LEK6AgIAAAAtWAgF/AX4jgICAgABBEGsiAySAgICAACAAEJiAgIAAIQQgAyABIAIQ1YCAgAACQCADKAIAQQFHDQAACyAEIAMpAwhCAhCDgICAABogA0EQaiSAgICAAAtDAgF/AX4jgICAgABBEGsiASSAgICAACABIAAQxICAgAACQCABKAIAQQFHDQAACyABKQMIIQIgAUEQaiSAgICAACACC8QBAgJ/AX4jgICAgABBwABrIgAkgICAgAAgAEEIahCWgICAAAJAIAAoAghBAUcNACAAKAIMIAAoAhAQl4CAgAALIABBCGoQloCAgAAgAEEUaiIBQQIQw4CAgAAgAEEwaiAAQQhqEMSAgIAAAkACQCAAKAIwDQAgACkDOCECIABBMGogARDEgICAACAAKAIwQQFHDQELAAsgACAAKQM4NwMoIAAgAjcDICAAQSBqQQIQrYCAgAAhAiAAQcAAaiSAgICAACACC3cCAn8BfiOAgICAAEEQayICJICAgIAAQQAhAwJAAkAgARCYgICAACIEQgIQmYCAgABFDQAgAkEEaiAEQgIQgICAgAAQ1ICAgABBASEDIAIoAgRBAUYNASAAIAIpAgg3AgQLIAAgAzYCACACQRBqJICAgIAADwsACzAAAkAgASgCAEEBRw0AIAAgASgCBCABKAIIENWAgIAADwsgAEIANwMAIABCAjcDCAuqAQEBfyOAgICAAEEgayIAJICAgIAAIABBDGoQloCAgAACQCAAKAIMQQFHDQAgACgCECAAKAIUEJeAgIAACxCagICAAAJAEJWAgIAARQ0AQoOAgIDg/wAQoYCAgAAAC0EAEJiAgIAAQgFCAhCDgICAABpBtIPAgABBEhCygICAABCzgICAAEEEQQAgAEEYakEAELSAgIAAEISAgIAAGiAAQSBqJICAgIAAQgILCQAQlYCAgACtCzEAAkAgAEL/AYNCBFINACABQv8Bg0IEUg0AIABCIIinIAFCIIinEJeAgIAAQgIPCwALPgIBfwF+I4CAgIAAQRBrIgAkgICAgAAgABCdgICAACAAKQMAIAApAwgQt4CAgAAhASAAQRBqJICAgIAAIAELPgIBfwF+I4CAgIAAQRBrIgAkgICAgAAgABCggICAACAAKQMAIAApAwgQt4CAgAAhASAAQRBqJICAgIAAIAELfQIBfwF+I4CAgIAAQRBrIgEkgICAgAACQCAAQv8Bg0LNAFINACABQQRqEJaAgIAAAkAgASgCBEEBRw0AIAEoAgggASgCDBCXgICAAAsQnICAgAAhAhCfgICAACAAELCAgIAAIAIgABDLgICAACABQRBqJICAgIAAQgIPCwALYQIBfwF+I4CAgIAAQRBrIgIkgICAgABBy4HAgABBFRCygICAABCzgICAACEDIAIgADcDCCACIAE3AwAgA0H0gcCAAEECIAJBAhC0gICAABCEgICAABogAkEQaiSAgICAAAvdAgIBfwJ+I4CAgIAAQSBrIgIkgICAgAACQAJAAkAgAEL/AYNCzQBSDQAgAUL/AYNCBFINACACQQhqEJaAgIAAAkAgAigCCEEBRw0AIAIoAgwgAigCEBCXgICAAAsQnICAgAAhAwJAAkAgAUL/////D1YNACACQQhqEKCAgIAAIAIpAxAhASACKQMIQYgIEJ6AgIAAIAEgABCHgICAAFBFDQMQzYCAgAAMAQsQv4CAgAAgAUIgiKdJDQNBASAAQgAQzoCAgABBARCigICAAEIAIAFChICAgHCDIgEgARCIgICAABpBhILAgABBFhCygICAABCzgICAACEEIAIgATcDGCACIAM3AxAgAiAANwMIIARBoILAgABBAyACQQhqQQMQtICAgAAQhICAgAAaCyACQSBqJICAgIAAQgIPCwALQoOAgIDggAEQoYCAgAAAC0KDgICA8IABEKGAgIAAAAsTAEEBEKKAgIAAQgAQhYCAgAAaCxUAIAAQooCAgAAgASACEIOAgIAAGgunAQIBfwJ+I4CAgIAAQRBrIgAkgICAgAAgABCWgICAAAJAIAAoAgBBAUcNACAAKAIEIAAoAggQl4CAgAALIAAQoICAgAAgACkDCCEBIAApAwBBiAgQnoCAgAAgARCBgICAABogABCjgICAAAJAIAAoAgANABDQgICAAAALIAApAwghAhDNgICAACABELCAgIAAIAIgARDLgICAACAAQRBqJICAgIAAQgILCQAQroCAgAAAC6ABAgF/An4jgICAgABBEGsiACSAgICAACAAEJaAgIAAAkAgACgCAEEBRw0AIAAoAgQgACgCCBCXgICAAAsQnICAgAAhARCfgICAAEEAEKKAgIAAQgIQhYCAgAAaQbiCwIAAQRMQsoCAgAAQs4CAgAAhAiAAIAE3AwAgAkHMgsCAAEEBIABBARC0gICAABCEgICAABogAEEQaiSAgICAAEICCwMAAAvbAQIBfgR/AkACQCACQQlLDQBCACEDIAIhBCABIQUDQAJAIAQNACADQgiGQg6EIQMMAwtBASEGAkAgBS0AACIHQd8ARg0AAkAgB0FQakH/AXFBCkkNAAJAIAdBv39qQf8BcUEaSQ0AIAdBn39qQf8BcUEZSw0EIAdBRWohBgwCCyAHQUtqIQYMAQsgB0FSaiEGCyADQgaGIAatQv8Bg4QhAyAEQX9qIQQgBUEBaiEFDAALCyABrUIghkIEhCACrUIghkIEhBCLgICAACEDCyAAQgA3AwAgACADNwMIC74BAgJ/AX4jgICAgABBEGsiAiSAgICAAEEAIQMCQANAIANBEEYNASACIANqQgI3AwAgA0EIaiEDDAALC0EBIQMCQCABQv8Bg0LMAFINACABQfCCwIAArUIghkIEhCACrUIghkIEhEKEgICAIBCUgICAABogAikDACIBQv8Bg0IEUg0AIAIpAwgiBEL/AYNCBFINACAAIAFCIIinNgIIIAAgBEIgiD4CBEEAIQMLIAAgAzYCACACQRBqJICAgIAAC2ACAX8BfiOAgICAAEEQayIDJICAgIAAIAMgAa1CIIZCBIQ3AwggAyACrUIghkIEhDcDAEHwgsCAAEECIANBAhC0gICAACEEIABCADcDACAAIAQ3AwggA0EQaiSAgICAAAvVAwMBfwJ+An8jgICAgABB4ABrIgYkgICAgABCACEHQgAhCEEAIQkCQCABIAKEUA0AIAMgBIRQDQBCACADfSADIARCAFMiCRshB0IAIAF9IAEgAkIAUyIKGyEIQgAgBCADQgBSrXx9IAQgCRshAyAEIAKFIQQCQAJAQgAgAiABQgBSrXx9IAIgChsiAlANAAJAIANQDQAgBkHQAGogByADIAggAhDbgICAAEEBIQkgBikDWCEBIAYpA1AhAgwCCyAGQcAAaiAHIAMgCEIAENuAgIAAIAZBMGogByADIAJCABDbgICAACAGKQNIIgIgBikDMHwiASACVCAGKQM4QgBSciEJIAYpA0AhAgwBCwJAIANQDQAgBkEgaiAHQgAgCCACENuAgIAAIAZBEGogA0IAIAggAhDbgICAACAGKQMoIgIgBikDEHwiASACVCAGKQMYQgBSciEJIAYpAyAhAgwBCyAGIAcgAyAIIAIQ24CAgABBACEJIAYpAwghASAGKQMAIQILQgAgAn0gAiAEQgBTIgobIQhCACABIAJCAFKtfH0gASAKGyIHIASFQgBZDQBBASEJCyAAIAg3AwAgBSAJNgIAIAAgBzcDCCAGQeAAaiSAgICAAAtXAQF+AkACQCADQcAAcQ0AIANFDQEgAiADQT9xrSIEhiABQQAgA2tBP3GtiIQhAiABIASGIQEMAQsgASADQT9xrYYhAkIAIQELIAAgATcDACAAIAI3AwgL0QgEAX8BfgN/BH4jgICAgABBsAFrIgUkgICAgABCACEGAkACQAJAAkACQCAEeSADeULAAHwgBEIAUhunIgcgAnkgAXlCwAB8IAJCAFIbpyIITQ0AIAhBP0sNASAHQd8ASw0CIAcgCGtBIEkNAyAFQaABaiADIARB4AAgB2siCRDagICAACAFNQKgAUIBfCEKQgAhC0IAIQYCQAJAAkACQANAIAVBkAFqIAEgAkHAACAIayIIENqAgIAAIAUpA5ABIQwCQCAIIAlPDQAgBUHQAGogAyAEIAgQ2oCAgAACQAJAIAUpA1AiClBFDQAMAQsgDCAKgCEMCyAFQcAAaiADIAQgDEIAENuAgIAAAkAgASAFKQNAIg1UIgggAiAFKQNIIgpUIAIgClEbDQAgAiAKfSAIrX0hAiABIA19IQEgBiALIAx8IgwgC1StfCEGDAsLIAIgBHwgASADfCIEIAFUrXwgCn0gBCANVK19IQIgBCANfSEBIAYgDCALfEJ/fCIMIAtUrXwhBgwKCyAFQYABaiAMIAqAIgxCACAIIAlrIggQ14CAgAAgBUHwAGogAyAEIAxCABDbgICAACAFQeAAaiAFKQNwIAUpA3ggCBDXgICAACAFKQOIASAGfCAFKQOAASIGIAt8IgsgBlStfCEGIAcgAiAFKQNofSABIAUpA2AiDFStfSICeSABIAx9IgF5QsAAfCACQgBSG6ciCE0NASAIQT9NDQALIANQRQ0BDAILIAEgA1QiCCACIARUIAIgBFEbRQ0CIAshDAwHCyABIAOAIQILIAEgA4IhASAGIAsgAnwiDCALVK18IQZCACECDAULIAIgBH0gCK19IQIgASADfSEBIAYgC0IBfCIMUK18IQYMBAsgAiAEQgAgASADWiACIARaIAIgBFEbIggbfSABIANCACAIGyIEVK19IQIgASAEfSEBIAitIQwMAwsgASABIAOAIgwgA359IQFCACEGQgAhAgwCCyACIAIgA0L/////D4MiBIAiBiADfn1CIIYgAUIgiCIMhCAEgCICQiCGIAwgAiADfn1CIIYgAUL/////D4OEIgEgBIAiA4QhDCABIAMgBH59IQEgAkIgiCAGhCEGQgAhAgwBCyAFQTBqIAMgBEHAACAIayIIENqAgIAAIAVBIGogASACIAgQ2oCAgABCACEGIAVBEGogA0IAIAUpAyAgBSkDMIAiDEIAENuAgIAAIAUgBEIAIAxCABDbgICAACAFKQMQIQoCQAJAIAUpAwggBSkDGCINIAUpAwB8IgsgDVStfEIAUg0AIAEgClQiCCACIAtUIAIgC1EbRQ0BCyAEIAJ8IAMgAXwiASADVK18IAt9IAEgClStfSECIAxCf3whDCABIAp9IQEMAQsgAiALfSAIrX0hAiABIAp9IQFCACEGCyAAIAE3AxAgACAMNwMAIAAgAjcDGCAAIAY3AwggBUGwAWokgICAgAALoQEBAn8jgICAgABBIGsiBSSAgICAACAFQgAgAX0gASACQgBTIgYbQgAgAiABQgBSrXx9IAIgBhtCACADfSADIARCAFMiBhtCACAEIANCAFKtfH0gBCAGGxDYgICA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AAAQdG90YWxfbmF0aXZlX2ZlZQAAAAsAAAAAAAAACnBheV9pbl96cm8AAAAAAAEAAAABAAAACwAAAAAAAAAAAAAADV9fY29uc3RydWN0b3IAAAAAAAABAAAAAAAAAAVvd25lcgAAAAAAABMAAAAAAAAAAAAAAI1TZXRzIHRoZSBuYXRpdmUgZmVlIHBlcmNlbnRhZ2UgaW4gYmFzaXMgcG9pbnRzLgoKIyBBcmd1bWVudHMKKiBgbmF0aXZlX2ZlZV9icGAgLSBGZWUgcGVyY2VudGFnZSBpbiBiYXNpcyBwb2ludHMgKDAtMTAwMDAsIHdoZXJlIDEwMDAwID0gMTAwJSkAAAAAAAARc2V0X25hdGl2ZV9mZWVfYnAAAAAAAAABAAAAAAAAAA1uYXRpdmVfZmVlX2JwAAAAAAAABAAAAAAAAAAAAAAAbUVuYWJsZXMgb3IgZGlzYWJsZXMgZmVlIGNvbGxlY3Rpb24gZ2xvYmFsbHkuCgojIEFyZ3VtZW50cwoqIGBmZWVfZW5hYmxlZGAgLSBXaGV0aGVyIGZlZSBjb2xsZWN0aW9uIGlzIGVuYWJsZWQAAAAAAAAPc2V0X2ZlZV9lbmFibGVkAAAAAAEAAAAAAAAAC2ZlZV9lbmFibGVkAAAAAAEAAAAAAAAAAAAAAKNTZXRzIG9yIHJlbW92ZXMgdGhlIFpSTyBmZWUgbGlicmFyeSBmb3IgY3VzdG9tIFpSTyB0b2tlbiBmZWUgY2FsY3VsYXRpb25zLgoKIyBBcmd1bWVudHMKKiBgenJvX2ZlZV9saWJgIC0gVGhlIFpSTyBmZWUgbGlicmFyeSBjb250cmFjdCBhZGRyZXNzLCBvciBgTm9uZWAgdG8gcmVtb3ZlAAAAAA9zZXRfenJvX2ZlZV9saWIAAAAAAQAAAAAAAAALenJvX2ZlZV9saWIAAAAD6AAAABMAAAAAAAAAAAAAATdXaXRoZHJhd3MgYW55IHRva2VuIChpbmNsdWRpbmcgbmF0aXZlIFhMTSkgZnJvbSB0aGUgY29udHJhY3QgdG8gYSBzcGVjaWZpZWQgYWRkcmVzcy4KCk9ubHkgdGhlIGNvbnRyYWN0IG93bmVyIGNhbiBleGVjdXRlIHRoaXMgbWV0aG9kLgoKIyBBcmd1bWVudHMKKiBgdG9rZW5gIC0gVGhlIHRva2VuIGNvbnRyYWN0IGFkZHJlc3MgKGNhbiBiZSBuYXRpdmUgWExNIG9yIGFueSBvdGhlciB0b2tlbikKKiBgdG9gIC0gVGhlIHJlY2lwaWVudCBhZGRyZXNzCiogYGFtb3VudGAgLSBUaGUgYW1vdW50IHRvIHdpdGhkcmF3IChtdXN0IGJlIHBvc2l0aXZlKQAAAAAOd2l0aGRyYXdfdG9rZW4AAAAAAAMAAAAAAAAABXRva2VuAAAAAAAAEwAAAAAAAAACdG8AAAAAABMAAAAAAAAABmFtb3VudAAAAAAACwAAAAAAAAAAAAAAMlJldHVybnMgdGhlIG5hdGl2ZSBmZWUgcGVyY2VudGFnZSBpbiBiYXNpcyBwb2ludHMuAAAAAAANbmF0aXZlX2ZlZV9icAAAAAAAAAAAAAABAAAABAAAAAAAAAAqUmV0dXJucyB3aGV0aGVyIGZlZSBjb2xsZWN0aW9uIGlzIGVuYWJsZWQuAAAAAAALZmVlX2VuYWJsZWQAAAAAAAAAAAEAAAABAAAAAAAAACtSZXR1cm5zIHRoZSBaUk8gZmVlIGxpYnJhcnkgYWRkcmVzcyBpZiBzZXQuAAAAAAt6cm9fZmVlX2xpYgAAAAAAAAAAAQAAA+gAAAATAAAAAAAAAAAAAAAKYXV0aG9yaXplcgAAAAAAAAAAAAEAAAATAAAAAgAAAAAAAAAAAAAAD1RyZWFzdXJ5U3RvcmFnZQAAAAADAAAAAAAAAAAAAAALTmF0aXZlRmVlQnAAAAAAAAAAAAAAAAAKRmVlRW5hYmxlZAAAAAAAAAAAAAAAAAAJWnJvRmVlTGliAAAAAAAAAAAAAY9TZXRzIFRUTCBjb25maWdzIGZvciBpbnN0YW5jZSBhbmQgcGVyc2lzdGVudCBzdG9yYWdlLgoKLSBgTm9uZWAgdmFsdWVzIHJlbW92ZSB0aGUgY29ycmVzcG9uZGluZyBjb25maWcgKGRpc2FibGVzIGF1dG8tZXh0ZW5zaW9uIGZvciB0aGF0IHR5cGUpCi0gVmFsaWRhdGVzIHRoYXQgYHRocmVzaG9sZCA8PSBleHRlbmRfdG8gPD0gTUFYX1RUTGAKCiMgQXJndW1lbnRzCi0gYGluc3RhbmNlYCAtIFRUTCBjb25maWcgZm9yIGluc3RhbmNlIHN0b3JhZ2UKLSBgcGVyc2lzdGVudGAgLSBUVEwgY29uZmlnIGZvciBwZXJzaXN0ZW50IHN0b3JhZ2UKCiMgUGFuaWNzCi0gYFR0bENvbmZpZ0Zyb3plbmAgaWYgY29uZmlncyBhcmUgZnJvemVuCi0gYEludmFsaWRUdGxDb25maWdgIGlmIHZhbGlkYXRpb24gZmFpbHMAAAAAD3NldF90dGxfY29uZmlncwAAAAACAAAAAAAAAAhpbnN0YW5jZQAAA+gAAAfQAAAACVR0bENvbmZpZwAAAAAAAAAAAAAKcGVyc2lzdGVudAAAAAAD6AAAB9AAAAAJVHRsQ29uZmlnAAAAAAAAAAAAAAAAAABIUmV0dXJucyB0aGUgY3VycmVudCBUVEwgY29uZmlncyBhcyAoaW5zdGFuY2VfY29uZmlnLCBwZXJzaXN0ZW50X2NvbmZpZykuAAAAC3R0bF9jb25maWdzAAAAAAAAAAABAAAD7QAAAAIAAAPoAAAH0AAAAAlUdGxDb25maWcAAAAAAAPoAAAH0AAAAAlUdGxDb25maWcAAAAAAAAAAAAA4VBlcm1hbmVudGx5IGZyZWV6ZXMgVFRMIGNvbmZpZ3MsIHByZXZlbnRpbmcgYW55IGZ1dHVyZSBtb2RpZmljYXRpb25zLgoKVGhpcyBpcyBpcnJldmVyc2libGUgYW5kIHByb3ZpZGVzIGltbXV0YWJpbGl0eSBndWFyYW50ZWVzIHRvIHVzZXJzLgpFbWl0cyBgVHRsQ29uZmlnc0Zyb3plbmAgZXZlbnQuCgojIFBhbmljcwotIGBUdGxDb25maWdBbHJlYWR5RnJvemVuYCBpZiBhbHJlYWR5IGZyb3plbgAAAAAAABJmcmVlemVfdHRsX2NvbmZpZ3MAAAAAAAAAAAAAAAAAAAAAACdSZXR1cm5zIHdoZXRoZXIgVFRMIGNvbmZpZ3MgYXJlIGZyb3plbi4AAAAAFWlzX3R0bF9jb25maWdzX2Zyb3plbgAAAAAAAAAAAAABAAAAAQAAAAAAAAClRXh0ZW5kcyB0aGUgaW5zdGFuY2UgVFRMLgoKIyBBcmd1bWVudHMKCiogYHRocmVzaG9sZGAgLSBUaGUgdGhyZXNob2xkIHRvIGV4dGVuZCB0aGUgVFRMIChpZiBjdXJyZW50IFRUTCBpcyBiZWxvdyB0aGlzLCBleHRlbmQpLgoqIGBleHRlbmRfdG9gIC0gVGhlIFRUTCB0byBleHRlbmQgdG8uAAAAAAAAE2V4dGVuZF9pbnN0YW5jZV90dGwAAAAAAgAAAAAAAAAJdGhyZXNob2xkAAAAAAAABAAAAAAAAAAJZXh0ZW5kX3RvAAAAAAAABAAAAAAAAAAAAAAAPlJldHVybnMgdGhlIGN1cnJlbnQgb3duZXIgYWRkcmVzcywgb3IgTm9uZSBpZiBubyBvd25lciBpcyBzZXQuAAAAAAAFb3duZXIAAAAAAAAAAAAAAQAAA+gAAAATAAAAAAAAAFlSZXR1cm5zIHRoZSBwZW5kaW5nIG93bmVyIGFkZHJlc3MgZm9yIDItc3RlcCB0cmFuc2Zlciwgb3IgTm9uZSBpZiBubyB0cmFuc2ZlciBpcyBwZW5kaW5nLgAAAAAAAA1wZW5kaW5nX293bmVyAAAAAAAAAAAAAAEAAAPoAAAAEwAAAAAAAAErVHJhbnNmZXJzIG93bmVyc2hpcCBpbW1lZGlhdGVseSB0byBhIG5ldyBhZGRyZXNzLgoKVXNlIHdpdGggY2F1dGlvbiAtIGlmIHlvdSB0cmFuc2ZlciB0byBhIHdyb25nIGFkZHJlc3MsIG93bmVyc2hpcCBpcyBsb3N0IGZvcmV2ZXIuCkNvbnNpZGVyIHVzaW5nIGBwcm9wb3NlX293bmVyc2hpcF90cmFuc2ZlcmAgaW5zdGVhZC4KCiMgUGFuaWNzCi0gYE93bmVyTm90U2V0YCBpZiBubyBvd25lciBpcyBjdXJyZW50bHkgc2V0Ci0gYFRyYW5zZmVySW5Qcm9ncmVzc2AgaWYgYSAyLXN0ZXAgdHJhbnNmZXIgaXMgaW4gcHJvZ3Jlc3MAAAAAEnRyYW5zZmVyX293bmVyc2hpcAAAAAAAAQAAAAAAAAAJbmV3X293bmVyAAAAAAAAEwAAAAAAAAAAAAACXFByb3Bvc2VzIGFuIG93bmVyc2hpcCB0cmFuc2ZlciB0byBhIG5ldyBhZGRyZXNzLgoKVGhlIG5ldyBvd25lciBtdXN0IGNhbGwgYGFjY2VwdF9vd25lcnNoaXAoKWAgd2l0aGluIGB0dGxgIGxlZGdlcnMKdG8gY29tcGxldGUgdGhlIHRyYW5zZmVyLiBUaGUgcGVuZGluZyB0cmFuc2ZlciB3aWxsIGF1dG9tYXRpY2FsbHkgZXhwaXJlIGFmdGVyLgoKIyBBcmd1bWVudHMKLSBgbmV3X293bmVyYCAtIFRoZSBwcm9wb3NlZCBuZXcgb3duZXIKLSBgdHRsYCAtIE51bWJlciBvZiBsZWRnZXJzIHRoZSBuZXcgb3duZXIgaGFzIHRvIGFjY2VwdC4KVXNlIGAwYCB0byBjYW5jZWwgYSBwZW5kaW5nIHRyYW5zZmVyIChuZXdfb3duZXIgbXVzdCBtYXRjaCBwZW5kaW5nKS4KCiMgUGFuaWNzCi0gYE93bmVyTm90U2V0YCBpZiBubyBvd25lciBpcyBjdXJyZW50bHkgc2V0Ci0gYE5vUGVuZGluZ1RyYW5zZmVyYCB3aGVuIGNhbmNlbGxpbmcgYW5kIG5vIHBlbmRpbmcgdHJhbnNmZXIgZXhpc3RzCi0gYEludmFsaWRUdGxgIGlmIHR0bCBleGNlZWRzIG1heCBUVEwKLSBgSW52YWxpZFBlbmRpbmdPd25lcmAgd2hlbiBjYW5jZWxsaW5nIHdpdGggd3JvbmcgbmV3X293bmVyIGFkZHJlc3MAAAAacHJvcG9zZV9vd25lcnNoaXBfdHJhbnNmZXIAAAAAAAIAAAAAAAAACW5ld19vd25lcgAAAAAAABMAAAAAAAAAA3R0bAAAAAAEAAAAAAAAAAAAAAC5QWNjZXB0cyBhIHBlbmRpbmcgMi1zdGVwIG93bmVyc2hpcCB0cmFuc2Zlci4KCk11c3QgYmUgY2FsbGVkIGJ5IHRoZSBwZW5kaW5nIG93bmVyIGJlZm9yZSB0aGUgVFRMIGV4cGlyZXMuCgojIFBhbmljcwotIGBOb1BlbmRpbmdUcmFuc2ZlcmAgaWYgdGhlcmUgaXMgbm8gcGVuZGluZyB0cmFuc2ZlciAob3IgaXQgZXhwaXJlZCkAAAAAAAAQYWNjZXB0X293bmVyc2hpcAAAAAAAAAAAAAAAAAAAAKRQZXJtYW5lbnRseSByZW5vdW5jZXMgb3duZXJzaGlwLgoKIyBQYW5pY3MKLSBgT3duZXJOb3RTZXRgIGlmIG5vIG93bmVyIGlzIGN1cnJlbnRseSBzZXQKLSBgVHJhbnNmZXJJblByb2dyZXNzYCBpZiBhIDItc3RlcCB0cmFuc2ZlciBpcyBpbiBwcm9ncmVzcyAoY2FuY2VsIGl0IGZpcnN0KQAAABJyZW5vdW5jZV9vd25lcnNoaXAAAAAAAAAAAAAAAAAABAAAAAAAAAAAAAAADUVuZHBvaW50RXJyb3IAAAAAAAAZAAAAAAAAABFBbHJlYWR5UmVnaXN0ZXJlZAAAAAAAAAEAAAAAAAAADUNvbXBvc2VFeGlzdHMAAAAAAAACAAAAAAAAAA9Db21wb3NlTm90Rm91bmQAAAAAAwAAAAAAAAAcRGVmYXVsdFJlY2VpdmVMaWJVbmF2YWlsYWJsZQAAAAQAAAAAAAAAGURlZmF1bHRTZW5kTGliVW5hdmFpbGFibGUAAAAAAAAFAAAAAAAAABVJbnN1ZmZpY2llbnROYXRpdmVGZWUAAAAAAAAGAAAAAAAAABJJbnN1ZmZpY2llbnRacm9GZWUAAAAAAAcAAAAAAAAAEEludmFsaWRGZWVBbW91bnQAAAAIAAAAAAAAAA1JbnZhbGlkRXhwaXJ5AAAAAAAACQAAAAAAAAAMSW52YWxpZEluZGV4AAAACgAAAAAAAAAMSW52YWxpZE5vbmNlAAAACwAAAAAAAAASSW52YWxpZFBheWxvYWRIYXNoAAAAAAAMAAAAAAAAABVJbnZhbGlkUmVjZWl2ZUxpYnJhcnkAAAAAAAANAAAAAAAAABFPbmx5Tm9uRGVmYXVsdExpYgAAAAAAAA4AAAAAAAAADk9ubHlSZWNlaXZlTGliAAAAAAAPAAAAAAAAABFPbmx5UmVnaXN0ZXJlZExpYgAAAAAAABAAAAAAAAAAC09ubHlTZW5kTGliAAAAABEAAAAAAAAAFFBhdGhOb3RJbml0aWFsaXphYmxlAAAAEgAAAAAAAAARUGF0aE5vdFZlcmlmaWFibGUAAAAAAAATAAAAAAAAABNQYXlsb2FkSGFzaE5vdEZvdW5kAAAAABQAAAAAAAAACVNhbWVWYWx1ZQAAAAAAABUAAAAAAAAADFVuYXV0aG9yaXplZAAAABYAAAAAAAAADlVuc3VwcG9ydGVkRWlkAAAAAAAXAAAAAAAAAApaZXJvWnJvRmVlAAAAAAAYAAAAAAAAAA5acm9VbmF2YWlsYWJsZQAAAAAAGQAAAAUAAAAAAAAAAAAAAApQYWNrZXRTZW50AAAAAAABAAAAC3BhY2tldF9zZW50AAAAAAMAAAAAAAAADmVuY29kZWRfcGFja2V0AAAAAAAOAAAAAAAAAAAAAAAHb3B0aW9ucwAAAAAOAAAAAAAAAAAAAAAMc2VuZF9saWJyYXJ5AAAAEwAAAAAAAAACAAAABQAAAAAAAAAAAAAADlBhY2tldFZlcmlmaWVkAAAAAAABAAAAD3BhY2tldF92ZXJpZmllZAAAAAADAAAAAAAAAAZvcmlnaW4AAAAAB9AAAAAGT3JpZ2luAAAAAAABAAAAAAAAAAhyZWNlaXZlcgAAABMAAAABAAAAAAAAAAxwYXlsb2FkX2hhc2gAAAPuAAAAIAAAAAAAAAACAAAABQAAAAAAAAAAAAAAD1BhY2tldERlbGl2ZXJlZAAAAAABAAAAEHBhY2tldF9kZWxpdmVyZWQAAAACAAAAAAAAAAZvcmlnaW4AAAAAB9AAAAAGT3JpZ2luAAAAAAABAAAAAAAAAAhyZWNlaXZlcgAAABMAAAABAAAAAgAAAAUAAAAAAAAAAAAAAA5MelJlY2VpdmVBbGVydAAAAAAAAQAAABBsel9yZWNlaXZlX2FsZXJ0AAAACQAAAAAAAAAIcmVjZWl2ZXIAAAATAAAAAQAAAAAAAAAIZXhlY3V0b3IAAAATAAAAAQAAAAAAAAAGb3JpZ2luAAAAAAfQAAAABk9yaWdpbgAAAAAAAQAAAAAAAAAEZ3VpZAAAA+4AAAAgAAAAAQAAAAAAAAADZ2FzAAAAAAsAAAAAAAAAAAAAAAV2YWx1ZQAAAAAAAAsAAAAAAAAAAAAAAAdtZXNzYWdlAAAAAA4AAAAAAAAAAAAAAApleHRyYV9kYXRhAAAAAAAOAAAAAAAAAAAAAAAGcmVhc29uAAAAAAAOAAAAAAAAAAIAAAAFAAAAAAAAAAAAAAAGWnJvU2V0AAAAAAABAAAAB3pyb19zZXQAAAAAAQAAAAAAAAADenJvAAAAABMAAAAAAAAAAgAAAAUAAAAAAAAAAAAAAAtEZWxlZ2F0ZVNldAAAAAABAAAADGRlbGVnYXRlX3NldAAAAAIAAAAAAAAABG9hcHAAAAATAAAAAQAAAAAAAAAIZGVsZWdhdGUAAAPoAAAAEwAAAAAAAAACAAAABQAAAAAAAAAAAAAAE0luYm91bmROb25jZVNraXBwZWQAAAAAAQAAABVpbmJvdW5kX25vbmNlX3NraXBwZWQAAAAAAAAEAAAAAAAAAAdzcmNfZWlkAAAAAAQAAAABAAAAAAAAAAZzZW5kZXIAAAAAA+4AAAAgAAAAAQAAAAAAAAAIcmVjZWl2ZXIAAAATAAAAAQAAAAAAAAAFbm9uY2UAAAAAAAAGAAAAAQAAAAIAAAAFAAAAAAAAAAAAAAAOUGFja2V0TmlsaWZpZWQAAAAAAAEAAAAPcGFja2V0X25pbGlmaWVkAAAAAAUAAAAAAAAAB3NyY19laWQAAAAABAAAAAEAAAAAAAAABnNlbmRlcgAAAAAD7gAAACAAAAABAAAAAAAAAAhyZWNlaXZlcgAAABMAAAABAAAAAAAAAAVub25jZQAAAAAAAAYAAAABAAAAAAAAAAxwYXlsb2FkX2hhc2gAAAPoAAAD7gAAACAAAAAAAAAAAgAAAAUAAAAAAAAAAAAAAAtQYWNrZXRCdXJudAAAAAABAAAADHBhY2tldF9idXJudAAAAAUAAAAAAAAAB3NyY19laWQAAAAABAAAAAEAAAAAAAAABnNlbmRlcgAAAAAD7gAAACAAAAABAAAAAAAAAAhyZWNlaXZlcgAAABMAAAABAAAAAAAAAAVub25jZQAAAAAAAAYAAAABAAAAAAAAAAxwYXlsb2FkX2hhc2gAAAPuAAAAIAAAAAAAAAACAAAABQAAAAAAAAAAAAAAEUxpYnJhcnlSZWdpc3RlcmVkAAAAAAAAAQAAABJsaWJyYXJ5X3JlZ2lzdGVyZWQAAAAAAAEAAAAAAAAAB25ld19saWIAAAAAEwAAAAAAAAACAAAABQAAAAAAAAAAAAAAFURlZmF1bHRTZW5kTGlicmFyeVNldAAAAAAAAAEAAAAYZGVmYXVsdF9zZW5kX2xpYnJhcnlfc2V0AAAAAgAAAAAAAAAHZHN0X2VpZAAAAAAEAAAAAQAAAAAAAAAHbmV3X2xpYgAAAAATAAAAAAAAAAIAAAAFAAAAAAAAAAAAAAAYRGVmYXVsdFJlY2VpdmVMaWJyYXJ5U2V0AAAAAQAAABtkZWZhdWx0X3JlY2VpdmVfbGlicmFyeV9zZXQAAAAAAgAAAAAAAAAHc3JjX2VpZAAAAAAEAAAAAQAAAAAAAAAHbmV3X2xpYgAAAAATAAAAAAAAAAIAAAAFAAAAAAAAAAAAAAAbRGVmYXVsdFJlY2VpdmVMaWJUaW1lb3V0U2V0AAAAAAEAAAAfZGVmYXVsdF9yZWNlaXZlX2xpYl90aW1lb3V0X3NldAAAAAACAAAAAAAAAAdzcmNfZWlkAAAAAAQAAAABAAAAAAAAAAd0aW1lb3V0AAAAA+gAAAfQAAAAB1RpbWVvdXQAAAAAAAAAAAIAAAAFAAAAAAAAAAAAAAAOU2VuZExpYnJhcnlTZXQAAAAAAAEAAAAQc2VuZF9saWJyYXJ5X3NldAAAAAMAAAAAAAAABnNlbmRlcgAAAAAAEwAAAAEAAAAAAAAAB2RzdF9laWQAAAAABAAAAAEAAAAAAAAAB25ld19saWIAAAAD6AAAABMAAAAAAAAAAgAAAAUAAAAAAAAAAAAAABFSZWNlaXZlTGlicmFyeVNldAAAAAAAAAEAAAATcmVjZWl2ZV9saWJyYXJ5X3NldAAAAAADAAAAAAAAAAhyZWNlaXZlcgAAABMAAAABAAAAAAAAAAdzcmNfZWlkAAAAAAQAAAABAAAAAAAAAAduZXdfbGliAAAAA+gAAAATAAAAAAAAAAIAAAAFAAAAAAAAAAAAAAAYUmVjZWl2ZUxpYnJhcnlUaW1lb3V0U2V0AAAAAQAAABtyZWNlaXZlX2xpYnJhcnlfdGltZW91dF9zZXQAAAAAAwAAAAAAAAAIcmVjZWl2ZXIAAAATAAAAAQAAAAAAAAADZWlkAAAAAAQAAAABAAAAAAAAAAd0aW1lb3V0AAAAA+gAAAfQAAAAB1RpbWVvdXQAAAAAAAAAAAIAAAAFAAAAAAAAAAAAAAALQ29tcG9zZVNlbnQAAAAAAQAAAAxjb21wb3NlX3NlbnQAAAAFAAAAAAAAAARmcm9tAAAAEwAAAAEAAAAAAAAAAnRvAAAAAAATAAAAAQAAAAAAAAAEZ3VpZAAAA+4AAAAgAAAAAQAAAAAAAAAFaW5kZXgAAAAAAAAEAAAAAQAAAAAAAAAHbWVzc2FnZQAAAAAOAAAAAAAAAAIAAAAFAAAAAAAAAAAAAAAQQ29tcG9zZURlbGl2ZXJlZAAAAAEAAAARY29tcG9zZV9kZWxpdmVyZWQAAAAAAAAEAAAAAAAAAARmcm9tAAAAEwAAAAEAAAAAAAAAAnRvAAAAAAATAAAAAQAAAAAAAAAEZ3VpZAAAA+4AAAAgAAAAAQAAAAAAAAAFaW5kZXgAAAAAAAAEAAAAAQAAAAIAAAAFAAAAAAAAAAAAAAAOTHpDb21wb3NlQWxlcnQAAAAAAAEAAAAQbHpfY29tcG9zZV9hbGVydAAAAAoAAAAAAAAABGZyb20AAAATAAAAAQAAAAAAAAACdG8AAAAAABMAAAABAAAAAAAAAAhleGVjdXRvcgAAABMAAAABAAAAAAAAAARndWlkAAAD7gAAACAAAAABAAAAAAAAAAVpbmRleAAAAAAAAAQAAAABAAAAAAAAAANnYXMAAAAACwAAAAAAAAAAAAAABXZhbHVlAAAAAAAACwAAAAAAAAAAAAAAB21lc3NhZ2UAAAAADgAAAAAAAAAAAAAACmV4dHJhX2RhdGEAAAAAAA4AAAAAAAAAAAAAAAZyZWFzb24AAAAAAA4AAAAAAAAAAgAAAAEAAAAtUGFyYW1ldGVycyBmb3Igc2VuZGluZyBhIGNyb3NzLWNoYWluIG1lc3NhZ2UuAAAAAAAAAAAAAA9NZXNzYWdpbmdQYXJhbXMAAAAABQAAACtEZXN0aW5hdGlvbiBlbmRwb2ludCBJRCAoY2hhaW4gaWRlbnRpZmllcikuAAAAAAdkc3RfZWlkAAAAAAQAAAAcVGhlIG1lc3NhZ2UgcGF5bG9hZCB0byBzZW5kLgAAAAdtZXNzYWdlAAAAAA4AAAAhRW5jb2RlZCBleGVjdXRvciBhbmQgRFZOIG9wdGlvbnMuAAAAAAAAB29wdGlvbnMAAAAADgAAADlXaGV0aGVyIHRvIHBheSBmZWVzIGluIFpSTyB0b2tlbiBpbnN0ZWFkIG9mIG5hdGl2ZSB0b2tlbi4AAAAAAAAKcGF5X2luX3pybwAAAAAAAQAAADVSZWNlaXZlciBhZGRyZXNzIG9uIHRoZSBkZXN0aW5hdGlvbiBjaGFpbiAoMzIgYnl0ZXMpLgAAAAAAAAhyZWNlaXZlcgAAA+4AAAAgAAAAAQAAAE1Tb3VyY2UgbWVzc2FnZSBpbmZvcm1hdGlvbiBpZGVudGlmeWluZyB3aGVyZSBhIGNyb3NzLWNoYWluIG1lc3NhZ2UgY2FtZSBmcm9tLgAAAAAAAAAAAAAGT3JpZ2luAAAAAAADAAAAF05vbmNlIGZvciB0aGlzIHBhdGh3YXkuAAAAAAVub25jZQAAAAAAAAYAAAAuU2VuZGVyIGFkZHJlc3Mgb24gdGhlIHNvdXJjZSBjaGFpbiAoMzIgYnl0ZXMpLgAAAAAABnNlbmRlcgAAAAAD7gAAACAAAAAmU291cmNlIGVuZHBvaW50IElEIChjaGFpbiBpZGVudGlmaWVyKS4AAAAAAAdzcmNfZWlkAAAAAAQAAAABAAAAKEZlZSBzdHJ1Y3R1cmUgZm9yIGNyb3NzLWNoYWluIG1lc3NhZ2luZy4AAAAAAAAADE1lc3NhZ2luZ0ZlZQAAAAIAAAAfRmVlIHBhaWQgaW4gbmF0aXZlIHRva2VuIChYTE0pLgAAAAAKbmF0aXZlX2ZlZQAAAAAACwAAAChGZWUgcGFpZCBpbiBaUk8gdG9rZW4gKExheWVyWmVybyB0b2tlbikuAAAAB3pyb19mZWUAAAAACwAAAAEAAABCUmVjZWlwdCByZXR1cm5lZCBhZnRlciBzdWNjZXNzZnVsbHkgc2VuZGluZyBhIGNyb3NzLWNoYWluIG1lc3NhZ2UuAAAAAAAAAAAAEE1lc3NhZ2luZ1JlY2VpcHQAAAADAAAAKVRoZSBmZWVzIGNoYXJnZWQgZm9yIHNlbmRpbmcgdGhlIG1lc3NhZ2UuAAAAAAAAA2ZlZQAAAAfQAAAADE1lc3NhZ2luZ0ZlZQAAACtHbG9iYWxseSB1bmlxdWUgaWRlbnRpZmllciBmb3IgdGhlIG1lc3NhZ2UuAAAAAARndWlkAAAD7gAAACAAAAAkVGhlIG91dGJvdW5kIG5vbmNlIGZvciB0aGlzIHBhdGh3YXkuAAAABW5vbmNlAAAAAAAABgAAAAIAAAA4VHlwZSBvZiBtZXNzYWdlIGxpYnJhcnkgaW5kaWNhdGluZyBzdXBwb3J0ZWQgb3BlcmF0aW9ucy4AAAAAAAAADk1lc3NhZ2VMaWJUeXBlAAAAAAADAAAAAAAAAB9TdXBwb3J0cyBvbmx5IHNlbmRpbmcgbWVzc2FnZXMuAAAAAARTZW5kAAAAAAAAACFTdXBwb3J0cyBvbmx5IHJlY2VpdmluZyBtZXNzYWdlcy4AAAAAAAAHUmVjZWl2ZQAAAAAAAAAALVN1cHBvcnRzIGJvdGggc2VuZGluZyBhbmQgcmVjZWl2aW5nIG1lc3NhZ2VzLgAAAAAAAA5TZW5kQW5kUmVjZWl2ZQAAAAAAAQAAALdWZXJzaW9uIGluZm9ybWF0aW9uIGZvciBhIG1lc3NhZ2UgbGlicmFyeS4KCk5vdGU6IGBtaW5vcmAgYW5kIGBlbmRwb2ludF92ZXJzaW9uYCB1c2UgYHUzMmAgaW5zdGVhZCBvZiBgdThgIGJlY2F1c2UgU3RlbGxhciBkb2VzIG5vdApzdXBwb3J0IGB1OGAgdHlwZXMgaW4gY29udHJhY3QgaW50ZXJmYWNlIGZ1bmN0aW9ucy4AAAAAAAAAABFNZXNzYWdlTGliVmVyc2lvbgAAAAAAAAMAAAAzRW5kcG9pbnQgdmVyc2lvbiAoc2hvdWxkIG5vdCBleGNlZWQgdTg6Ok1BWCA9IDI1NSkuAAAAABBlbmRwb2ludF92ZXJzaW9uAAAABAAAABVNYWpvciB2ZXJzaW9uIG51bWJlci4AAAAAAAAFbWFqb3IAAAAAAAAGAAAAN01pbm9yIHZlcnNpb24gbnVtYmVyIChzaG91bGQgbm90IGV4Y2VlZCB1ODo6TUFYID0gMjU1KS4AAAAABW1pbm9yAAAAAAAABAAAAAEAAAA2VGltZW91dCBjb25maWd1cmF0aW9uIGZvciByZWNlaXZlIGxpYnJhcnkgdHJhbnNpdGlvbnMuAAAAAAAAAAAAB1RpbWVvdXQAAAAAAgAAAChVbml4IHRpbWVzdGFtcCB3aGVuIHRoZSB0aW1lb3V0IGV4cGlyZXMuAAAABmV4cGlyeQAAAAAABgAAAClUaGUgbmV3IGxpYnJhcnkgYWRkcmVzcyB0byB0cmFuc2l0aW9uIHRvLgAAAAAAAANsaWIAAAAAEwAAAAEAAAA1UGFyYW1ldGVycyBmb3Igc2V0dGluZyBtZXNzYWdlIGxpYnJhcnkgY29uZmlndXJhdGlvbi4AAAAAAAAAAAAADlNldENvbmZpZ1BhcmFtAAAAAAADAAAAH1hEUi1lbmNvZGVkIGNvbmZpZ3VyYXRpb24gZGF0YS4AAAAABmNvbmZpZwAAAAAADgAAADBUaGUgdHlwZSBvZiBjb25maWd1cmF0aW9uIChlLmcuLCBleGVjdXRvciwgVUxOKS4AAAALY29uZmlnX3R5cGUAAAAABAAAACdUaGUgZW5kcG9pbnQgSUQgdGhpcyBjb25maWcgYXBwbGllcyB0by4AAAAAA2VpZAAAAAAEAAAAAQAAADFSZXNvbHZlZCBsaWJyYXJ5IGluZm9ybWF0aW9uIHdpdGggZGVmYXVsdCBzdGF0dXMuAAAAAAAAAAAAAA9SZXNvbHZlZExpYnJhcnkAAAAAAgAAAERXaGV0aGVyIHRoaXMgaXMgdGhlIGRlZmF1bHQgbGlicmFyeSAodHJ1ZSkgb3IgT0FwcC1zcGVjaWZpYyAoZmFsc2UpLgAAAAppc19kZWZhdWx0AAAAAAABAAAAHVRoZSByZXNvbHZlZCBsaWJyYXJ5IGFkZHJlc3MuAAAAAAAAA2xpYgAAAAATAAAAAQAAAEhPdXRib3VuZCBwYWNrZXQgY29udGFpbmluZyBhbGwgaW5mb3JtYXRpb24gZm9yIGNyb3NzLWNoYWluIHRyYW5zbWlzc2lvbi4AAAAAAAAADk91dGJvdW5kUGFja2V0AAAAAAAHAAAAGERlc3RpbmF0aW9uIGVuZHBvaW50IElELgAAAAdkc3RfZWlkAAAAAAQAAAAsR2xvYmFsbHkgdW5pcXVlIGlkZW50aWZpZXIgZm9yIHRoaXMgbWVzc2FnZS4AAAAEZ3VpZAAAA+4AAAAgAAAAFFRoZSBtZXNzYWdlIHBheWxvYWQuAAAAB21lc3NhZ2UAAAAADgAAACBPdXRib3VuZCBub25jZSBmb3IgdGhpcyBwYXRod2F5LgAAAAVub25jZQAAAAAAAAYAAAAxUmVjZWl2ZXIgYWRkcmVzcyBvbiBkZXN0aW5hdGlvbiBjaGFpbiAoMzIgYnl0ZXMpLgAAAAAAAAhyZWNlaXZlcgAAA+4AAAAgAAAAH1NlbmRlciBhZGRyZXNzIG9uIHNvdXJjZSBjaGFpbi4AAAAABnNlbmRlcgAAAAAAEwAAABNTb3VyY2UgZW5kcG9pbnQgSUQuAAAAAAdzcmNfZWlkAAAAAAQAAAABAAAAK0EgZmVlIHJlY2lwaWVudCB3aXRoIHRoZSBhbW91bnQgdG8gYmUgcGFpZC4AAAAAAAAAAAxGZWVSZWNpcGllbnQAAAACAAAAFUFtb3VudCBvZiBmZWUgdG8gcGF5LgAAAAAAAAZhbW91bnQAAAAAAAsAAAAfVGhlIGFkZHJlc3MgdG8gc2VuZCB0aGUgZmVlIHRvLgAAAAACdG8AAAAAABMAAAABAAAAPFJlc3VsdCBvZiBzZW5kIG9wZXJhdGlvbiBjb250YWluaW5nIGZlZXMgYW5kIGVuY29kZWQgcGFja2V0LgAAAAAAAAANRmVlc0FuZFBhY2tldAAAAAAAAAMAAAAqVGhlIGVuY29kZWQgcGFja2V0IHJlYWR5IGZvciB0cmFuc21pc3Npb24uAAAAAAAOZW5jb2RlZF9wYWNrZXQAAAAAAA4AAAA/TGlzdCBvZiBuYXRpdmUgdG9rZW4gZmVlIHJlY2lwaWVudHMgKGV4ZWN1dG9yLCBEVk5zLCB0cmVhc3VyeSkuAAAAABVuYXRpdmVfZmVlX3JlY2lwaWVudHMAAAAAAAPqAAAH0AAAAAxGZWVSZWNpcGllbnQAAAAsTGlzdCBvZiBaUk8gdG9rZW4gZmVlIHJlY2lwaWVudHMgKHRyZWFzdXJ5KS4AAAASenJvX2ZlZV9yZWNpcGllbnRzAAAAAAPqAAAH0AAAAAxGZWVSZWNpcGllbnQAAAAEAAAAHVBhY2tldENvZGVjVjFFcnJvcjogMTEwMC0xMTA5AAAAAAAAAAAAABJQYWNrZXRDb2RlY1YxRXJyb3IAAAAAAAIAAAAAAAAAE0ludmFsaWRQYWNrZXRIZWFkZXIAAAAETAAAAAAAAAAUSW52YWxpZFBhY2tldFZlcnNpb24AAARNAAAABAAAAB1Xb3JrZXJPcHRpb25zRXJyb3I6IDExMTAtMTExOQAAAAAAAAAAAAASV29ya2VyT3B0aW9uc0Vycm9yAAAAAAAJAAAAAAAAABJJbnZhbGlkQnl0ZXNMZW5ndGgAAAAABFYAAAAAAAAAGUludmFsaWRMZWdhY3lPcHRpb25zVHlwZTEAAAAAAARXAAAAAAAAABlJbnZhbGlkTGVnYWN5T3B0aW9uc1R5cGUyAAAAAAAEWAAAAAAAAAARSW52YWxpZE9wdGlvblR5cGUAAAAAAARZAAAAAAAAAA5JbnZhbGlkT3B0aW9ucwAAAAAEWgAAAAAAAAAPSW52YWxpZFdvcmtlcklkAAAABFsAAAAAAAAAHUxlZ2FjeU9wdGlvbnNUeXBlMUdhc092ZXJmbG93AAAAAAAEXAAAAAAAAAAgTGVnYWN5T3B0aW9uc1R5cGUyQW1vdW50T3ZlcmZsb3cAAARdAAAAAAAAAB1MZWdhY3lPcHRpb25zVHlwZTJHYXNPdmVyZmxvdwAAAAAABF4AAAAEAAAAHEJ1ZmZlclJlYWRlckVycm9yOiAxMDAwLTEwMDkAAAAAAAAAEUJ1ZmZlclJlYWRlckVycm9yAAAAAAAAAgAAAAAAAAANSW52YWxpZExlbmd0aAAAAAAAA+gAAAAAAAAAFUludmFsaWRBZGRyZXNzUGF5bG9hZAAAAAAAA+kAAAAEAAAAHEJ1ZmZlcldyaXRlckVycm9yOiAxMDEwLTEwMTkAAAAAAAAAEUJ1ZmZlcldyaXRlckVycm9yAAAAAAAAAQAAAAAAAAAVSW52YWxpZEFkZHJlc3NQYXlsb2FkAAAAAAAD8gAAAAQAAAAfVHRsQ29uZmlndXJhYmxlRXJyb3I6IDEwMjAtMTAyOQAAAAAAAAAAFFR0bENvbmZpZ3VyYWJsZUVycm9yAAAAAwAAAAAAAAAQSW52YWxpZFR0bENvbmZpZwAAA/wAAAAAAAAAD1R0bENvbmZpZ0Zyb3plbgAAAAP9AAAAAAAAABZUdGxDb25maWdBbHJlYWR5RnJvemVuAAAAAAP+AAAABAAAABdPd25hYmxlRXJyb3I6IDEwMzAtMTAzOQAAAAAAAAAADE93bmFibGVFcnJvcgAAAAYAAAAAAAAAE0ludmFsaWRQZW5kaW5nT3duZXIAAAAEBgAAAAAAAAAKSW52YWxpZFR0bAAAAAAEBwAAAAAAAAARTm9QZW5kaW5nVHJhbnNmZXIAAAAAAAQIAAAAAAAAAA9Pd25lckFscmVhZHlTZXQAAAAECQAAAAAAAAALT3duZXJOb3RTZXQAAAAECgAAAAAAAAASVHJhbnNmZXJJblByb2dyZXNzAAAAAAQLAAAABAAAABhCeXRlc0V4dEVycm9yOiAxMDQwLTEwNDkAAAAAAAAADUJ5dGVzRXh0RXJyb3IAAAAAAAABAAAAAAAAAA5MZW5ndGhNaXNtYXRjaAAAAAAEEAAAAAQAAAAbVXBncmFkZWFibGVFcnJvcjogMTA1MC0xMDU5AAAAAAAAAAAQVXBncmFkZWFibGVFcnJvcgAAAAEAAAAAAAAAE01pZ3JhdGlvbk5vdEFsbG93ZWQAAAAEGgAAAAQAAAAYTXVsdGlzaWdFcnJvcjogMTA2MC0xMDY5AAAAAAAAAA1NdWx0aXNpZ0Vycm9yAAAAAAAACAAAAAAAAAASQWxyZWFkeUluaXRpYWxpemVkAAAAAAQkAAAAAAAAAA1JbnZhbGlkU2lnbmVyAAAAAAAEJQAAAAAAAAAOU2lnbmF0dXJlRXJyb3IAAAAABCYAAAAAAAAAE1NpZ25lckFscmVhZHlFeGlzdHMAAAAEJwAAAAAAAAAOU2lnbmVyTm90Rm91bmQAAAAABCgAAAAAAAAAHVRvdGFsU2lnbmVyc0xlc3NUaGFuVGhyZXNob2xkAAAAAAAEKQAAAAAAAAAPVW5zb3J0ZWRTaWduZXJzAAAABCoAAAAAAAAADVplcm9UaHJlc2hvbGQAAAAAAAQrAAAABQAAADBFdmVudCBlbWl0dGVkIHdoZW4gYSBzaWduZXIgaXMgYWRkZWQgb3IgcmVtb3ZlZC4AAAAAAAAACVNpZ25lclNldAAAAAAAAAEAAAAKc2lnbmVyX3NldAAAAAAAAgAAAAAAAAAGc2lnbmVyAAAAAAPuAAAAFAAAAAEAAAAAAAAABmFjdGl2ZQAAAAAAAQAAAAAAAAACAAAABQAAADZFdmVudCBlbWl0dGVkIHdoZW4gdGhlIHNpZ25hdHVyZSB0aHJlc2hvbGQgaXMgY2hhbmdlZC4AAAAAAAAAAAAMVGhyZXNob2xkU2V0AAAAAQAAAA10aHJlc2hvbGRfc2V0AAAAAAAAAQAAAAAAAAAJdGhyZXNob2xkAAAAAAAABAAAAAAAAAACAAAAAgAAAAAAAAAAAAAAD011bHRpc2lnU3RvcmFnZQAAAAACAAAAAAAAAAAAAAAHU2lnbmVycwAAAAAAAAAAAAAAAAlUaHJlc2hvbGQAAAAAAAAFAAAAV0V2ZW50IGVtaXR0ZWQgd2hlbiBvd25lcnNoaXAgaXMgdHJhbnNmZXJyZWQgKGJvdGggc2luZ2xlLXN0ZXAgYW5kIHR3by1zdGVwIGNvbXBsZXRpb24pLgAAAAAAAAAAFE93bmVyc2hpcFRyYW5zZmVycmVkAAAAAQAAABVvd25lcnNoaXBfdHJhbnNmZXJyZWQAAAAAAAACAAAAAAAAAAlvbGRfb3duZXIAAAAAAAATAAAAAAAAAAAAAAAJbmV3X293bmVyAAAAAAAAEwAAAAAAAAACAAAABQAAADtFdmVudCBlbWl0dGVkIHdoZW4gYSAyLXN0ZXAgb3duZXJzaGlwIHRyYW5zZmVyIGlzIHByb3Bvc2VkLgAAAAAAAAAAFU93bmVyc2hpcFRyYW5zZmVycmluZwAAAAAAAAEAAAAWb3duZXJzaGlwX3RyYW5zZmVycmluZwAAAAAAAwAAAAAAAAAJb2xkX293bmVyAAAAAAAAEwAAAAAAAAAAAAAACW5ld19vd25lcgAAAAAAABMAAAAAAAAAAAAAAAN0dGwAAAAABAAAAAAAAAACAAAABQAAACpFdmVudCBlbWl0dGVkIHdoZW4gb3duZXJzaGlwIGlzIHJlbm91bmNlZC4AAAAAAAAAAAAST3duZXJzaGlwUmVub3VuY2VkAAAAAAABAAAAE293bmVyc2hpcF9yZW5vdW5jZWQAAAAAAQAAAAAAAAAJb2xkX293bmVyAAAAAAAAEwAAAAAAAAACAAAAAgAAAAAAAAAAAAAADk93bmFibGVTdG9yYWdlAAAAAAACAAAAAAAAAAAAAAAFT3duZXIAAAAAAAAAAAAAAAAAAAxQZW5kaW5nT3duZXIAAAABAAAASVRUTCBjb25maWd1cmF0aW9uOiB0aHJlc2hvbGQgKHdoZW4gdG8gZXh0ZW5kKSBhbmQgZXh0ZW5kX3RvICh0YXJnZXQgVFRMKS4AAAAAAAAAAAAACVR0bENvbmZpZwAAAAAAAAIAAAAoVGFyZ2V0IFRUTCBhZnRlciBleHRlbnNpb24gKGluIGxlZGdlcnMpLgAAAAlleHRlbmRfdG8AAAAAAAAEAAAAM1RUTCB0aHJlc2hvbGQgdGhhdCB0cmlnZ2VycyBleHRlbnNpb24gKGluIGxlZGdlcnMpLgAAAAAJdGhyZXNob2xkAAAAAAAABAAAAAUAAAAnRXZlbnQgZW1pdHRlZCB3aGVuIFRUTCBjb25maWdzIGFyZSBzZXQuAAAAAAAAAAANVHRsQ29uZmlnc1NldAAAAAAAAAEAAAAPdHRsX2NvbmZpZ3Nfc2V0AAAAAAIAAAAAAAAACGluc3RhbmNlAAAD6AAAB9AAAAAJVHRsQ29uZmlnAAAAAAAAAAAAAAAAAAAKcGVyc2lzdGVudAAAAAAD6AAAB9AAAAAJVHRsQ29uZmlnAAAAAAAAAAAAAAIAAAAFAAAAKkV2ZW50IGVtaXR0ZWQgd2hlbiBUVEwgY29uZmlncyBhcmUgZnJvemVuLgAAAAAAAAAAABBUdGxDb25maWdzRnJvemVuAAAAAQAAABJ0dGxfY29uZmlnc19mcm96ZW4AAAAAAAAAAAACAAAAAgAAAAAAAAAAAAAAEFR0bENvbmZpZ1N0b3JhZ2UAAAADAAAAAAAAAAAAAAAGRnJvemVuAAAAAAAAAAAAAAAAAAhJbnN0YW5jZQAAAAAAAAAAAAAAClBlcnNpc3RlbnQAAAAAAAIAAAAAAAAAAAAAABJVcGdyYWRlYWJsZVN0b3JhZ2UAAAAAAAEAAAAAAAAAAAAAAAlNaWdyYXRpbmcAAAAAHhFjb250cmFjdGVudm1ldGF2MAAAAAAAAAAXAAAAAABvDmNvbnRyYWN0bWV0YXYwAAAAAAAAAAVyc3ZlcgAAAAAAAAYxLjkwLjAAAAAAAAAAAAAIcnNzZGt2ZXIAAAAvMjMuNC4wIzY3M2Q2YzRmMjM2OGQyODJkMjVkYTI5YmRhNTVjMjFiOGJlNjljYTYA";
13
+ /**
14
+ * Pre-computed WASM hash (SHA-256)
15
+ * Use this when the WASM is already uploaded on-chain
16
+ */
17
+ export declare const WASM_HASH = "1bfeb72123ffa91ac90e056f03dc8b2370a5d6563e5cedc9495b175d1e8caf20";
18
+ /**
19
+ * Get the WASM bytecode as a Buffer
20
+ * Use this to upload the WASM to the network
21
+ */
22
+ export declare function getWasmBuffer(): Buffer;
23
+ export declare const TreasuryError: {
24
+ 1: {
25
+ message: string;
26
+ };
27
+ 2: {
28
+ message: string;
29
+ };
30
+ 3: {
31
+ message: string;
32
+ };
33
+ 4: {
34
+ message: string;
35
+ };
36
+ };
37
+ export type TreasuryStorage = {
38
+ tag: "NativeFeeBp";
39
+ values: void;
40
+ } | {
41
+ tag: "FeeEnabled";
42
+ values: void;
43
+ } | {
44
+ tag: "ZroFeeLib";
45
+ values: void;
46
+ };
47
+ export declare const EndpointError: {
48
+ 1: {
49
+ message: string;
50
+ };
51
+ 2: {
52
+ message: string;
53
+ };
54
+ 3: {
55
+ message: string;
56
+ };
57
+ 4: {
58
+ message: string;
59
+ };
60
+ 5: {
61
+ message: string;
62
+ };
63
+ 6: {
64
+ message: string;
65
+ };
66
+ 7: {
67
+ message: string;
68
+ };
69
+ 8: {
70
+ message: string;
71
+ };
72
+ 9: {
73
+ message: string;
74
+ };
75
+ 10: {
76
+ message: string;
77
+ };
78
+ 11: {
79
+ message: string;
80
+ };
81
+ 12: {
82
+ message: string;
83
+ };
84
+ 13: {
85
+ message: string;
86
+ };
87
+ 14: {
88
+ message: string;
89
+ };
90
+ 15: {
91
+ message: string;
92
+ };
93
+ 16: {
94
+ message: string;
95
+ };
96
+ 17: {
97
+ message: string;
98
+ };
99
+ 18: {
100
+ message: string;
101
+ };
102
+ 19: {
103
+ message: string;
104
+ };
105
+ 20: {
106
+ message: string;
107
+ };
108
+ 21: {
109
+ message: string;
110
+ };
111
+ 22: {
112
+ message: string;
113
+ };
114
+ 23: {
115
+ message: string;
116
+ };
117
+ 24: {
118
+ message: string;
119
+ };
120
+ 25: {
121
+ message: string;
122
+ };
123
+ };
124
+ /**
125
+ * Parameters for sending a cross-chain message.
126
+ */
127
+ export interface MessagingParams {
128
+ /**
129
+ * Destination endpoint ID (chain identifier).
130
+ */
131
+ dst_eid: u32;
132
+ /**
133
+ * The message payload to send.
134
+ */
135
+ message: Buffer;
136
+ /**
137
+ * Encoded executor and DVN options.
138
+ */
139
+ options: Buffer;
140
+ /**
141
+ * Whether to pay fees in ZRO token instead of native token.
142
+ */
143
+ pay_in_zro: boolean;
144
+ /**
145
+ * Receiver address on the destination chain (32 bytes).
146
+ */
147
+ receiver: Buffer;
148
+ }
149
+ /**
150
+ * Source message information identifying where a cross-chain message came from.
151
+ */
152
+ export interface Origin {
153
+ /**
154
+ * Nonce for this pathway.
155
+ */
156
+ nonce: u64;
157
+ /**
158
+ * Sender address on the source chain (32 bytes).
159
+ */
160
+ sender: Buffer;
161
+ /**
162
+ * Source endpoint ID (chain identifier).
163
+ */
164
+ src_eid: u32;
165
+ }
166
+ /**
167
+ * Fee structure for cross-chain messaging.
168
+ */
169
+ export interface MessagingFee {
170
+ /**
171
+ * Fee paid in native token (XLM).
172
+ */
173
+ native_fee: i128;
174
+ /**
175
+ * Fee paid in ZRO token (LayerZero token).
176
+ */
177
+ zro_fee: i128;
178
+ }
179
+ /**
180
+ * Receipt returned after successfully sending a cross-chain message.
181
+ */
182
+ export interface MessagingReceipt {
183
+ /**
184
+ * The fees charged for sending the message.
185
+ */
186
+ fee: MessagingFee;
187
+ /**
188
+ * Globally unique identifier for the message.
189
+ */
190
+ guid: Buffer;
191
+ /**
192
+ * The outbound nonce for this pathway.
193
+ */
194
+ nonce: u64;
195
+ }
196
+ /**
197
+ * Type of message library indicating supported operations.
198
+ */
199
+ export type MessageLibType = {
200
+ tag: "Send";
201
+ values: void;
202
+ } | {
203
+ tag: "Receive";
204
+ values: void;
205
+ } | {
206
+ tag: "SendAndReceive";
207
+ values: void;
208
+ };
209
+ /**
210
+ * Version information for a message library.
211
+ *
212
+ * Note: `minor` and `endpoint_version` use `u32` instead of `u8` because Stellar does not
213
+ * support `u8` types in contract interface functions.
214
+ */
215
+ export interface MessageLibVersion {
216
+ /**
217
+ * Endpoint version (should not exceed u8::MAX = 255).
218
+ */
219
+ endpoint_version: u32;
220
+ /**
221
+ * Major version number.
222
+ */
223
+ major: u64;
224
+ /**
225
+ * Minor version number (should not exceed u8::MAX = 255).
226
+ */
227
+ minor: u32;
228
+ }
229
+ /**
230
+ * Timeout configuration for receive library transitions.
231
+ */
232
+ export interface Timeout {
233
+ /**
234
+ * Unix timestamp when the timeout expires.
235
+ */
236
+ expiry: u64;
237
+ /**
238
+ * The new library address to transition to.
239
+ */
240
+ lib: string;
241
+ }
242
+ /**
243
+ * Parameters for setting message library configuration.
244
+ */
245
+ export interface SetConfigParam {
246
+ /**
247
+ * XDR-encoded configuration data.
248
+ */
249
+ config: Buffer;
250
+ /**
251
+ * The type of configuration (e.g., executor, ULN).
252
+ */
253
+ config_type: u32;
254
+ /**
255
+ * The endpoint ID this config applies to.
256
+ */
257
+ eid: u32;
258
+ }
259
+ /**
260
+ * Resolved library information with default status.
261
+ */
262
+ export interface ResolvedLibrary {
263
+ /**
264
+ * Whether this is the default library (true) or OApp-specific (false).
265
+ */
266
+ is_default: boolean;
267
+ /**
268
+ * The resolved library address.
269
+ */
270
+ lib: string;
271
+ }
272
+ /**
273
+ * Outbound packet containing all information for cross-chain transmission.
274
+ */
275
+ export interface OutboundPacket {
276
+ /**
277
+ * Destination endpoint ID.
278
+ */
279
+ dst_eid: u32;
280
+ /**
281
+ * Globally unique identifier for this message.
282
+ */
283
+ guid: Buffer;
284
+ /**
285
+ * The message payload.
286
+ */
287
+ message: Buffer;
288
+ /**
289
+ * Outbound nonce for this pathway.
290
+ */
291
+ nonce: u64;
292
+ /**
293
+ * Receiver address on destination chain (32 bytes).
294
+ */
295
+ receiver: Buffer;
296
+ /**
297
+ * Sender address on source chain.
298
+ */
299
+ sender: string;
300
+ /**
301
+ * Source endpoint ID.
302
+ */
303
+ src_eid: u32;
304
+ }
305
+ /**
306
+ * A fee recipient with the amount to be paid.
307
+ */
308
+ export interface FeeRecipient {
309
+ /**
310
+ * Amount of fee to pay.
311
+ */
312
+ amount: i128;
313
+ /**
314
+ * The address to send the fee to.
315
+ */
316
+ to: string;
317
+ }
318
+ /**
319
+ * Result of send operation containing fees and encoded packet.
320
+ */
321
+ export interface FeesAndPacket {
322
+ /**
323
+ * The encoded packet ready for transmission.
324
+ */
325
+ encoded_packet: Buffer;
326
+ /**
327
+ * List of native token fee recipients (executor, DVNs, treasury).
328
+ */
329
+ native_fee_recipients: Array<FeeRecipient>;
330
+ /**
331
+ * List of ZRO token fee recipients (treasury).
332
+ */
333
+ zro_fee_recipients: Array<FeeRecipient>;
334
+ }
335
+ /**
336
+ * PacketCodecV1Error: 1100-1109
337
+ */
338
+ export declare const PacketCodecV1Error: {
339
+ 1100: {
340
+ message: string;
341
+ };
342
+ 1101: {
343
+ message: string;
344
+ };
345
+ };
346
+ /**
347
+ * WorkerOptionsError: 1110-1119
348
+ */
349
+ export declare const WorkerOptionsError: {
350
+ 1110: {
351
+ message: string;
352
+ };
353
+ 1111: {
354
+ message: string;
355
+ };
356
+ 1112: {
357
+ message: string;
358
+ };
359
+ 1113: {
360
+ message: string;
361
+ };
362
+ 1114: {
363
+ message: string;
364
+ };
365
+ 1115: {
366
+ message: string;
367
+ };
368
+ 1116: {
369
+ message: string;
370
+ };
371
+ 1117: {
372
+ message: string;
373
+ };
374
+ 1118: {
375
+ message: string;
376
+ };
377
+ };
378
+ /**
379
+ * BufferReaderError: 1000-1009
380
+ */
381
+ export declare const BufferReaderError: {
382
+ 1000: {
383
+ message: string;
384
+ };
385
+ 1001: {
386
+ message: string;
387
+ };
388
+ };
389
+ /**
390
+ * BufferWriterError: 1010-1019
391
+ */
392
+ export declare const BufferWriterError: {
393
+ 1010: {
394
+ message: string;
395
+ };
396
+ };
397
+ /**
398
+ * TtlConfigurableError: 1020-1029
399
+ */
400
+ export declare const TtlConfigurableError: {
401
+ 1020: {
402
+ message: string;
403
+ };
404
+ 1021: {
405
+ message: string;
406
+ };
407
+ 1022: {
408
+ message: string;
409
+ };
410
+ };
411
+ /**
412
+ * OwnableError: 1030-1039
413
+ */
414
+ export declare const OwnableError: {
415
+ 1030: {
416
+ message: string;
417
+ };
418
+ 1031: {
419
+ message: string;
420
+ };
421
+ 1032: {
422
+ message: string;
423
+ };
424
+ 1033: {
425
+ message: string;
426
+ };
427
+ 1034: {
428
+ message: string;
429
+ };
430
+ 1035: {
431
+ message: string;
432
+ };
433
+ };
434
+ /**
435
+ * BytesExtError: 1040-1049
436
+ */
437
+ export declare const BytesExtError: {
438
+ 1040: {
439
+ message: string;
440
+ };
441
+ };
442
+ /**
443
+ * UpgradeableError: 1050-1059
444
+ */
445
+ export declare const UpgradeableError: {
446
+ 1050: {
447
+ message: string;
448
+ };
449
+ };
450
+ /**
451
+ * MultisigError: 1060-1069
452
+ */
453
+ export declare const MultisigError: {
454
+ 1060: {
455
+ message: string;
456
+ };
457
+ 1061: {
458
+ message: string;
459
+ };
460
+ 1062: {
461
+ message: string;
462
+ };
463
+ 1063: {
464
+ message: string;
465
+ };
466
+ 1064: {
467
+ message: string;
468
+ };
469
+ 1065: {
470
+ message: string;
471
+ };
472
+ 1066: {
473
+ message: string;
474
+ };
475
+ 1067: {
476
+ message: string;
477
+ };
478
+ };
479
+ export type MultisigStorage = {
480
+ tag: "Signers";
481
+ values: void;
482
+ } | {
483
+ tag: "Threshold";
484
+ values: void;
485
+ };
486
+ export type OwnableStorage = {
487
+ tag: "Owner";
488
+ values: void;
489
+ } | {
490
+ tag: "PendingOwner";
491
+ values: void;
492
+ };
493
+ /**
494
+ * TTL configuration: threshold (when to extend) and extend_to (target TTL).
495
+ */
496
+ export interface TtlConfig {
497
+ /**
498
+ * Target TTL after extension (in ledgers).
499
+ */
500
+ extend_to: u32;
501
+ /**
502
+ * TTL threshold that triggers extension (in ledgers).
503
+ */
504
+ threshold: u32;
505
+ }
506
+ export type TtlConfigStorage = {
507
+ tag: "Frozen";
508
+ values: void;
509
+ } | {
510
+ tag: "Instance";
511
+ values: void;
512
+ } | {
513
+ tag: "Persistent";
514
+ values: void;
515
+ };
516
+ export type UpgradeableStorage = {
517
+ tag: "Migrating";
518
+ values: void;
519
+ };
520
+ export interface Client {
521
+ /**
522
+ * Construct and simulate a get_fee 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.
523
+ * Get the treasury fee for a cross-chain message.
524
+ *
525
+ * Returns 0 if fee collection is disabled. For ZRO payments, delegates to the ZRO fee library.
526
+ */
527
+ get_fee: ({ sender, dst_eid, total_native_fee, pay_in_zro }: {
528
+ sender: string;
529
+ dst_eid: u32;
530
+ total_native_fee: i128;
531
+ pay_in_zro: boolean;
532
+ }, txnOptions?: {
533
+ /**
534
+ * The fee to pay for the transaction. Default: BASE_FEE
535
+ */
536
+ fee?: number;
537
+ /**
538
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
539
+ */
540
+ timeoutInSeconds?: number;
541
+ /**
542
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
543
+ */
544
+ simulate?: boolean;
545
+ }) => Promise<AssembledTransaction<i128>>;
546
+ /**
547
+ * Construct and simulate a set_native_fee_bp 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.
548
+ * Sets the native fee percentage in basis points.
549
+ *
550
+ * # Arguments
551
+ * * `native_fee_bp` - Fee percentage in basis points (0-10000, where 10000 = 100%)
552
+ */
553
+ set_native_fee_bp: ({ native_fee_bp }: {
554
+ native_fee_bp: u32;
555
+ }, txnOptions?: {
556
+ /**
557
+ * The fee to pay for the transaction. Default: BASE_FEE
558
+ */
559
+ fee?: number;
560
+ /**
561
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
562
+ */
563
+ timeoutInSeconds?: number;
564
+ /**
565
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
566
+ */
567
+ simulate?: boolean;
568
+ }) => Promise<AssembledTransaction<null>>;
569
+ /**
570
+ * Construct and simulate a set_fee_enabled 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.
571
+ * Enables or disables fee collection globally.
572
+ *
573
+ * # Arguments
574
+ * * `fee_enabled` - Whether fee collection is enabled
575
+ */
576
+ set_fee_enabled: ({ fee_enabled }: {
577
+ fee_enabled: boolean;
578
+ }, txnOptions?: {
579
+ /**
580
+ * The fee to pay for the transaction. Default: BASE_FEE
581
+ */
582
+ fee?: number;
583
+ /**
584
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
585
+ */
586
+ timeoutInSeconds?: number;
587
+ /**
588
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
589
+ */
590
+ simulate?: boolean;
591
+ }) => Promise<AssembledTransaction<null>>;
592
+ /**
593
+ * Construct and simulate a set_zro_fee_lib 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.
594
+ * Sets or removes the ZRO fee library for custom ZRO token fee calculations.
595
+ *
596
+ * # Arguments
597
+ * * `zro_fee_lib` - The ZRO fee library contract address, or `None` to remove
598
+ */
599
+ set_zro_fee_lib: ({ zro_fee_lib }: {
600
+ zro_fee_lib: Option<string>;
601
+ }, txnOptions?: {
602
+ /**
603
+ * The fee to pay for the transaction. Default: BASE_FEE
604
+ */
605
+ fee?: number;
606
+ /**
607
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
608
+ */
609
+ timeoutInSeconds?: number;
610
+ /**
611
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
612
+ */
613
+ simulate?: boolean;
614
+ }) => Promise<AssembledTransaction<null>>;
615
+ /**
616
+ * Construct and simulate a withdraw_token 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.
617
+ * Withdraws any token (including native XLM) from the contract to a specified address.
618
+ *
619
+ * Only the contract owner can execute this method.
620
+ *
621
+ * # Arguments
622
+ * * `token` - The token contract address (can be native XLM or any other token)
623
+ * * `to` - The recipient address
624
+ * * `amount` - The amount to withdraw (must be positive)
625
+ */
626
+ withdraw_token: ({ token, to, amount }: {
627
+ token: string;
628
+ to: string;
629
+ amount: i128;
630
+ }, txnOptions?: {
631
+ /**
632
+ * The fee to pay for the transaction. Default: BASE_FEE
633
+ */
634
+ fee?: number;
635
+ /**
636
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
637
+ */
638
+ timeoutInSeconds?: number;
639
+ /**
640
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
641
+ */
642
+ simulate?: boolean;
643
+ }) => Promise<AssembledTransaction<null>>;
644
+ /**
645
+ * Construct and simulate a native_fee_bp 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.
646
+ * Returns the native fee percentage in basis points.
647
+ */
648
+ native_fee_bp: (txnOptions?: {
649
+ /**
650
+ * The fee to pay for the transaction. Default: BASE_FEE
651
+ */
652
+ fee?: number;
653
+ /**
654
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
655
+ */
656
+ timeoutInSeconds?: number;
657
+ /**
658
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
659
+ */
660
+ simulate?: boolean;
661
+ }) => Promise<AssembledTransaction<u32>>;
662
+ /**
663
+ * Construct and simulate a fee_enabled 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.
664
+ * Returns whether fee collection is enabled.
665
+ */
666
+ fee_enabled: (txnOptions?: {
667
+ /**
668
+ * The fee to pay for the transaction. Default: BASE_FEE
669
+ */
670
+ fee?: number;
671
+ /**
672
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
673
+ */
674
+ timeoutInSeconds?: number;
675
+ /**
676
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
677
+ */
678
+ simulate?: boolean;
679
+ }) => Promise<AssembledTransaction<boolean>>;
680
+ /**
681
+ * Construct and simulate a zro_fee_lib 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.
682
+ * Returns the ZRO fee library address if set.
683
+ */
684
+ zro_fee_lib: (txnOptions?: {
685
+ /**
686
+ * The fee to pay for the transaction. Default: BASE_FEE
687
+ */
688
+ fee?: number;
689
+ /**
690
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
691
+ */
692
+ timeoutInSeconds?: number;
693
+ /**
694
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
695
+ */
696
+ simulate?: boolean;
697
+ }) => Promise<AssembledTransaction<Option<string>>>;
698
+ /**
699
+ * 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.
700
+ */
701
+ authorizer: (txnOptions?: {
702
+ /**
703
+ * The fee to pay for the transaction. Default: BASE_FEE
704
+ */
705
+ fee?: number;
706
+ /**
707
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
708
+ */
709
+ timeoutInSeconds?: number;
710
+ /**
711
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
712
+ */
713
+ simulate?: boolean;
714
+ }) => Promise<AssembledTransaction<string>>;
715
+ /**
716
+ * 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.
717
+ * Sets TTL configs for instance and persistent storage.
718
+ *
719
+ * - `None` values remove the corresponding config (disables auto-extension for that type)
720
+ * - Validates that `threshold <= extend_to <= MAX_TTL`
721
+ *
722
+ * # Arguments
723
+ * - `instance` - TTL config for instance storage
724
+ * - `persistent` - TTL config for persistent storage
725
+ *
726
+ * # Panics
727
+ * - `TtlConfigFrozen` if configs are frozen
728
+ * - `InvalidTtlConfig` if validation fails
729
+ */
730
+ set_ttl_configs: ({ instance, persistent }: {
731
+ instance: Option<TtlConfig>;
732
+ persistent: Option<TtlConfig>;
733
+ }, txnOptions?: {
734
+ /**
735
+ * The fee to pay for the transaction. Default: BASE_FEE
736
+ */
737
+ fee?: number;
738
+ /**
739
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
740
+ */
741
+ timeoutInSeconds?: number;
742
+ /**
743
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
744
+ */
745
+ simulate?: boolean;
746
+ }) => Promise<AssembledTransaction<null>>;
747
+ /**
748
+ * 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.
749
+ * Returns the current TTL configs as (instance_config, persistent_config).
750
+ */
751
+ ttl_configs: (txnOptions?: {
752
+ /**
753
+ * The fee to pay for the transaction. Default: BASE_FEE
754
+ */
755
+ fee?: number;
756
+ /**
757
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
758
+ */
759
+ timeoutInSeconds?: number;
760
+ /**
761
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
762
+ */
763
+ simulate?: boolean;
764
+ }) => Promise<AssembledTransaction<readonly [Option<TtlConfig>, Option<TtlConfig>]>>;
765
+ /**
766
+ * 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.
767
+ * Permanently freezes TTL configs, preventing any future modifications.
768
+ *
769
+ * This is irreversible and provides immutability guarantees to users.
770
+ * Emits `TtlConfigsFrozen` event.
771
+ *
772
+ * # Panics
773
+ * - `TtlConfigAlreadyFrozen` if already frozen
774
+ */
775
+ freeze_ttl_configs: (txnOptions?: {
776
+ /**
777
+ * The fee to pay for the transaction. Default: BASE_FEE
778
+ */
779
+ fee?: number;
780
+ /**
781
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
782
+ */
783
+ timeoutInSeconds?: number;
784
+ /**
785
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
786
+ */
787
+ simulate?: boolean;
788
+ }) => Promise<AssembledTransaction<null>>;
789
+ /**
790
+ * 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.
791
+ * Returns whether TTL configs are frozen.
792
+ */
793
+ is_ttl_configs_frozen: (txnOptions?: {
794
+ /**
795
+ * The fee to pay for the transaction. Default: BASE_FEE
796
+ */
797
+ fee?: number;
798
+ /**
799
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
800
+ */
801
+ timeoutInSeconds?: number;
802
+ /**
803
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
804
+ */
805
+ simulate?: boolean;
806
+ }) => Promise<AssembledTransaction<boolean>>;
807
+ /**
808
+ * 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.
809
+ * Extends the instance TTL.
810
+ *
811
+ * # Arguments
812
+ *
813
+ * * `threshold` - The threshold to extend the TTL (if current TTL is below this, extend).
814
+ * * `extend_to` - The TTL to extend to.
815
+ */
816
+ extend_instance_ttl: ({ threshold, extend_to }: {
817
+ threshold: u32;
818
+ extend_to: u32;
819
+ }, txnOptions?: {
820
+ /**
821
+ * The fee to pay for the transaction. Default: BASE_FEE
822
+ */
823
+ fee?: number;
824
+ /**
825
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
826
+ */
827
+ timeoutInSeconds?: number;
828
+ /**
829
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
830
+ */
831
+ simulate?: boolean;
832
+ }) => Promise<AssembledTransaction<null>>;
833
+ /**
834
+ * 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.
835
+ * Returns the current owner address, or None if no owner is set.
836
+ */
837
+ owner: (txnOptions?: {
838
+ /**
839
+ * The fee to pay for the transaction. Default: BASE_FEE
840
+ */
841
+ fee?: number;
842
+ /**
843
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
844
+ */
845
+ timeoutInSeconds?: number;
846
+ /**
847
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
848
+ */
849
+ simulate?: boolean;
850
+ }) => Promise<AssembledTransaction<Option<string>>>;
851
+ /**
852
+ * Construct and simulate a pending_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.
853
+ * Returns the pending owner address for 2-step transfer, or None if no transfer is pending.
854
+ */
855
+ pending_owner: (txnOptions?: {
856
+ /**
857
+ * The fee to pay for the transaction. Default: BASE_FEE
858
+ */
859
+ fee?: number;
860
+ /**
861
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
862
+ */
863
+ timeoutInSeconds?: number;
864
+ /**
865
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
866
+ */
867
+ simulate?: boolean;
868
+ }) => Promise<AssembledTransaction<Option<string>>>;
869
+ /**
870
+ * 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.
871
+ * Transfers ownership immediately to a new address.
872
+ *
873
+ * Use with caution - if you transfer to a wrong address, ownership is lost forever.
874
+ * Consider using `propose_ownership_transfer` instead.
875
+ *
876
+ * # Panics
877
+ * - `OwnerNotSet` if no owner is currently set
878
+ * - `TransferInProgress` if a 2-step transfer is in progress
879
+ */
880
+ transfer_ownership: ({ new_owner }: {
881
+ new_owner: string;
882
+ }, txnOptions?: {
883
+ /**
884
+ * The fee to pay for the transaction. Default: BASE_FEE
885
+ */
886
+ fee?: number;
887
+ /**
888
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
889
+ */
890
+ timeoutInSeconds?: number;
891
+ /**
892
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
893
+ */
894
+ simulate?: boolean;
895
+ }) => Promise<AssembledTransaction<null>>;
896
+ /**
897
+ * Construct and simulate a propose_ownership_transfer 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
+ * Proposes an ownership transfer to a new address.
899
+ *
900
+ * The new owner must call `accept_ownership()` within `ttl` ledgers
901
+ * to complete the transfer. The pending transfer will automatically expire after.
902
+ *
903
+ * # Arguments
904
+ * - `new_owner` - The proposed new owner
905
+ * - `ttl` - Number of ledgers the new owner has to accept.
906
+ * Use `0` to cancel a pending transfer (new_owner must match pending).
907
+ *
908
+ * # Panics
909
+ * - `OwnerNotSet` if no owner is currently set
910
+ * - `NoPendingTransfer` when cancelling and no pending transfer exists
911
+ * - `InvalidTtl` if ttl exceeds max TTL
912
+ * - `InvalidPendingOwner` when cancelling with wrong new_owner address
913
+ */
914
+ propose_ownership_transfer: ({ new_owner, ttl }: {
915
+ new_owner: string;
916
+ ttl: u32;
917
+ }, txnOptions?: {
918
+ /**
919
+ * The fee to pay for the transaction. Default: BASE_FEE
920
+ */
921
+ fee?: number;
922
+ /**
923
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
924
+ */
925
+ timeoutInSeconds?: number;
926
+ /**
927
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
928
+ */
929
+ simulate?: boolean;
930
+ }) => Promise<AssembledTransaction<null>>;
931
+ /**
932
+ * Construct and simulate a accept_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.
933
+ * Accepts a pending 2-step ownership transfer.
934
+ *
935
+ * Must be called by the pending owner before the TTL expires.
936
+ *
937
+ * # Panics
938
+ * - `NoPendingTransfer` if there is no pending transfer (or it expired)
939
+ */
940
+ accept_ownership: (txnOptions?: {
941
+ /**
942
+ * The fee to pay for the transaction. Default: BASE_FEE
943
+ */
944
+ fee?: number;
945
+ /**
946
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
947
+ */
948
+ timeoutInSeconds?: number;
949
+ /**
950
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
951
+ */
952
+ simulate?: boolean;
953
+ }) => Promise<AssembledTransaction<null>>;
954
+ /**
955
+ * 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.
956
+ * Permanently renounces ownership.
957
+ *
958
+ * # Panics
959
+ * - `OwnerNotSet` if no owner is currently set
960
+ * - `TransferInProgress` if a 2-step transfer is in progress (cancel it first)
961
+ */
962
+ renounce_ownership: (txnOptions?: {
963
+ /**
964
+ * The fee to pay for the transaction. Default: BASE_FEE
965
+ */
966
+ fee?: number;
967
+ /**
968
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
969
+ */
970
+ timeoutInSeconds?: number;
971
+ /**
972
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
973
+ */
974
+ simulate?: boolean;
975
+ }) => Promise<AssembledTransaction<null>>;
976
+ }
977
+ export declare class Client extends ContractClient {
978
+ readonly options: ContractClientOptions;
979
+ static deploy<T = Client>(
980
+ /** Constructor/Initialization Args for the contract's `__constructor` method */
981
+ { owner }: {
982
+ owner: string;
983
+ },
984
+ /** Options for initializing a Client as well as for calling a method, with extras specific to deploying. */
985
+ options: MethodOptions & Omit<ContractClientOptions, "contractId"> & {
986
+ /** The hash of the Wasm blob, which must already be installed on-chain. */
987
+ wasmHash: Buffer | string;
988
+ /** Salt used to generate the contract's ID. Passed through to {@link Operation.createCustomContract}. Default: random. */
989
+ salt?: Buffer | Uint8Array;
990
+ /** The format used to decode `wasmHash`, if it's provided as a string. */
991
+ format?: "hex" | "base64";
992
+ }): Promise<AssembledTransaction<T>>;
993
+ constructor(options: ContractClientOptions);
994
+ readonly fromJSON: {
995
+ get_fee: (json: string) => AssembledTransaction<bigint>;
996
+ set_native_fee_bp: (json: string) => AssembledTransaction<null>;
997
+ set_fee_enabled: (json: string) => AssembledTransaction<null>;
998
+ set_zro_fee_lib: (json: string) => AssembledTransaction<null>;
999
+ withdraw_token: (json: string) => AssembledTransaction<null>;
1000
+ native_fee_bp: (json: string) => AssembledTransaction<number>;
1001
+ fee_enabled: (json: string) => AssembledTransaction<boolean>;
1002
+ zro_fee_lib: (json: string) => AssembledTransaction<Option<string>>;
1003
+ authorizer: (json: string) => AssembledTransaction<string>;
1004
+ set_ttl_configs: (json: string) => AssembledTransaction<null>;
1005
+ ttl_configs: (json: string) => AssembledTransaction<readonly [Option<TtlConfig>, Option<TtlConfig>]>;
1006
+ freeze_ttl_configs: (json: string) => AssembledTransaction<null>;
1007
+ is_ttl_configs_frozen: (json: string) => AssembledTransaction<boolean>;
1008
+ extend_instance_ttl: (json: string) => AssembledTransaction<null>;
1009
+ owner: (json: string) => AssembledTransaction<Option<string>>;
1010
+ pending_owner: (json: string) => AssembledTransaction<Option<string>>;
1011
+ transfer_ownership: (json: string) => AssembledTransaction<null>;
1012
+ propose_ownership_transfer: (json: string) => AssembledTransaction<null>;
1013
+ accept_ownership: (json: string) => AssembledTransaction<null>;
1014
+ renounce_ownership: (json: string) => AssembledTransaction<null>;
1015
+ };
1016
+ }