@layerzerolabs/protocol-stellar-v2 0.2.18 → 0.2.20

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 (213) hide show
  1. package/.turbo/turbo-build.log +303 -253
  2. package/.turbo/turbo-lint.log +66 -65
  3. package/.turbo/turbo-test.log +1312 -1282
  4. package/Cargo.lock +21 -8
  5. package/Cargo.toml +2 -0
  6. package/contracts/ERROR_SPEC.md +9 -2
  7. package/contracts/common-macros/src/contract_ttl.rs +18 -7
  8. package/contracts/common-macros/src/lib.rs +4 -4
  9. package/contracts/common-macros/src/tests/contract_ttl.rs +1 -1
  10. package/contracts/common-macros/src/tests/snapshots/common_macros__tests__contract_ttl__snapshot_generated_contractimpl_code.snap +2 -1
  11. package/contracts/common-macros/src/tests/snapshots/common_macros__tests__upgradeable__snapshot_generated_upgradeable_code.snap +7 -12
  12. package/contracts/common-macros/src/upgradeable.rs +15 -21
  13. package/contracts/message-libs/uln-302/src/events.rs +4 -0
  14. package/contracts/message-libs/uln-302/src/send_uln.rs +23 -7
  15. package/contracts/message-libs/uln-302/src/tests/send_uln302/send.rs +38 -64
  16. package/contracts/oapps/counter/Cargo.toml +1 -0
  17. package/contracts/oapps/counter/integration_tests/setup_uln.rs +1 -1
  18. package/contracts/oapps/oapp/src/oapp_receiver.rs +1 -1
  19. package/contracts/oapps/oapp/src/tests/test_oapp_core.rs +113 -65
  20. package/contracts/oapps/oapp/src/tests/test_oapp_options_type3.rs +111 -82
  21. package/contracts/oapps/oapp/src/tests/test_oapp_receiver.rs +293 -65
  22. package/contracts/oapps/oapp/src/tests/test_oapp_sender.rs +331 -56
  23. package/contracts/oapps/oft/Cargo.toml +10 -7
  24. package/contracts/oapps/{oft-std → oft}/integration-tests/extensions/test_oft_fee.rs +3 -4
  25. package/contracts/oapps/{oft-std → oft}/integration-tests/extensions/test_pausable.rs +2 -3
  26. package/contracts/oapps/{oft-std → oft}/integration-tests/extensions/test_rate_limiter.rs +1 -1
  27. package/contracts/oapps/oft/integration-tests/mod.rs +1 -1
  28. package/contracts/oapps/oft/integration-tests/setup.rs +28 -127
  29. package/contracts/oapps/oft/integration-tests/utils.rs +254 -21
  30. package/contracts/oapps/oft/src/extensions/oft_fee.rs +23 -8
  31. package/contracts/oapps/oft/src/extensions/pausable.rs +19 -4
  32. package/contracts/oapps/oft/src/extensions/rate_limiter.rs +52 -28
  33. package/contracts/oapps/oft/src/lib.rs +10 -14
  34. package/contracts/oapps/oft/src/oft.rs +143 -193
  35. package/contracts/oapps/oft/src/oft_types/lock_unlock.rs +9 -11
  36. package/contracts/oapps/oft/src/oft_types/mint_burn.rs +12 -14
  37. package/contracts/oapps/oft/src/oft_types/mod.rs +13 -0
  38. package/contracts/oapps/{oft-std → oft-core}/Cargo.toml +6 -4
  39. package/contracts/oapps/{oft-std → oft-core}/integration-tests/mod.rs +1 -1
  40. package/contracts/oapps/{oft-std → oft-core}/integration-tests/setup.rs +126 -29
  41. package/contracts/oapps/{oft → oft-core}/integration-tests/test_with_sml.rs +3 -3
  42. package/contracts/oapps/oft-core/integration-tests/utils.rs +201 -0
  43. package/contracts/oapps/oft-core/src/lib.rs +18 -0
  44. package/contracts/oapps/oft-core/src/oft_core.rs +479 -0
  45. package/contracts/oapps/{oft → oft-core}/src/tests/mod.rs +0 -2
  46. package/contracts/oapps/{oft → oft-core}/src/tests/test_lz_receive.rs +7 -7
  47. package/contracts/oapps/{oft → oft-core}/src/tests/test_oft_msg_codec.rs +4 -4
  48. package/contracts/oapps/{oft → oft-core}/src/tests/test_resolve_address.rs +3 -3
  49. package/contracts/oapps/{oft → oft-core}/src/tests/test_utils.rs +46 -27
  50. package/contracts/oapps/{oft → oft-core}/src/utils.rs +1 -1
  51. package/contracts/upgrader/src/lib.rs +30 -57
  52. package/contracts/upgrader/src/tests/test_data/test_upgradeable_contract1.wasm +0 -0
  53. package/contracts/upgrader/src/tests/test_data/test_upgradeable_contract2.wasm +0 -0
  54. package/contracts/upgrader/src/tests/test_upgrader.rs +44 -35
  55. package/contracts/utils/src/buffer_reader.rs +1 -0
  56. package/contracts/utils/src/errors.rs +8 -2
  57. package/contracts/utils/src/ownable.rs +125 -3
  58. package/contracts/utils/src/tests/option_ext.rs +1 -1
  59. package/contracts/utils/src/tests/ownable.rs +445 -7
  60. package/contracts/utils/src/tests/ttl_configurable.rs +2 -2
  61. package/contracts/utils/src/tests/upgradeable.rs +372 -175
  62. package/contracts/utils/src/ttl_configurable.rs +3 -3
  63. package/contracts/utils/src/upgradeable.rs +48 -23
  64. package/contracts/workers/dvn/Cargo.toml +1 -0
  65. package/contracts/workers/dvn/src/auth.rs +12 -42
  66. package/contracts/workers/dvn/src/dvn.rs +16 -31
  67. package/contracts/workers/dvn/src/errors.rs +0 -1
  68. package/contracts/workers/dvn/src/interfaces/dvn.rs +35 -0
  69. package/contracts/workers/dvn/src/lib.rs +4 -3
  70. package/contracts/workers/dvn/src/tests/auth.rs +1 -1
  71. package/contracts/workers/dvn/src/tests/dvn.rs +19 -15
  72. package/contracts/workers/dvn/src/tests/multisig/set_threshold.rs +2 -4
  73. package/contracts/workers/dvn/src/tests/multisig/verify_signatures.rs +1 -3
  74. package/contracts/workers/dvn/src/tests/setup.rs +5 -9
  75. package/contracts/workers/dvn-fee-lib/Cargo.toml +1 -1
  76. package/contracts/workers/dvn-fee-lib/src/dvn_fee_lib.rs +3 -5
  77. package/contracts/workers/dvn-fee-lib/src/tests/dvn_fee_lib.rs +2 -3
  78. package/contracts/workers/executor/Cargo.toml +1 -0
  79. package/contracts/workers/executor/src/executor.rs +15 -26
  80. package/contracts/workers/executor-fee-lib/Cargo.toml +2 -1
  81. package/contracts/workers/executor-fee-lib/src/executor_fee_lib.rs +63 -5
  82. package/contracts/workers/executor-fee-lib/src/executor_option.rs +28 -1
  83. package/contracts/workers/executor-fee-lib/src/lib.rs +3 -0
  84. package/contracts/workers/executor-fee-lib/src/tests/executor_fee_lib.rs +701 -0
  85. package/contracts/workers/executor-fee-lib/src/tests/executor_option.rs +370 -0
  86. package/contracts/workers/executor-fee-lib/src/tests/mod.rs +4 -0
  87. package/contracts/workers/executor-fee-lib/src/tests/setup.rs +60 -0
  88. package/contracts/workers/executor-helper/src/lib.rs +3 -0
  89. package/contracts/workers/executor-helper/src/tests/executor_helper.rs +184 -0
  90. package/contracts/workers/executor-helper/src/tests/mod.rs +2 -0
  91. package/contracts/workers/executor-helper/src/tests/setup.rs +366 -0
  92. package/contracts/workers/fee-lib-interfaces/Cargo.toml +14 -0
  93. package/contracts/workers/{worker/src/interfaces/mod.rs → fee-lib-interfaces/src/lib.rs} +4 -3
  94. package/contracts/workers/price-feed/Cargo.toml +2 -1
  95. package/contracts/workers/price-feed/src/events.rs +1 -1
  96. package/contracts/workers/price-feed/src/lib.rs +3 -0
  97. package/contracts/workers/price-feed/src/price_feed.rs +6 -12
  98. package/contracts/workers/price-feed/src/storage.rs +1 -1
  99. package/contracts/workers/price-feed/src/tests/mod.rs +2 -0
  100. package/contracts/workers/price-feed/src/tests/price_feed.rs +869 -0
  101. package/contracts/workers/price-feed/src/tests/setup.rs +70 -0
  102. package/contracts/workers/price-feed/src/types.rs +1 -1
  103. package/contracts/workers/worker/src/errors.rs +0 -3
  104. package/contracts/workers/worker/src/lib.rs +0 -2
  105. package/contracts/workers/worker/src/storage.rs +32 -29
  106. package/contracts/workers/worker/src/tests/setup.rs +1 -7
  107. package/contracts/workers/worker/src/tests/worker.rs +50 -42
  108. package/contracts/workers/worker/src/worker.rs +49 -58
  109. package/package.json +4 -5
  110. package/sdk/.turbo/turbo-test.log +229 -217
  111. package/sdk/dist/generated/bml.d.ts +39 -1
  112. package/sdk/dist/generated/bml.js +33 -8
  113. package/sdk/dist/generated/counter.d.ts +131 -3
  114. package/sdk/dist/generated/counter.js +41 -10
  115. package/sdk/dist/generated/dvn.d.ts +431 -362
  116. package/sdk/dist/generated/dvn.js +80 -55
  117. package/sdk/dist/generated/dvn_fee_lib.d.ts +327 -251
  118. package/sdk/dist/generated/dvn_fee_lib.js +55 -57
  119. package/sdk/dist/generated/endpoint.d.ts +131 -3
  120. package/sdk/dist/generated/endpoint.js +41 -10
  121. package/sdk/dist/generated/executor.d.ts +503 -339
  122. package/sdk/dist/generated/executor.js +80 -48
  123. package/sdk/dist/generated/executor_fee_lib.d.ts +395 -319
  124. package/sdk/dist/generated/executor_fee_lib.js +54 -56
  125. package/sdk/dist/generated/executor_helper.d.ts +53 -187
  126. package/sdk/dist/generated/executor_helper.js +47 -29
  127. package/sdk/dist/generated/layerzero_view.d.ts +1271 -0
  128. package/sdk/dist/generated/layerzero_view.js +294 -0
  129. package/sdk/dist/generated/oft.d.ts +1851 -0
  130. package/sdk/dist/generated/oft.js +347 -0
  131. package/sdk/dist/generated/price_feed.d.ts +329 -253
  132. package/sdk/dist/generated/price_feed.js +55 -57
  133. package/sdk/dist/generated/sml.d.ts +131 -3
  134. package/sdk/dist/generated/sml.js +41 -10
  135. package/sdk/dist/generated/treasury.d.ts +131 -3
  136. package/sdk/dist/generated/treasury.js +41 -10
  137. package/sdk/dist/generated/uln302.d.ts +131 -3
  138. package/sdk/dist/generated/uln302.js +43 -12
  139. package/sdk/dist/generated/upgrader.d.ts +201 -15
  140. package/sdk/dist/generated/upgrader.js +99 -1
  141. package/sdk/dist/index.d.ts +2 -2
  142. package/sdk/dist/index.js +3 -3
  143. package/sdk/package.json +3 -2
  144. package/sdk/src/index.ts +3 -3
  145. package/sdk/test/oft-sml.test.ts +20 -20
  146. package/sdk/test/upgrader.test.ts +2 -3
  147. package/sdk/turbo.json +8 -0
  148. package/tools/ts-bindings-gen/Cargo.toml +2 -0
  149. package/tools/ts-bindings-gen/src/main.rs +53 -5
  150. package/turbo.json +0 -2
  151. package/contracts/oapps/oft/src/interfaces/mint_burn_token.rs +0 -23
  152. package/contracts/oapps/oft/src/interfaces/mod.rs +0 -3
  153. package/contracts/oapps/oft/src/oft_impl.rs +0 -201
  154. package/contracts/oapps/oft/src/tests/extensions/mod.rs +0 -11
  155. package/contracts/oapps/oft/src/tests/extensions/setup.rs +0 -917
  156. package/contracts/oapps/oft/src/tests/extensions/test_oft_fee.rs +0 -751
  157. package/contracts/oapps/oft/src/tests/extensions/test_pausable.rs +0 -434
  158. package/contracts/oapps/oft/src/tests/extensions/test_rate_limiter.rs +0 -1080
  159. package/contracts/oapps/oft-std/integration-tests/utils.rs +0 -427
  160. package/contracts/oapps/oft-std/src/lib.rs +0 -16
  161. package/contracts/oapps/oft-std/src/oft.rs +0 -174
  162. package/sdk/dist/generated/oft_std.d.ts +0 -1722
  163. package/sdk/dist/generated/oft_std.js +0 -316
  164. package/sdk/dist/wasm/blocked-message-lib.d.ts +0 -1
  165. package/sdk/dist/wasm/blocked-message-lib.js +0 -2
  166. package/sdk/dist/wasm/counter.d.ts +0 -1
  167. package/sdk/dist/wasm/counter.js +0 -2
  168. package/sdk/dist/wasm/dvn-fee-lib.d.ts +0 -1
  169. package/sdk/dist/wasm/dvn-fee-lib.js +0 -2
  170. package/sdk/dist/wasm/dvn.d.ts +0 -1
  171. package/sdk/dist/wasm/dvn.js +0 -2
  172. package/sdk/dist/wasm/endpoint-v2.d.ts +0 -1
  173. package/sdk/dist/wasm/endpoint-v2.js +0 -2
  174. package/sdk/dist/wasm/executor-fee-lib.d.ts +0 -1
  175. package/sdk/dist/wasm/executor-fee-lib.js +0 -2
  176. package/sdk/dist/wasm/executor-helper.d.ts +0 -1
  177. package/sdk/dist/wasm/executor-helper.js +0 -2
  178. package/sdk/dist/wasm/executor.d.ts +0 -1
  179. package/sdk/dist/wasm/executor.js +0 -2
  180. package/sdk/dist/wasm/layerzero-views.d.ts +0 -1
  181. package/sdk/dist/wasm/layerzero-views.js +0 -2
  182. package/sdk/dist/wasm/oft-std.d.ts +0 -1
  183. package/sdk/dist/wasm/oft-std.js +0 -2
  184. package/sdk/dist/wasm/price-feed.d.ts +0 -1
  185. package/sdk/dist/wasm/price-feed.js +0 -2
  186. package/sdk/dist/wasm/simple-message-lib.d.ts +0 -1
  187. package/sdk/dist/wasm/simple-message-lib.js +0 -2
  188. package/sdk/dist/wasm/treasury.d.ts +0 -1
  189. package/sdk/dist/wasm/treasury.js +0 -2
  190. package/sdk/dist/wasm/uln302.d.ts +0 -1
  191. package/sdk/dist/wasm/uln302.js +0 -2
  192. package/sdk/dist/wasm/upgrader.d.ts +0 -1
  193. package/sdk/dist/wasm/upgrader.js +0 -2
  194. package/sdk/dist/wasm.d.ts +0 -15
  195. package/sdk/dist/wasm.js +0 -15
  196. /package/contracts/oapps/{oft-std → oft}/integration-tests/extensions/mod.rs +0 -0
  197. /package/contracts/oapps/{oft → oft-core}/src/codec/mod.rs +0 -0
  198. /package/contracts/oapps/{oft → oft-core}/src/codec/oft_compose_msg_codec.rs +0 -0
  199. /package/contracts/oapps/{oft → oft-core}/src/codec/oft_msg_codec.rs +0 -0
  200. /package/contracts/oapps/{oft → oft-core}/src/errors.rs +0 -0
  201. /package/contracts/oapps/{oft → oft-core}/src/events.rs +0 -0
  202. /package/contracts/oapps/{oft → oft-core}/src/storage.rs +0 -0
  203. /package/contracts/oapps/{oft → oft-core}/src/tests/test_decimals.rs +0 -0
  204. /package/contracts/oapps/{oft → oft-core}/src/tests/test_oft_compose_msg_codec.rs +0 -0
  205. /package/contracts/oapps/{oft → oft-core}/src/tests/test_oft_version.rs +0 -0
  206. /package/contracts/oapps/{oft → oft-core}/src/tests/test_quote_oft.rs +0 -0
  207. /package/contracts/oapps/{oft → oft-core}/src/tests/test_quote_send.rs +0 -0
  208. /package/contracts/oapps/{oft → oft-core}/src/tests/test_send.rs +0 -0
  209. /package/contracts/oapps/{oft → oft-core}/src/tests/test_token.rs +0 -0
  210. /package/contracts/oapps/{oft → oft-core}/src/types.rs +0 -0
  211. /package/contracts/workers/{worker/src/interfaces → fee-lib-interfaces/src}/dvn_fee_lib.rs +0 -0
  212. /package/contracts/workers/{worker/src/interfaces → fee-lib-interfaces/src}/executor_fee_lib.rs +0 -0
  213. /package/contracts/workers/{worker/src/interfaces → fee-lib-interfaces/src}/price_feed.rs +0 -0
@@ -0,0 +1,1271 @@
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
+ /**
8
+ * Embedded WASM bytecode (base64-encoded)
9
+ * Size: 34031 bytes (33.23 KB)
10
+ */
11
+ export declare const WASM_BASE64 = "AGFzbQEAAAABmQEaYAJ+fgF+YAN+fn4BfmABfgF+YAABfmAEfn5+fgF+YAJ/fwBgAX8BfmACfn4Bf2ACf34AYAABf2ABfwBgAX8Bf2AAAGACfn8AYAF+AGADf39/AGADfn9+AX9gBH9+fn4Bf2AGf35+f35+AGACf38BfmADfn9/AGADfn5+AX9gBH9/f38BfmACfn4AYAN/fn4AYAV+f39/fwACowEbAWwBMQAAAWwBXwABAWEBMAACAXgBMAAAAXYBXwADAWQBXwABAWIBOAACAWIBZQAAAWIBMAACAWwBMgAAAXgBMQAAAWwBNwAEAWwBNgACAWkBXwACAWkBMAACAWIBMwAAAWIBagAAAWIBMQAEAW0BOQABAW0BYQAEAXYBZwAAAXgBMwADAXgBOAADAWwBMAAAAWwBOAAAAXgBNQACAWIBZgABA2FgBQYHCAcHCQoFCwkGDAMDCg0MCg4GCg8IAwYDAQUFDgwDAwMDAwkACBAECBEAEhMTAQATFAsGExUMDAYACAkCBhYDBQUDAwADAAMCFwAMGAMDAgoCAwUDDAgIGQ8IDwYPBQMBABEGIQR/AUGAgMAAC38AQbyCwAALfwBB84TAAAt/AEGAhcAACwefAxwGbWVtb3J5AgAKYXV0aG9yaXplcgA1DV9fY29uc3RydWN0b3IANghlbmRwb2ludAA7BnVsbjMwMgA9CWxvY2FsX2VpZAA/DWluaXRpYWxpemFibGUAQQp2ZXJpZmlhYmxlAEQKZXhlY3V0YWJsZQBHDnVsbl92ZXJpZmlhYmxlAEwPc2V0X3R0bF9jb25maWdzAFYLdHRsX2NvbmZpZ3MAXBJmcmVlemVfdHRsX2NvbmZpZ3MAXxVpc190dGxfY29uZmlnc19mcm96ZW4AYBNleHRlbmRfaW5zdGFuY2VfdHRsAGEFb3duZXIAYg1wZW5kaW5nX293bmVyAGQSdHJhbnNmZXJfb3duZXJzaGlwAGUacHJvcG9zZV9vd25lcnNoaXBfdHJhbnNmZXIAZxBhY2NlcHRfb3duZXJzaGlwAGoScmVub3VuY2Vfb3duZXJzaGlwAGsHdXBncmFkZQBsB21pZ3JhdGUAbgZmcmVlemUAbwlpc19mcm96ZW4AcQFfAwEKX19kYXRhX2VuZAMCC19faGVhcF9iYXNlAwMKoFZgTQECfkIAIQICQAJAIAEQnICAgAAiA0ICEJ2AgIAARQ0AIANCAhCAgICAACICQv8Bg0LNAFINASAAIAI3AwhCASECCyAAIAI3AwAPCwALwgECAX8BfiOAgICAAEEQayIBJICAgIAAAkACQAJAAkACQAJAIABB/wFxDgMAAQIACyABQcCAwIAAQQgQsYCAgAAgASgCAA0DIAEgASkDCBCygICAAAwCCyABQciAwIAAQQYQsYCAgAAgASgCAA0CIAEgASkDCBCygICAAAwBCyABQc6AwIAAQQgQsYCAgAAgASgCAA0BIAEgASkDCBCygICAAAsgASkDCCECIAEpAwBQDQELAAsgAUEQaiSAgICAACACCw8AIAAgARCXgICAAEIBUQsVACAAEJyAgIAAIAFCAhCBgICAABoLDwAgACABEKCAgIAAQQFzCw0AIAAgARCDgICAAFALWAECfyOAgICAAEEQayIAJICAgIAAIABBBGoQooCAgAACQCAAKAIEQQFHDQAgACgCCCAAKAIMEKOAgIAAC0EAEKSAgIAAIQEgAEEQaiSAgICAACABQf0BcQsMACAAQQEQ3YCAgAALGwAgAK1CIIZCBIQgAa1CIIZCBIQQmICAgAAaC0cCAX8BfkECIQECQCAAEPmAgIAAIgJCAhCdgICAAEUNAEEBIQECQAJAIAJCAhCAgICAAKdB/wFxDgIBAgALAAtBACEBCyABC4sBAgJ/AX4jgICAgABBEGsiACSAgICAACAAQQRqEKKAgIAAAkAgACgCBEEBRw0AIAAoAgggACgCDBCjgICAAAtBACEBAkBBABCmgICAACICQgIQnYCAgABFDQBBASEBAkACQCACQgIQgICAgACnQf8BcQ4CAQIACwALQQAhAQsgAEEQaiSAgICAACABC8IBAgF/AX4jgICAgABBEGsiASSAgICAAAJAAkACQAJAAkACQCAAQf8BcQ4DAAECAAsgAUHShMCAAEEGELGAgIAAIAEoAgANAyABIAEpAwgQsoCAgAAMAgsgAUHYhMCAAEEIELGAgIAAIAEoAgANAiABIAEpAwgQsoCAgAAMAQsgAUHghMCAAEEKELGAgIAAIAEoAgANASABIAEpAwgQsoCAgAALIAEpAwghAiABKQMAUA0BCwALIAFBEGokgICAgAAgAgsPABCogICAABCCgICAABoLZgIBfwF+I4CAgIAAQRBrIgAkgICAgAAgABCigICAAAJAIAAoAgBBAUcNACAAKAIEIAAoAggQo4CAgAALIAAQqoCAgAAgACkDCCEBIAApAwBBiggQq4CAgAAgAEEQaiSAgICAACABC0oCAX8BfiOAgICAAEEQayIAJICAgIAAIAAQqoCAgAAgACkDCCEBIAApAwBBiggQq4CAgAAgARCCgICAABogAEEQaiSAgICAACABC1ABAX8jgICAgABBEGsiASSAgICAACABQQRqEKKAgIAAAkAgASgCBEEBRw0AIAEoAgggASgCDBCjgICAAAsgABCwgICAACABQRBqJICAgIAACykAAkAgAKdBAXFFDQAPCyABQfp3aq1CIIZCg4CAgOCAAXwQroCAgAAAC0IBAX8jgICAgABBEGsiACSAgICAACAAEK2AgIAAAkAgACkDAFANAEKDgICAsIEBEK6AgIAAAAsgAEEQaiSAgICAAAuTAQIBfwJ+I4CAgIAAQRBrIgEkgICAgAAgAUEEahCigICAAAJAIAEoAgRBAUcNACABKAIIIAEoAgwQo4CAgAALQgAhAgJAAkBBARCvgICAACIDQgAQnYCAgABFDQAgA0IAEICAgIAAIgJC/wGDQs0AUg0BIAAgAjcDCEIBIQILIAAgAjcDACABQRBqJICAgIAADwsACwsAIAAQmYCAgAAaC5IBAgF/AX4jgICAgABBEGsiASSAgICAAAJAAkACQAJAIABBAXFFDQAgAUHlg8CAAEEMELGAgIAAIAEoAgANAiABIAEpAwgQsoCAgAAMAQsgAUHgg8CAAEEFELGAgIAAIAEoAgANASABIAEpAwgQsoCAgAALIAEpAwghAiABKQMAUA0BCwALIAFBEGokgICAgAAgAgtNAQJ+QgAhAQJAAkBBABCvgICAACICQgIQnYCAgABFDQAgAkICEICAgIAAIgFC/wGDQs0AUg0BIAAgATcDCEIBIQELIAAgATcDAA8LAAtRAgF/AX4jgICAgABBEGsiAySAgICAACADIAEgAhD2gICAAEIBIQQCQCADKAIADQAgACADKQMINwMIQgAhBAsgACAENwMAIANBEGokgICAgAALRAEBfyOAgICAAEEQayICJICAgIAAIAIgATcDCCACQQhqQQEQyoCAgAAhASAAQgA3AwAgACABNwMIIAJBEGokgICAgAALDgBBgIDAgAAQtICAgAALDAAgAEEgENGAgIAACwgAEKiAgIAAC8sBAAJAAkACQCAAQv8Bg0LNAFINACABQv8Bg0LNAFINACACQv8Bg0LNAFINAEGAyx5BgNIfELeAgIAAQYDLHkGA0h8QuICAgABBABCvgICAAEICEJ2AgIAADQEgABC5gICAAEEAIAEQnoCAgABBASACEJ6AgIAAIAFCjtKuFRCEgICAABCFgICAACIBQv8Bg0IEUg0CQQIQnICAgAAgAUKEgICAcINCAhCBgICAABpCAg8LAAtCg4CAgJCBARCugICAAAALELqAgIAAAAsOAEEBIAAgARD6gICAAAsOAEECIAAgARD6gICAAAsOAEEAIABCAhDpgICAAAsJABDygICAAAALCAAQvICAgAALawIBfwF+I4CAgIAAQRBrIgAkgICAgAAgABCigICAAAJAIAAoAgBBAUcNACAAKAIEIAAoAggQo4CAgAALIABBABCbgICAAAJAIAAoAgANABDUgICAAAALIAApAwghASAAQRBqJICAgIAAIAELCAAQvoCAgAALawIBfwF+I4CAgIAAQRBrIgAkgICAgAAgABCigICAAAJAIAAoAgBBAUcNACAAKAIEIAAoAggQo4CAgAALIABBARCbgICAAAJAIAAoAgANABDUgICAAAALIAApAwghASAAQRBqJICAgIAAIAELDwAQwICAgACtQiCGQgSEC4gBAgF/AX4jgICAgABBEGsiACSAgICAACAAQQRqEKKAgIAAAkAgACgCBEEBRw0AIAAoAgggACgCDBCjgICAAAsCQAJAQQIQnICAgAAiAUICEJ2AgIAARQ0AIAFCAhCAgICAACIBQv8Bg0IEUQ0BAAsQ1ICAgAAACyAAQRBqJICAgIAAIAFCIIinC7oBAQJ/I4CAgIAAQcAAayICJICAgIAAIAJBIGogABDCgICAAAJAIAIoAiBBAUYNACACQQhqQRBqIAJBOGopAwA3AwAgAkEQaiACQSBqQRBqKQMANwMAIAIgAikDKDcDCCABQv8Bg0LNAFINACACQSBqEKKAgIAAAkAgAigCIEEBRw0AIAIoAiQgAigCKBCjgICAAAsQvICAgAAgAkEIaiABEMOAgIAAIQMgAkHAAGokgICAgAAgA60PCwAL4gECAn8CfiOAgICAAEEwayICJICAgIAAQQAhAwJAA0Ag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ASACKQMIUA0BCwALIAJB0ABqJICAgIAAIAELrgICAX8BfiOAgICAAEHAAGsiBiSAgICAAEGogsCAAEEUEMmAgIAAIQcgBkEgaiAFEPOAgIAAAkAgBigCIEEBRg0AIAYgBikDKDcDGCAGIAQ3AxAgBiACNwMAIAYgA61CIIZCBIQ3AwhBACEDAkADQAJAIANBIEcNAEEAIQMCQANAIANBIEYNASAGQSBqIANqIAYgA2opAwA3AwAgA0EIaiEDDAALCwJAAkAgASAHIAZBIGpBBBDKgICAABCFgICAACIFQgJSDQBCACEFDAELIAZBIGogBRDFgICAACAGKAIgQQFGDQMgBikDKCEEQgEhBQsgACAENwMIIAAgBTcDACAGQcAAaiSAgICAAA8LIAZBIGogA2pCAjcDACADQQhqIQMMAAsLELqAgIAAAAsAC0UCAX8BfiOAgICAAEEQayICJICAgIAAIAIgACABEPaAgIAAAkAgAigCAEEBRw0AAAsgAikDCCEDIAJBEGokgICAgAAgAwsaACAArUIghkIEhCABrUIghkIEhBCUgICAAAtRAQF/I4CAgIAAQRBrIgMkgICAgAAgAyAAIAEgAhCFgICAABD0gICAAAJAIAMoAgBBAUcNABC6gICAAAALIAMpAwghAiADQRBqJICAgIAAIAIL5QgGAX8BfgF/AX4BfwF+I4CAgIAAQcAAayICJICAgIAAAkACQCAAQv8Bg0LIAFINACACIAA3AwAgAkEIaiABEMWAgIAAIAIoAghBAUYNACACKQMQIQMgAkEIahCigICAAAJAIAIoAghBAUcNACACKAIMIAIoAhAQo4CAgAALAkACQCACKQMAEIaAgIAAQoCAgIBwg0KAgICAkApSDQAgAkEANgI0IAIgAjYCMAJAIAJBMGpBARDNgICAACIAEIaAgIAAQoCAgIBwg0KAgICAEFINACACQQA6AAgCQCAAEIaAgIAAQoCAgIBwg0KAgICAEFINACAAIAJBCGpBARDOgICAAAJAIAItAAhBAUcNAAJAIAJBMGpBCBDNgICAACIAEIaAgIAAQoCAgIBwg0KAgICAgAFSDQAgAkIANwMIIAAQhoCAgABCgICAgHCDQoCAgICAAVINAiAAIAJBCGpBCBDOgICAACACKQMIIQAgAkEwahDPgICAACEEIAJBMGoQ0ICAgAAhBSACQTBqEM+AgIAAIQYgAkEwahDQgICAACEBAkAgBhDAgICAAEcNAEG8gsCAAEEIENGAgIAAIAEQh4CAgAAQiICAgAAiAUL/AYNCzQBSDQcgAiAAQjiGIABCgP4Dg0IohoQgAEKAgPwHg0IYhiAAQoCAgPgPg0IIhoSEIABCCIhCgICA+A+DIABCGIhCgID8B4OEIABCKIhCgP4DgyAAQjiIhISEIgA3AxAgAiAFNwMIIAIgBDYCGAJAELyAgIAAIAJBCGogARDDgICAAA0AIAJBCGpBqIHAgABBEBCxgICAACACKAIIDQggAkEIaiACKQMQELKAgIAADAcLAkACQCACQQhqIAEQvoCAgAAiByADEMaAgIAARQ0AIAJBMGoQvICAgAAgASAEIAUgABDIgICAACACKAIwRQ0BIAIpAzggAxCggICAAEUNAQsgAkEIakGggcCAAEEIELGAgIAAIAIoAggNCCACQQhqIAIpAxAQsoCAgAAMBwsgAikDACEAQcSCwIAAQQoQyYCAgAAhASACIAM3AyggAiAANwMgQQAhBANAAkAgBEEQRw0AQQAhBAJAA0AgBEEQRg0BIAJBMGogBGogAkEgaiAEaikDADcDACAEQQhqIQQMAAsLAkAgByABIAJBMGpBAhDKgICAABDSgICAAA0AIAJBCGpBjYHAgABBCRCxgICAACACKAIIDQogAkEIaiACKQMQELKAgIAADAkLIAJBCGpBloHAgABBChCxgICAACACKAIIDQkgAkEIaiACKQMQELKAgIAADAgLIAJBMGogBGpCAjcDACAEQQhqIQQMAAsLQoOAgIAQEK6AgIAAAAtCg4CAgICCARCugICAAAALQoOAgIDQiQEQroCAgAAACxDTgICAAAALQoOAgICAggEQroCAgAAAC0KDgICAwIkBEK6AgIAAAAsgAikDECEAIAIpAwhQDQELAAsgAkHAAGokgICAgAAgAAt1AgJ/AX4CQAJAIAAoAgQiAiABaiIBIAJJDQAgASAAKAIAIgMpAwAQhoCAgABCIIinSw0BIAMpAwAgAq1CIIZCBIQgAa1CIIZCBIQQmoCAgAAhBCAAIAE2AgQgBA8LELqAgIAAAAtCg4CAgID9ABCugICAAAALHwAgAEIEIAGtQiCGQgSEIAKtQiCGQgSEEJGAgIAAGgu5AQIBfwF+I4CAgIAAQRBrIgEkgICAgAACQAJAIABBBBDNgICAACICEIaAgIAAQoCAgIBwg0KAgICAwABSDQAgAUEANgIMIAIQhoCAgABCgICAgHCDQoCAgIDAAFINASACIAFBDGpBBBDOgICAACABKAIMIQAgAUEQaiSAgICAACAAQRh0IABBgP4DcUEIdHIgAEEIdkGA/gNxIABBGHZycg8LQoOAgICAggEQroCAgAAACxDTgICAAAAL/wEDAX8BfgJ/I4CAgIAAQcAAayIBJICAgIAAAkACQCAAQSAQzYCAgAAiAhCGgICAAEKAgICAcINCgICAgIAEUg0AIAFBIGpBGGoiAEIANwMAIAFBIGpBEGoiA0IANwMAIAFBIGpBCGoiBEIANwMAIAFCADcDICACEIaAgIAAQoCAgIBwg0KAgICAgARSDQEgAiABQSBqQSAQzoCAgAAgAUEYaiAAKQMANwMAIAFBEGogAykDADcDACABQQhqIAQpAwA3AwAgASABKQMgNwMAIAEQtICAgAAhAiABQcAAaiSAgICAACACDwtCg4CAgICCARCugICAAAALENOAgIAAAAsaACAArUIghkIEhCABrUIghkIEhBCPgICAAAs0AQF/QQEhAwJAAkACQCAAIAEgAhCFgICAAKdB/wFxDgIBAgALELqAgIAAAAtBACEDCyADCwkAELqAgIAAAAsJABC6gICAAAALfQIBfwF+I4CAgIAAQTBrIgEkgICAgAAgAUEgaiAAKQMIEPOAgIAAAkAgASgCIEEBRw0AAAsgASABKQMoNwMIIAEgACkDADcDECABIAA1AhBCIIZCBIQ3AxhBzIHAgABBAyABQQhqQQMQ24CAgAAhAiABQTBqJICAgIAAIAIL3gQBBX8jgICAgABB0ABrIgIkgICAgAAgAkEoaiAAENeAgIAAAkAgAigCKEECRg0AIAJBCGpBCGogAkEoakEIaiIDKAIANgIAIAIgAikCKDcDCCACQShqIAEQ14CAgAAgAigCKEECRg0AIAJBGGpBCGogAygCADYCACACIAIpAig3AxggAkEoahCigICAAAJAIAIoAihBAUcNACACKAIsIAIoAjAQo4CAgAALEKeAgIAAAkACQAJAEKWAgIAADQAQ2ICAgAAiA0GA+4ADIANBgPuAA0kbIQQgAiACQRhqNgIsIAIgAkEIajYCKEEAIQMDQCADQQhGDQMCQCACQShqIANqKAIAIgUoAgBBAXFFDQAgBSgCCCIGIARLDQMgBSgCBCAGSw0DCyADQQRqIQMMAAsLQoOAgIDQ/wAQroCAgAAAC0KDgICAwP8AEK6AgIAAAAsCQAJAIAIoAghBAUcNACACKAIMIAIoAhAQt4CAgAAMAQtBARCmgICAAEICEImAgIAAGgsCQAJAIAIoAhhBAUcNACACKAIcIAIoAiAQuICAgAAMAQtBAhCmgICAAEICEImAgIAAGgsgAkEoakEIaiACQQhqQQhqKAIANgIAIAJBPGogAkEYakEIaigCADYCACACIAIpAwg3AyggAiACKQMYNwI0QYyEwIAAQQ8QyYCAgAAQ2YCAgAAhACACQShqENqAgIAAIQEgAiACQTRqENqAgIAANwNIIAIgATcDQCAAQbCEwIAAQQIgAkHAAGpBAhDbgICAABCKgICAABogAkHQAGokgICAgABCAg8LAAtoAQF/I4CAgIAAQRBrIgIkgICAgAACQAJAIAFCAlENACACQQRqIAEQ94CAgAACQCACKAIERQ0AIABBAjYCAAwCCyAAIAIpAgg3AgQgAEEBNgIADAELIABBADYCAAsgAkEQaiSAgICAAAszAQJ+EJWAgIAAIQACQBCWgICAAEIgiCIBIABCIIgiAFQNACABpyAAp2sPCxC6gICAAAALYwMBfwF+AX8jgICAgABBEGsiASSAgICAACABIAA3AwBCAiECQQEhAwJAA0AgA0UNASADQX9qIQMgACECDAALCyABIAI3AwggAUEIakEBEMqAgIAAIQAgAUEQaiSAgICAACAAC0MCAX8BfiOAgICAAEEQayIBJICAgIAAIAEgABDegICAAAJAIAEoAgBBAUcNAAALIAEpAwghAiABQRBqJICAgIAAIAILLgACQCABIANGDQAACyAArUIghkIEhCACrUIghkIEhCABrUIghkIEhBCSgICAAAvEAQICfwF+I4CAgIAAQcAAayIAJICAgIAAIABBCGoQooCAgAACQCAAKAIIQQFHDQAgACgCDCAAKAIQEKOAgIAACyAAQQhqEKKAgIAAIABBFGoiAUECEN2AgIAAIABBMGogAEEIahDegICAAAJAAkAgACgCMA0AIAApAzghAiAAQTBqIAEQ3oCAgAAgACgCMEEBRw0BCwALIAAgACkDODcDKCAAIAI3AyAgAEEgakECEMqAgIAAIQIgAEHAAGokgICAgAAgAgt3AgJ/AX4jgICAgABBEGsiAiSAgICAAEEAIQMCQAJAIAEQpoCAgAAiBEICEJ2AgIAARQ0AIAJBBGogBEICEICAgIAAEPeAgIAAQQEhAyACKAIEQQFGDQEgACACKQIINwIECyAAIAM2AgAgAkEQaiSAgICAAA8LAAswAAJAIAEoAgBBAUcNACAAIAEoAgQgASgCCBD4gICAAA8LIABCADcDACAAQgI3AwgLqgEBAX8jgICAgABBIGsiACSAgICAACAAQQxqEKKAgIAAAkAgACgCDEEBRw0AIAAoAhAgACgCFBCjgICAAAsQp4CAgAACQBClgICAAEUNAEKDgICA4P8AEK6AgIAAAAtBABCmgICAAEIBQgIQgYCAgAAaQcCEwIAAQRIQyYCAgAAQ2YCAgABBBEEAIABBGGpBABDbgICAABCKgICAABogAEEgaiSAgICAAEICCwkAEKWAgIAArQsxAAJAIABC/wGDQgRSDQAgAUL/AYNCBFINACAAQiCIpyABQiCIpxCjgICAAEICDwsACz4CAX8BfiOAgICAAEEQayIAJICAgIAAIAAQqoCAgAAgACkDACAAKQMIEOOAgIAAIQEgAEEQaiSAgICAACABCw0AIAFCAiAAp0EBcRsLPgIBfwF+I4CAgIAAQRBrIgAkgICAgAAgABCtgICAACAAKQMAIAApAwgQ44CAgAAhASAAQRBqJICAgIAAIAELfQIBfwF+I4CAgIAAQRBrIgEkgICAgAACQCAAQv8Bg0LNAFINACABQQRqEKKAgIAAAkAgASgCBEEBRw0AIAEoAgggASgCDBCjgICAAAsQqYCAgAAhAhCsgICAACAAELmAgIAAIAIgABDmgICAACABQRBqJICAgIAAQgIPCwALYQIBfwF+I4CAgIAAQRBrIgIkgICAgABB14LAgABBFRDJgICAABDZgICAACEDIAIgADcDCCACIAE3AwAgA0GAg8CAAEECIAJBAhDbgICAABCKgICAABogAkEQaiSAgICAAAvdAgIBfwJ+I4CAgIAAQSBrIgIkgICAgAACQAJAAkAgAEL/AYNCzQBSDQAgAUL/AYNCBFINACACQQhqEKKAgIAAAkAgAigCCEEBRw0AIAIoAgwgAigCEBCjgICAAAsQqYCAgAAhAwJAAkAgAUL/////D1YNACACQQhqEK2AgIAAIAIpAxAhASACKQMIQYgIEKuAgIAAIAEgABCDgICAAFBFDQMQ6ICAgAAMAQsQ2ICAgAAgAUIgiKdJDQNBASAAQgAQ6YCAgABBARCvgICAAEIAIAFChICAgHCDIgEgARCLgICAABpBkIPAgABBFhDJgICAABDZgICAACEEIAIgATcDGCACIAM3AxAgAiAANwMIIARBrIPAgABBAyACQQhqQQMQ24CAgAAQioCAgAAaCyACQSBqJICAgIAAQgIPCwALQoOAgIDggAEQroCAgAAAC0KDgICA8IABEK6AgIAAAAsTAEEBEK+AgIAAQgAQiYCAgAAaCxUAIAAQr4CAgAAgASACEIGAgIAAGgunAQIBfwJ+I4CAgIAAQRBrIgAkgICAgAAgABCigICAAAJAIAAoAgBBAUcNACAAKAIEIAAoAggQo4CAgAALIAAQrYCAgAAgACkDCCEBIAApAwBBiAgQq4CAgAAgARCCgICAABogABCwgICAAAJAIAAoAgANABDUgICAAAALIAApAwghAhDogICAACABELmAgIAAIAIgARDmgICAACAAQRBqJICAgIAAQgILoAECAX8CfiOAgICAAEEQayIAJICAgIAAIAAQooCAgAACQCAAKAIAQQFHDQAgACgCBCAAKAIIEKOAgIAACxCpgICAACEBEKyAgIAAQQAQr4CAgABCAhCJgICAABpBxIPAgABBExDJgICAABDZgICAACECIAAgATcDACACQdiDwIAAQQEgAEEBENuAgIAAEIqAgIAAGiAAQRBqJICAgIAAQgILmAEBAX8jgICAgABBEGsiASSAgICAACABIAAQxYCAgAACQAJAIAEoAgBBAUYNACABKQMIIQAgARCigICAAAJAIAEoAgBBAUcNACABKAIEIAEoAggQo4CAgAALEKeAgIAAEKGAgIAADQFBARDtgICAACAAEIyAgIAAGiABQRBqJICAgIAAQgIPCwALQoOAgIDAgwEQroCAgAAACwwAQQEgABDwgICAAAutAQEBfyOAgICAAEEQayIBJICAgIAAAkACQAJAIABC/wGDQsgAUg0AIAFBBGoQooCAgAACQCABKAIEQQFHDQAgASgCCCABKAIMEKOAgIAACxCngICAAEEBEKSAgIAAQf0BcUUNASAAEIiAgIAAQv8Bg0ICUg0CQQAQ7YCAgAAgAUEQaiSAgICAAEICDwsAC0KDgICAsIMBEK6AgIAAAAtCg4CAgKCDARCugICAAAALWgEBfyOAgICAAEEQayIAJICAgIAAIABBBGoQooCAgAACQCAAKAIEQQFHDQAgACgCCCAAKAIMEKOAgIAACxCngICAAEEAQQEQ8ICAgAAgAEEQaiSAgICAAEICCxoAIAAQ+YCAgAAgAa1C/wGDQgIQgYCAgAAaCwkAEKGAgIAArQsDAAALOwACQAJAIAFC//////////8AVg0AIAFCCIZCBoQhAQwBCyABEI2AgIAAIQELIABCADcDACAAIAE3AwgLXQIBfwF+AkACQCABp0H/AXEiAkHAAEYNAAJAIAJBBkYNAEIBIQNCg5CAgIABIQEMAgsgAUIIiCEBQgAhAwwBC0IAIQMgARCOgICAACEBCyAAIAM3AwAgACABNwMICzEAAkAgAiAERg0AAAsgACABrUIghkIEhCADrUIghkIEhCACrUIghkIEhBCTgICAABoL2wECAX4EfwJAAkAgAkEJSw0AQgAhAyACIQQgASEFA0ACQCAEDQAgA0IIhkIOhCEDDAMLQQEhBgJAIAUtAAAiB0HfAEYNAAJAIAdBUGpB/wFxQQpJDQACQCAHQb9/akH/AXFBGkkNACAHQZ9/akH/AXFBGUsNBCAHQUVqIQYMAgsgB0FLaiEGDAELIAdBUmohBgsgA0IGhiAGrUL/AYOEIQMgBEF/aiEEIAVBAWohBQwACwsgAa1CIIZCBIQgAq1CIIZCBIQQkICAgAAhAwsgAEIANwMAIAAgAzcDCAutAQICfwF+I4CAgIAAQRBrIgIkgICAgABBACEDAkADQCADQRBGDQEgAiADakICNwMAIANBCGohAwwACwtBASEDAkAgAUL/AYNCzABSDQAgAUH8g8CAAEECIAJBAhD1gICAACACKQMAIgFC/wGDQgRSDQAgAikDCCIEQv8Bg0IEUg0AIAAgAUIgiKc2AgggACAEQiCIPgIEQQAhAwsgACADNgIAIAJBEGokgICAgAALYAIBfwF+I4CAgIAAQRBrIgMkgICAgAAgAyABrUIghkIEhDcDCCADIAKtQiCGQgSENwMAQfyDwIAAQQIgA0ECENuAgIAAIQQgAEIANwMAIAAgBDcDCCADQRBqJICAgIAAC5IBAgF/AX4jgICAgABBEGsiASSAgICAAAJAAkACQAJAIABBAXFFDQAgAUHqhMCAAEEJELGAgIAAIAEoAgANAiABIAEpAwgQsoCAgAAMAQsgAUHShMCAAEEGELGAgIAAIAEoAgANASABIAEpAwgQsoCAgAALIAEpAwghAiABKQMAUA0BCwALIAFBEGokgICAgAAgAgtWAgF/AX4jgICAgABBEGsiAySAgICAACAAEKaAgIAAIQQgAyABIAIQ+ICAgAACQCADKAIAQQFHDQAACyAEIAMpAwhCAhCBgICAABogA0EQaiSAgICAAAsL/QQBAEGAgMAAC/MEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAD//////////////////////////////////////////0VuZHBvaW50VWxuMzAyTG9jYWxFaWROb3RFeGVjdXRhYmxlVmVyaWZpZWRCdXROb3RFeGVjdXRhYmxlRXhlY3V0YWJsZUV4ZWN1dGVkVmVyaWZ5aW5nVmVyaWZpYWJsZVZlcmlmaWVkTm90SW5pdGlhbGl6YWJsZW5vbmNlc2VuZGVyc3JjX2VpZAAAuAAQAAUAAAC9ABAABgAAAMMAEAAHAAAAaW5pdGlhbGl6YWJsZWlzX3ZhbGlkX3JlY2VpdmVfbGlicmFyeWluYm91bmRfbm9uY2VsYXp5X2luYm91bmRfbm9uY2VpbmJvdW5kX3BheWxvYWRfaGFzaAAAABIAAAABdmVyaWZpYWJsZXRocmVzaG9sZG93bmVyc2hpcF90cmFuc2ZlcnJlZG5ld19vd25lcm9sZF9vd25lcgAAbAEQAAkAAAB1ARAACQAAAG93bmVyc2hpcF90cmFuc2ZlcnJpbmd0dGwAAABsARAACQAAAHUBEAAJAAAApgEQAAMAAABvd25lcnNoaXBfcmVub3VuY2VkAHUBEAAJAAAAT3duZXJQZW5kaW5nT3duZXJleHRlbmRfdG8AAPEBEAAJAAAATgEQAAkAAAB0dGxfY29uZmlnc19zZXRpbnN0YW5jZXBlcnNpc3RlbnQAAAAbAhAACAAAACMCEAAKAAAAdHRsX2NvbmZpZ3NfZnJvemVuRnJvemVuSW5zdGFuY2VQZXJzaXN0ZW50TWlncmF0aW5nAKOmAQ5jb250cmFjdHNwZWN2MAAAAAQAAAAiRXJyb3JzIGZvciBMYXllclplcm9WaWV3IGNvbnRyYWN0LgAAAAAAAAAAABJMYXllclplcm9WaWV3RXJyb3IAAAAAAAEAAAApSW52YWxpZCBwYWNrZXQgaGVhZGVyIChkc3RfZWlkIG1pc21hdGNoKS4AAAAAAAAKSW52YWxpZEVJRAAAAAAAAQAAAAAAAAAAAAAACmF1dGhvcml6ZXIAAAAAAAAAAAABAAAAEwAAAAAAAAAAAAAADV9fY29uc3RydWN0b3IAAAAAAAADAAAAAAAAAAVvd25lcgAAAAAAABMAAAAAAAAACGVuZHBvaW50AAAAEwAAAAAAAAAGdWxuMzAyAAAAAAATAAAAAAAAAAAAAAAdUmV0dXJucyB0aGUgZW5kcG9pbnQgYWRkcmVzcy4AAAAAAAAIZW5kcG9pbnQAAAAAAAAAAQAAABMAAAAAAAAAG1JldHVybnMgdGhlIFVsbjMwMiBhZGRyZXNzLgAAAAAGdWxuMzAyAAAAAAAAAAAAAQAAABMAAAAAAAAAHlJldHVybnMgdGhlIGxvY2FsIGVuZHBvaW50IElELgAAAAAACWxvY2FsX2VpZAAAAAAAAAAAAAABAAAABAAAAAAAAABQQ2hlY2tzIGlmIGEgbWVzc2FnaW5nIHBhdGggY2FuIGJlIGluaXRpYWxpemVkIGZvciB0aGUgZ2l2ZW4gb3JpZ2luIGFuZCByZWNlaXZlci4AAAANaW5pdGlhbGl6YWJsZQAAAAAAAAIAAAAAAAAABm9yaWdpbgAAAAAH0AAAAAZPcmlnaW4AAAAAAAAAAAAIcmVjZWl2ZXIAAAATAAAAAQAAAAEAAAAAAAAAtENoZWNrcyBpZiBhIG1lc3NhZ2UgY2FuIGJlIHZlcmlmaWVkIGF0IHRoZSBlbmRwb2ludC4KClZlcmlmaWVzOgoxLiBSZWNlaXZlIGxpYnJhcnkgaXMgdmFsaWQgZm9yIHRoaXMgcmVjZWl2ZXIgYW5kIHNvdXJjZQoyLiBFbmRwb2ludCBub25jZSBjaGVjayBwYXNzZXMKMy4gUGF5bG9hZCBoYXNoIGlzIG5vdCBlbXB0eQAAAAp2ZXJpZmlhYmxlAAAAAAAEAAAAAAAAAAZvcmlnaW4AAAAAB9AAAAAGT3JpZ2luAAAAAAAAAAAACHJlY2VpdmVyAAAAEwAAAAAAAAALcmVjZWl2ZV9saWIAAAAAEwAAAAAAAAAMcGF5bG9hZF9oYXNoAAAD7gAAACAAAAABAAAAAQAAAAAAAAApUmV0dXJucyB0aGUgZXhlY3V0aW9uIHN0YXRlIG9mIGEgbWVzc2FnZS4AAAAAAAAKZXhlY3V0YWJsZQAAAAAAAgAAAAAAAAAGb3JpZ2luAAAAAAfQAAAABk9yaWdpbgAAAAAAAAAAAAhyZWNlaXZlcgAAABMAAAABAAAH0AAAAA5FeGVjdXRpb25TdGF0ZQAAAAAAAAAAAO5SZXR1cm5zIHRoZSBjb21iaW5lZCB2ZXJpZmljYXRpb24gc3RhdGUgb2YgYSBtZXNzYWdlLgoKVGhpcyBmdW5jdGlvbiBjaGVja3M6CjEuIFBhY2tldCBoZWFkZXIgdmFsaWRpdHkgKGRzdF9laWQgbWF0Y2hlcyBsb2NhbF9laWQpCjIuIEVuZHBvaW50IGluaXRpYWxpemFibGUgc3RhdHVzCjMuIEVuZHBvaW50IHZlcmlmaWFibGUgc3RhdHVzCjQuIFVMTiB2ZXJpZmlhYmxlIHN0YXR1cyAoRFZOIGNvbmZpcm1hdGlvbnMpAAAAAAAOdWxuX3ZlcmlmaWFibGUAAAAAAAIAAAAAAAAADXBhY2tldF9oZWFkZXIAAAAAAAAOAAAAAAAAAAxwYXlsb2FkX2hhc2gAAAPuAAAAIAAAAAEAAAfQAAAAEVZlcmlmaWNhdGlvblN0YXRlAAAAAAAAAgAAAAAAAAAAAAAAFExheWVyWmVyb1ZpZXdTdG9yYWdlAAAAAwAAAAAAAAAAAAAACEVuZHBvaW50AAAAAAAAAAAAAAAGVWxuMzAyAAAAAAAAAAAAAAAAAAhMb2NhbEVpZAAAAAIAAACBUmVwcmVzZW50cyB0aGUgZXhlY3V0aW9uIHN0YXRlIG9mIGEgY3Jvc3MtY2hhaW4gbWVzc2FnZS4KClVzZWQgYnkgZXhlY3V0b3JzIHRvIGRldGVybWluZSB3aGVuIGEgbWVzc2FnZSBpcyByZWFkeSB0byBiZSBkZWxpdmVyZWQuAAAAAAAAAAAAAA5FeGVjdXRpb25TdGF0ZQAAAAAABAAAAAAAAAA+TWVzc2FnZSBpcyBub3QgcmVhZHkgZm9yIGV4ZWN1dGlvbiAtIHdhaXRpbmcgZm9yIHZlcmlmaWNhdGlvbi4AAAAAAA1Ob3RFeGVjdXRhYmxlAAAAAAAAAAAAAEZNZXNzYWdlIGlzIHZlcmlmaWVkIGJ1dCBjYW5ub3QgYmUgZXhlY3V0ZWQgeWV0IChwcmlvciBub25jZXMgcGVuZGluZykuAAAAAAAYVmVyaWZpZWRCdXROb3RFeGVjdXRhYmxlAAAAAAAAACBNZXNzYWdlIGlzIHJlYWR5IHRvIGJlIGV4ZWN1dGVkLgAAAApFeGVjdXRhYmxlAAAAAAAAAAAAIk1lc3NhZ2UgaGFzIGFscmVhZHkgYmVlbiBleGVjdXRlZC4AAAAAAAhFeGVjdXRlZAAAAAIAAACIUmVwcmVzZW50cyB0aGUgdmVyaWZpY2F0aW9uIHN0YXRlIG9mIGEgY3Jvc3MtY2hhaW4gbWVzc2FnZSBhdCB0aGUgVUxOIGxldmVsLgoKVXNlZCBieSBEVk5zIGFuZCBleGVjdXRvcnMgdG8gdHJhY2sgdmVyaWZpY2F0aW9uIHByb2dyZXNzLgAAAAAAAAARVmVyaWZpY2F0aW9uU3RhdGUAAAAAAAAEAAAAAAAAADNEVk5zIGFyZSBzdGlsbCBjb2xsZWN0aW5nIHNpZ25hdHVyZXMvY29uZmlybWF0aW9ucy4AAAAACVZlcmlmeWluZwAAAAAAAAAAAABASGFzIGVub3VnaCBEVk4gY29uZmlybWF0aW9ucywgcmVhZHkgdG8gYmUgY29tbWl0dGVkIHRvIGVuZHBvaW50LgAAAApWZXJpZmlhYmxlAAAAAAAAAAAAIUFscmVhZHkgdmVyaWZpZWQgYXQgdGhlIGVuZHBvaW50LgAAAAAAAAhWZXJpZmllZAAAAAAAAAAlQ2Fubm90IGJlIGluaXRpYWxpemVkIChwYXRoIGJsb2NrZWQpLgAAAAAAABBOb3RJbml0aWFsaXphYmxlAAAAAAAAAY9TZXRzIFRUTCBjb25maWdzIGZvciBpbnN0YW5jZSBhbmQgcGVyc2lzdGVudCBzdG9yYWdlLgoKLSBgTm9uZWAgdmFsdWVzIHJlbW92ZSB0aGUgY29ycmVzcG9uZGluZyBjb25maWcgKGRpc2FibGVzIGF1dG8tZXh0ZW5zaW9uIGZvciB0aGF0IHR5cGUpCi0gVmFsaWRhdGVzIHRoYXQgYHRocmVzaG9sZCA8PSBleHRlbmRfdG8gPD0gTUFYX1RUTGAKCiMgQXJndW1lbnRzCi0gYGluc3RhbmNlYCAtIFRUTCBjb25maWcgZm9yIGluc3RhbmNlIHN0b3JhZ2UKLSBgcGVyc2lzdGVudGAgLSBUVEwgY29uZmlnIGZvciBwZXJzaXN0ZW50IHN0b3JhZ2UKCiMgUGFuaWNzCi0gYFR0bENvbmZpZ0Zyb3plbmAgaWYgY29uZmlncyBhcmUgZnJvemVuCi0gYEludmFsaWRUdGxDb25maWdgIGlmIHZhbGlkYXRpb24gZmFpbHMAAAAAD3NldF90dGxfY29uZmlncwAAAAACAAAAAAAAAAhpbnN0YW5jZQAAA+gAAAfQAAAACVR0bENvbmZpZwAAAAAAAAAAAAAKcGVyc2lzdGVudAAAAAAD6AAAB9AAAAAJVHRsQ29uZmlnAAAAAAAAAAAAAAAAAABIUmV0dXJucyB0aGUgY3VycmVudCBUVEwgY29uZmlncyBhcyAoaW5zdGFuY2VfY29uZmlnLCBwZXJzaXN0ZW50X2NvbmZpZykuAAAAC3R0bF9jb25maWdzAAAAAAAAAAABAAAD7QAAAAIAAAPoAAAH0AAAAAlUdGxDb25maWcAAAAAAAPoAAAH0AAAAAlUdGxDb25maWcAAAAAAAAAAAAA4VBlcm1hbmVudGx5IGZyZWV6ZXMgVFRMIGNvbmZpZ3MsIHByZXZlbnRpbmcgYW55IGZ1dHVyZSBtb2RpZmljYXRpb25zLgoKVGhpcyBpcyBpcnJldmVyc2libGUgYW5kIHByb3ZpZGVzIGltbXV0YWJpbGl0eSBndWFyYW50ZWVzIHRvIHVzZXJzLgpFbWl0cyBgVHRsQ29uZmlnc0Zyb3plbmAgZXZlbnQuCgojIFBhbmljcwotIGBUdGxDb25maWdBbHJlYWR5RnJvemVuYCBpZiBhbHJlYWR5IGZyb3plbgAAAAAAABJmcmVlemVfdHRsX2NvbmZpZ3MAAAAAAAAAAAAAAAAAAAAAACdSZXR1cm5zIHdoZXRoZXIgVFRMIGNvbmZpZ3MgYXJlIGZyb3plbi4AAAAAFWlzX3R0bF9jb25maWdzX2Zyb3plbgAAAAAAAAAAAAABAAAAAQAAAAAAAAClRXh0ZW5kcyB0aGUgaW5zdGFuY2UgVFRMLgoKIyBBcmd1bWVudHMKCiogYHRocmVzaG9sZGAgLSBUaGUgdGhyZXNob2xkIHRvIGV4dGVuZCB0aGUgVFRMIChpZiBjdXJyZW50IFRUTCBpcyBiZWxvdyB0aGlzLCBleHRlbmQpLgoqIGBleHRlbmRfdG9gIC0gVGhlIFRUTCB0byBleHRlbmQgdG8uAAAAAAAAE2V4dGVuZF9pbnN0YW5jZV90dGwAAAAAAgAAAAAAAAAJdGhyZXNob2xkAAAAAAAABAAAAAAAAAAJZXh0ZW5kX3RvAAAAAAAABAAAAAAAAAAAAAAAPlJldHVybnMgdGhlIGN1cnJlbnQgb3duZXIgYWRkcmVzcywgb3IgTm9uZSBpZiBubyBvd25lciBpcyBzZXQuAAAAAAAFb3duZXIAAAAAAAAAAAAAAQAAA+gAAAATAAAAAAAAAFlSZXR1cm5zIHRoZSBwZW5kaW5nIG93bmVyIGFkZHJlc3MgZm9yIDItc3RlcCB0cmFuc2Zlciwgb3IgTm9uZSBpZiBubyB0cmFuc2ZlciBpcyBwZW5kaW5nLgAAAAAAAA1wZW5kaW5nX293bmVyAAAAAAAAAAAAAAEAAAPoAAAAEwAAAAAAAAErVHJhbnNmZXJzIG93bmVyc2hpcCBpbW1lZGlhdGVseSB0byBhIG5ldyBhZGRyZXNzLgoKVXNlIHdpdGggY2F1dGlvbiAtIGlmIHlvdSB0cmFuc2ZlciB0byBhIHdyb25nIGFkZHJlc3MsIG93bmVyc2hpcCBpcyBsb3N0IGZvcmV2ZXIuCkNvbnNpZGVyIHVzaW5nIGBwcm9wb3NlX293bmVyc2hpcF90cmFuc2ZlcmAgaW5zdGVhZC4KCiMgUGFuaWNzCi0gYE93bmVyTm90U2V0YCBpZiBubyBvd25lciBpcyBjdXJyZW50bHkgc2V0Ci0gYFRyYW5zZmVySW5Qcm9ncmVzc2AgaWYgYSAyLXN0ZXAgdHJhbnNmZXIgaXMgaW4gcHJvZ3Jlc3MAAAAAEnRyYW5zZmVyX293bmVyc2hpcAAAAAAAAQAAAAAAAAAJbmV3X293bmVyAAAAAAAAEwAAAAAAAAAAAAACXFByb3Bvc2VzIGFuIG93bmVyc2hpcCB0cmFuc2ZlciB0byBhIG5ldyBhZGRyZXNzLgoKVGhlIG5ldyBvd25lciBtdXN0IGNhbGwgYGFjY2VwdF9vd25lcnNoaXAoKWAgd2l0aGluIGB0dGxgIGxlZGdlcnMKdG8gY29tcGxldGUgdGhlIHRyYW5zZmVyLiBUaGUgcGVuZGluZyB0cmFuc2ZlciB3aWxsIGF1dG9tYXRpY2FsbHkgZXhwaXJlIGFmdGVyLgoKIyBBcmd1bWVudHMKLSBgbmV3X293bmVyYCAtIFRoZSBwcm9wb3NlZCBuZXcgb3duZXIKLSBgdHRsYCAtIE51bWJlciBvZiBsZWRnZXJzIHRoZSBuZXcgb3duZXIgaGFzIHRvIGFjY2VwdC4KVXNlIGAwYCB0byBjYW5jZWwgYSBwZW5kaW5nIHRyYW5zZmVyIChuZXdfb3duZXIgbXVzdCBtYXRjaCBwZW5kaW5nKS4KCiMgUGFuaWNzCi0gYE93bmVyTm90U2V0YCBpZiBubyBvd25lciBpcyBjdXJyZW50bHkgc2V0Ci0gYE5vUGVuZGluZ1RyYW5zZmVyYCB3aGVuIGNhbmNlbGxpbmcgYW5kIG5vIHBlbmRpbmcgdHJhbnNmZXIgZXhpc3RzCi0gYEludmFsaWRUdGxgIGlmIHR0bCBleGNlZWRzIG1heCBUVEwKLSBgSW52YWxpZFBlbmRpbmdPd25lcmAgd2hlbiBjYW5jZWxsaW5nIHdpdGggd3JvbmcgbmV3X293bmVyIGFkZHJlc3MAAAAacHJvcG9zZV9vd25lcnNoaXBfdHJhbnNmZXIAAAAAAAIAAAAAAAAACW5ld19vd25lcgAAAAAAABMAAAAAAAAAA3R0bAAAAAAEAAAAAAAAAAAAAAC5QWNjZXB0cyBhIHBlbmRpbmcgMi1zdGVwIG93bmVyc2hpcCB0cmFuc2Zlci4KCk11c3QgYmUgY2FsbGVkIGJ5IHRoZSBwZW5kaW5nIG93bmVyIGJlZm9yZSB0aGUgVFRMIGV4cGlyZXMuCgojIFBhbmljcwotIGBOb1BlbmRpbmdUcmFuc2ZlcmAgaWYgdGhlcmUgaXMgbm8gcGVuZGluZyB0cmFuc2ZlciAob3IgaXQgZXhwaXJlZCkAAAAAAAAQYWNjZXB0X293bmVyc2hpcAAAAAAAAAAAAAAAAAAAAKRQZXJtYW5lbnRseSByZW5vdW5jZXMgb3duZXJzaGlwLgoKIyBQYW5pY3MKLSBgT3duZXJOb3RTZXRgIGlmIG5vIG93bmVyIGlzIGN1cnJlbnRseSBzZXQKLSBgVHJhbnNmZXJJblByb2dyZXNzYCBpZiBhIDItc3RlcCB0cmFuc2ZlciBpcyBpbiBwcm9ncmVzcyAoY2FuY2VsIGl0IGZpcnN0KQAAABJyZW5vdW5jZV9vd25lcnNoaXAAAAAAAAAAAAAAAAAAAAAAAJVUaGUgdHlwZSBvZiBkYXRhIHJlcXVpcmVkIGZvciBtaWdyYXRpb24uClVwZ3JhZGVzIHRoZSBjb250cmFjdCB0byBuZXcgV0FTTSBieXRlY29kZS4KU2V0cyBhIG1pZ3JhdGlvbiBmbGFnIHRoYXQgbXVzdCBiZSBjbGVhcmVkIGJ5IGNhbGxpbmcgYG1pZ3JhdGVgLgAAAAAAAAd1cGdyYWRlAAAAAAEAAAAAAAAADW5ld193YXNtX2hhc2gAAAAAAAPuAAAAIAAAAAAAAAAAAAAAdlJ1bnMgbWlncmF0aW9uIGxvZ2ljIGFmdGVyIGFuIHVwZ3JhZGUuCkNhbiBvbmx5IGJlIGNhbGxlZCB3aGVuIHRoZSBtaWdyYXRpb24gZmxhZyBpcyBzZXQgYnkgYSBwcmV2aW91cyBgdXBncmFkZWAgY2FsbC4AAAAAAAdtaWdyYXRlAAAAAAEAAAAAAAAADm1pZ3JhdGlvbl9kYXRhAAAAAAAOAAAAAAAAAAAAAABeUGVybWFuZW50bHkgZnJlZXplcyB0aGUgY29udHJhY3QsIHByZXZlbnRpbmcgYW55IGZ1dHVyZSB1cGdyYWRlcy4KVGhpcyBhY3Rpb24gaXMgaXJyZXZlcnNpYmxlLgAAAAAABmZyZWV6ZQAAAAAAAAAAAAAAAAAAAAAAO1JldHVybnMgd2hldGhlciB0aGUgY29udHJhY3QgaXMgZnJvemVuICh1cGdyYWRlcyBkaXNhYmxlZCkuAAAAAAlpc19mcm96ZW4AAAAAAAAAAAAAAQAAAAEAAAAEAAAAAAAAAAAAAAANRW5kcG9pbnRFcnJvcgAAAAAAABkAAAAAAAAAEUFscmVhZHlSZWdpc3RlcmVkAAAAAAAAAQAAAAAAAAANQ29tcG9zZUV4aXN0cwAAAAAAAAIAAAAAAAAAD0NvbXBvc2VOb3RGb3VuZAAAAAADAAAAAAAAABxEZWZhdWx0UmVjZWl2ZUxpYlVuYXZhaWxhYmxlAAAABAAAAAAAAAAZRGVm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cmFfZGF0YQAAAAAADgAAAAAAAAAAAAAABnJlYXNvbgAAAAAADgAAAAAAAAACAAAAAQAAAC1QYXJhbWV0ZXJzIGZvciBzZW5kaW5nIGEgY3Jvc3MtY2hhaW4gbWVzc2FnZS4AAAAAAAAAAAAAD01lc3NhZ2luZ1BhcmFtcwAAAAAFAAAAK0Rlc3RpbmF0aW9uIGVuZHBvaW50IElEIChjaGFpbiBpZGVudGlmaWVyKS4AAAAAB2RzdF9laWQAAAAABAAAABxUaGUgbWVzc2FnZSBwYXlsb2FkIHRvIHNlbmQuAAAAB21lc3NhZ2UAAAAADgAAACFFbmNvZGVkIGV4ZWN1dG9yIGFuZCBEVk4gb3B0aW9ucy4AAAAAAAAHb3B0aW9ucwAAAAAOAAAAOVdoZXRoZXIgdG8gcGF5IGZlZXMgaW4gWlJPIHRva2VuIGluc3RlYWQgb2YgbmF0aXZlIHRva2VuLgAAAAAAAApwYXlfaW5fenJvAAAAAAABAAAANVJlY2VpdmVyIGFkZHJlc3Mgb24gdGhlIGRlc3RpbmF0aW9uIGNoYWluICgzMiBieXRlcykuAAAAAAAACHJlY2VpdmVyAAAD7gAAACAAAAABAAAATVNvdXJjZSBtZXNzYWdlIGluZm9ybWF0aW9uIGlkZW50aWZ5aW5nIHdoZXJlIGEgY3Jvc3MtY2hhaW4gbWVzc2FnZSBjYW1lIGZyb20uAAAAAAAAAAAAAAZPcmlnaW4AAAAAAAMAAAAXTm9uY2UgZm9yIHRoaXMgcGF0aHdheS4AAAAABW5vbmNlAAAAAAAABgAAAC5TZW5kZXIgYWRkcmVzcyBvbiB0aGUgc291cmNlIGNoYWluICgzMiBieXRlcykuAAAAAAAGc2VuZGVyAAAAAAPuAAAAIAAAACZTb3VyY2UgZW5kcG9pbnQgSUQgKGNoYWluIGlkZW50aWZpZXIpLgAAAAAAB3NyY19laWQAAAAABAAAAAEAAAAoRmVlIHN0cnVjdHVyZSBmb3IgY3Jvc3MtY2hhaW4gbWVzc2FnaW5nLgAAAAAAAAAMTWVzc2FnaW5nRmVlAAAAAgAAAB9GZWUgcGFpZCBpbiBuYXRpdmUgdG9rZW4gKFhMTSkuAAAAAApuYXRpdmVfZmVlAAAAAAALAAAAKEZlZSBwYWlkIGluIFpSTyB0b2tlbiAoTGF5ZXJaZXJvIHRva2VuKS4AAAAHenJvX2ZlZQAAAAALAAAAAQAAAEJSZWNlaXB0IHJldHVybmVkIGFmdGVyIHN1Y2Nlc3NmdWxseSBzZW5kaW5nIGEgY3Jvc3MtY2hhaW4gbWVzc2FnZS4AAAAAAAAAAAAQTWVzc2FnaW5nUmVjZWlwdAAAAAMAAAApVGhlIGZlZXMgY2hhcmdlZCBmb3Igc2VuZGluZyB0aGUgbWVzc2FnZS4AAAAAAAADZmVlAAAAB9AAAAAMTWVzc2FnaW5nRmVlAAAAK0dsb2JhbGx5IHVuaXF1ZSBpZGVudGlmaWVyIGZvciB0aGUgbWVzc2FnZS4AAAAABGd1aWQAAAPuAAAAIAAAACRUaGUgb3V0Ym91bmQgbm9uY2UgZm9yIHRoaXMgcGF0aHdheS4AAAAFbm9uY2UAAAAAAAAGAAAAAgAAADhUeXBlIG9mIG1lc3NhZ2UgbGlicmFyeSBpbmRpY2F0aW5nIHN1cHBvcnRlZCBvcGVyYXRpb25zLgAAAAAAAAAOTWVzc2FnZUxpYlR5cGUAAAAAAAMAAAAAAAAAH1N1cHBvcnRzIG9ubHkgc2VuZGluZyBtZXNzYWdlcy4AAAAABFNlbmQAAAAAAAAAIVN1cHBvcnRzIG9ubHkgcmVjZWl2aW5nIG1lc3NhZ2VzLgAAAAAAAAdSZWNlaXZlAAAAAAAAAAAtU3VwcG9ydHMgYm90aCBzZW5kaW5nIGFuZCByZWNlaXZpbmcgbWVzc2FnZXMuAAAAAAAADlNlbmRBbmRSZWNlaXZlAAAAAAABAAAAt1ZlcnNpb24gaW5mb3JtYXRpb24gZm9yIGEgbWVzc2FnZSBsaWJyYXJ5LgoKTm90ZTogYG1pbm9yYCBhbmQgYGVuZHBvaW50X3ZlcnNpb25gIHVzZSBgdTMyYCBpbnN0ZWFkIG9mIGB1OGAgYmVjYXVzZSBTdGVsbGFyIGRvZXMgbm90CnN1cHBvcnQgYHU4YCB0eXBlcyBpbiBjb250cmFjdCBpbnRlcmZhY2UgZnVuY3Rpb25zLgAAAAAAAAAAEU1lc3NhZ2VMaWJWZXJzaW9uAAAAAAAAAwAAADNFbmRwb2ludCB2ZXJzaW9uIChzaG91bGQgbm90IGV4Y2VlZCB1ODo6TUFYID0gMjU1KS4AAAAAEGVuZHBvaW50X3ZlcnNpb24AAAAEAAAAFU1ham9yIHZlcnNpb24gbnVtYmVyLgAAAAAAAAVtYWpvcgAAAAAAAAYAAAA3TWlub3IgdmVyc2lvbiBudW1iZXIgKHNob3VsZCBub3QgZXhjZWVkIHU4OjpNQVggPSAyNTUpLgAAAAAFbWlub3IAAAAAAAAEAAAAAQAAADZUaW1lb3V0IGNvbmZpZ3VyYXRpb24gZm9yIHJlY2VpdmUgbGlicmFyeSB0cmFuc2l0aW9ucy4AAAAAAAAAAAAHVGltZW91dAAAAAACAAAAKFVuaXggdGltZXN0YW1wIHdoZW4gdGhlIHRpbWVvdXQgZXhwaXJlcy4AAAAGZXhwaXJ5AAAAAAAGAAAAKVRoZSBuZXcgbGlicmFyeSBhZGRyZXNzIHRvIHRyYW5zaXRpb24gdG8uAAAAAAAAA2xpYgAAAAATAAAAAQAAADVQYXJhbWV0ZXJzIGZvciBzZXR0aW5nIG1lc3NhZ2UgbGlicmFyeSBjb25maWd1cmF0aW9uLgAAAAAAAAAAAAAOU2V0Q29uZmlnUGFyYW0AAAAAAAMAAAAfWERSLWVuY29kZWQgY29uZmlndXJhdGlvbiBkYXRhLgAAAAAGY29uZmlnAAAAAAAOAAAAMFRoZSB0eXBlIG9mIGNvbmZpZ3VyYXRpb24gKGUuZy4sIGV4ZWN1dG9yLCBVTE4pLgAAAAtjb25maWdfdHlwZQAAAAAEAAAAJ1RoZSBlbmRwb2ludCBJRCB0aGlzIGNvbmZpZyBhcHBsaWVzIHRvLgAAAAADZWlkAAAAAAQAAAABAAAAMVJlc29sdmVkIGxpYnJhcnkgaW5mb3JtYXRpb24gd2l0aCBkZWZhdWx0IHN0YXR1cy4AAAAAAAAAAAAAD1Jlc29sdmVkTGlicmFyeQAAAAACAAAARFdoZXRoZXIgdGhpcyBpcyB0aGUgZGVmYXVsdCBsaWJyYXJ5ICh0cnVlKSBvciBPQXBwLXNwZWNpZmljIChmYWxzZSkuAAAACmlzX2RlZmF1bHQAAAAAAAEAAAAdVGhlIHJlc29sdmVkIGxpYnJhcnkgYWRkcmVzcy4AAAAAAAADbGliAAAAABMAAAABAAAASE91dGJvdW5kIHBhY2tldCBjb250YWluaW5nIGFsbCBpbmZvcm1hdGlvbiBmb3IgY3Jvc3MtY2hhaW4gdHJhbnNtaXNzaW9uLgAAAAAAAAAOT3V0Ym91bmRQYWNrZXQAAAAAAAcAAAAYRGVzdGluYXRpb24gZW5kcG9pbnQgSUQuAAAAB2RzdF9laWQAAAAABAAAACxHbG9iYWxseSB1bmlxdWUgaWRlbnRpZmllciBmb3IgdGhpcyBtZXNzYWdlLgAAAARndWlkAAAD7gAAACAAAAAUVGhlIG1lc3NhZ2UgcGF5bG9hZC4AAAAHbWVzc2FnZQAAAAAOAAAAIE91dGJvdW5kIG5vbmNlIGZvciB0aGlzIHBhdGh3YXkuAAAABW5vbmNlAAAAAAAABgAAADFSZWNlaXZlciBhZGRyZXNzIG9uIGRlc3RpbmF0aW9uIGNoYWluICgzMiBieXRlcykuAAAAAAAACHJlY2VpdmVyAAAD7gAAACAAAAAfU2VuZGVyIGFkZHJlc3Mgb24gc291cmNlIGNoYWluLgAAAAAGc2VuZGVyAAAAAAATAAAAE1NvdXJjZSBlbmRwb2ludCBJRC4AAAAAB3NyY19laWQAAAAABAAAAAEAAAArQSBmZWUgcmVjaXBpZW50IHdpdGggdGhlIGFtb3VudCB0byBiZSBwYWlkLgAAAAAAAAAADEZlZVJlY2lwaWVudAAAAAIAAAAVQW1vdW50IG9mIGZlZSB0byBwYXkuAAAAAAAABmFtb3VudAAAAAAACwAAAB9UaGUgYWRkcmVzcyB0byBzZW5kIHRoZSBmZWUgdG8uAAAAAAJ0bwAAAAAAEwAAAAEAAAA8UmVzdWx0IG9mIHNlbmQgb3BlcmF0aW9uIGNvbnRhaW5pbmcgZmVlcyBhbmQgZW5jb2RlZCBwYWNrZXQuAAAAAAAAAA1GZWVzQW5kUGFja2V0AAAAAAAAAwAAACpUaGUgZW5jb2RlZCBwYWNrZXQgcmVhZHkgZm9yIHRyYW5zbWlzc2lvbi4AAAAAAA5lbmNvZGVkX3BhY2tldAAAAAAADgAAAD9MaXN0IG9mIG5hdGl2ZSB0b2tlbiBmZWUgcmVjaXBpZW50cyAoZXhlY3V0b3IsIERWTnMsIHRyZWFzdXJ5KS4AAAAAFW5hdGl2ZV9mZWVfcmVjaXBpZW50cwAAAAAAA+oAAAfQAAAADEZlZVJlY2lwaWVudAAAACxMaXN0IG9mIFpSTyB0b2tlbiBmZWUgcmVjaXBpZW50cyAodHJlYXN1cnkpLgAAABJ6cm9fZmVlX3JlY2lwaWVudHMAAAAAA+oAAAfQAAAADEZlZVJlY2lwaWVudAAAAAQAAAAdUGFja2V0Q29kZWNWMUVycm9yOiAxMTAwLTExMDkAAAAAAAAAAAAAElBhY2tldENvZGVjVjFFcnJvcgAAAAAAAgAAAAAAAAATSW52YWxpZFBhY2tldEhlYWRlcgAAAARMAAAAAAAAABRJbnZhbGlkUGFja2V0VmVyc2lvbgAABE0AAAAEAAAAHVdvcmtlck9wdGlvbnNFcnJvcjogMTExMC0xMTE5AAAAAAAAAAAAABJXb3JrZXJPcHRpb25zRXJyb3IAAAAAAAkAAAAAAAAAEkludmFsaWRCeXRlc0xlbmd0aAAAAAAEVgAAAAAAAAAZSW52YWxpZExlZ2FjeU9wdGlvbnNUeXBlMQAAAAAABFcAAAAAAAAAGUludmFsaWRMZWdhY3lPcHRpb25zVHlwZTIAAAAAAARYAAAAAAAAABFJbnZhbGlkT3B0aW9uVHlwZQAAAAAABFkAAAAAAAAADkludmFsaWRPcHRpb25zAAAAAARaAAAAAAAAAA9JbnZhbGlkV29ya2VySWQAAAAEWwAAAAAAAAAdTGVnYWN5T3B0aW9uc1R5cGUxR2FzT3ZlcmZsb3cAAAAAAARcAAAAAAAAACBMZWdhY3lPcHRpb25zVHlwZTJBbW91bnRPdmVyZmxvdwAABF0AAAAAAAAAHUxlZ2FjeU9wdGlvbnNUeXBlMkdhc092ZXJmbG93AAAAAAAEXgAAAAQAAAAAAAAAAAAAAAtVbG4zMDJFcnJvcgAAAAATAAAAAAAAAB1EZWZhdWx0RXhlY3V0b3JDb25maWdOb3RGb3VuZAAAAAAAAAEAAAAAAAAAH0RlZmF1bHRSZWNlaXZlVWxuQ29uZmlnTm90Rm91bmQAAAAAAgAAAAAAAAAcRGVmYXVsdFNlbmRVbG5Db25maWdOb3RGb3VuZAAAAAMAAAAAAAAAFUR1cGxpY2F0ZU9wdGlvbmFsRFZOcwAAAAAAAAQAAAAAAAAAFUR1cGxpY2F0ZVJlcXVpcmVkRFZOcwAAAAAAAAUAAAAAAAAADUludmFsaWRDb25maWcAAAAAAAAGAAAAAAAAABFJbnZhbGlkQ29uZmlnVHlwZQAAAAAAAAcAAAAAAAAAFEludmFsaWRDb25maXJtYXRpb25zAAAACAAAAAAAAAAKSW52YWxpZEVJRAAAAAAACQAAAAAAAAASSW52YWxpZE1lc3NhZ2VTaXplAAAAAAAKAAAAAAAAABdJbnZhbGlkT3B0aW9uYWxEVk5Db3VudAAAAAALAAAAAAAAABNJbnZhbGlkT3B0aW9uYWxEVk5zAAAAAAwAAAAAAAAAG0ludmFsaWRPcHRpb25hbERWTlRocmVzaG9sZAAAAAANAAAAAAAAABdJbnZhbGlkUmVxdWlyZWREVk5Db3VudAAAAAAOAAAAAAAAABNJbnZhbGlkUmVxdWlyZWREVk5zAAAAAA8AAAAAAAAAEFVsbkF0TGVhc3RPbmVEVk4AAAAQAAAAAAAAAA5VbnN1cHBvcnRlZEVpZAAAAAAAEQAAAAAAAAAJVmVyaWZ5aW5nAAAAAAAAEgAAAAAAAAAPWmVyb01lc3NhZ2VTaXplAAAAABMAAAAFAAAAAAAAAAAAAAARRXhlY3V0b3JDb25maWdTZXQAAAAAAAABAAAAE2V4ZWN1dG9yX2NvbmZpZ19zZXQAAAAAAwAAAAAAAAAGc2VuZGVyAAAAAAATAAAAAQAAAAAAAAAHZHN0X2VpZAAAAAAEAAAAAQAAAAAAAAAGY29uZmlnAAAAAAfQAAAAEk9BcHBFeGVjdXRvckNvbmZpZwAAAAAAAAAAAAIAAAAFAAAAAAAAAAAAAAAQU2VuZFVsbkNvbmZpZ1NldAAAAAEAAAATc2VuZF91bG5fY29uZmlnX3NldAAAAAADAAAAAAAAAAZzZW5kZXIAAAAAABMAAAABAAAAAAAAAAdkc3RfZWlkAAAAAAQAAAABAAAAAAAAAAZjb25maWcAAAAAB9AAAAANT0FwcFVsbkNvbmZpZwAAAAAAAAAAAAACAAAABQAAAAAAAAAAAAAAE1JlY2VpdmVVbG5Db25maWdTZXQAAAAAAQAAABZyZWNlaXZlX3Vsbl9jb25maWdfc2V0AAAAAAADAAAAAAAAAAhyZWNlaXZlcgAAABMAAAABAAAAAAAAAAdzcmNfZWlkAAAAAAQAAAABAAAAAAAAAAZjb25maWcAAAAAB9AAAAANT0FwcFVsbkNvbmZpZwAAAAAAAAAAAAACAAAABQAAAAAAAAAAAAAAGURlZmF1bHRFeGVjdXRvckNvbmZpZ3NTZXQAAAAAAAABAAAAHGRlZmF1bHRfZXhlY3V0b3JfY29uZmlnc19zZXQAAAABAAAAAAAAAAZwYXJhbXMAAAAAA+oAAAfQAAAAHVNldERlZmF1bHRFeGVjdXRvckNvbmZpZ1BhcmFtAAAAAAAAAAAAAAIAAAAFAAAAAAAAAAAAAAAYRGVmYXVsdFNlbmRVbG5Db25maWdzU2V0AAAAAQAAABxkZWZhdWx0X3NlbmRfdWxuX2NvbmZpZ3Nfc2V0AAAAAQAAAAAAAAAGcGFyYW1zAAAAAAPqAAAH0AAAABhTZXREZWZhdWx0VWxuQ29uZmlnUGFyYW0AAAAAAAAAAgAAAAUAAAAAAAAAAAAAABtEZWZhdWx0UmVjZWl2ZVVsbkNvbmZpZ3NTZXQAAAAAAQAAAB9kZWZhdWx0X3JlY2VpdmVfdWxuX2NvbmZpZ3Nfc2V0AAAAAAEAAAAAAAAABnBhcmFtcwAAAAAD6gAAB9AAAAAYU2V0RGVmYXVsdFVsbkNvbmZpZ1BhcmFtAAAAAAAAAAIAAAAFAAAAAAAAAAAAAAAPRXhlY3V0b3JGZWVQYWlkAAAAAAEAAAARZXhlY3V0b3JfZmVlX3BhaWQAAAAAAAADAAAAAAAAAAhleGVjdXRvcgAAABMAAAABAAAAAAAAAARndWlkAAAD7gAAACAAAAABAAAAAAAAAANmZWUAAAAH0AAAAAxGZWVSZWNpcGllbnQAAAAAAAAAAgAAAAUAAAAAAAAAAAAAAApEVk5GZWVQYWlkAAAAAAABAAAADGR2bl9mZWVfcGFpZAAAAAMAAAAAAAAABGd1aWQAAAPuAAAAIAAAAAEAAAAAAAAABGR2bnMAAAPqAAAAEwAAAAAAAAAAAAAABGZlZXMAAAPqAAAH0AAAAAxGZWVSZWNpcGllbnQAAAAAAAAAAgAAAAUAAAAAAAAAAAAAAA9QYXlsb2FkVmVyaWZpZWQAAAAAAQAAABBwYXlsb2FkX3ZlcmlmaWVkAAAABAAAAAAAAAADZHZuAAAAABMAAAABAAAAAAAAAAZoZWFkZXIAAAAAAA4AAAAAAAAAAAAAAA1jb25maXJtYXRpb25zAAAAAAAABgAAAAAAAAAAAAAACnByb29mX2hhc2gAAAAAA+4AAAAgAAAAAAAAAAIAAAABAAAAOFVsdHJhIExpZ2h0IE5vZGUgY29uZmlndXJhdGlvbiBmb3IgbWVzc2FnZSB2ZXJpZmljYXRpb24uAAAAAAAAAAlVbG5Db25maWcAAAAAAAAEAAAASk51bWJlciBvZiBibG9jayBjb25maXJtYXRpb25zIHJlcXVpcmVkIGJlZm9yZSBtZXNzYWdlIHZlcmlmaWNhdGlvbiBiZWdpbnMuAAAAAAANY29uZmlybWF0aW9ucwAAAAAAAAYAAAAzTWluaW11bSBudW1iZXIgb2Ygb3B0aW9uYWwgRFZOcyByZXF1aXJlZCB0byB2ZXJpZnkuAAAAABZvcHRpb25hbF9kdm5fdGhyZXNob2xkAAAAAAAEAAAAQExpc3Qgb2YgRFZOIGFkZHJlc3NlcyBmcm9tIHdoaWNoIGEgdGhyZXNob2xkIG51bWJlciBtdXN0IHZlcmlmeS4AAAANb3B0aW9uYWxfZHZucwAAAAAAA+oAAAATAAAARkxpc3Qgb2YgRFZOIGFkZHJlc3NlcyB0aGF0IG11c3QgQUxMIHZlcmlmeSB0aGUgbWVzc2FnZSAobm8gdGhyZXNob2xkKS4AAAAAAA1yZXF1aXJlZF9kdm5zAAAAAAAD6gAAABMAAAABAAAAPE9BcHAtc3BlY2lmaWMgVUxOIGNvbmZpZ3VyYXRpb24gd2l0aCBkZWZhdWx0IG92ZXJyaWRlIGZsYWdzLgAAAAAAAAANT0FwcFVsbkNvbmZpZwAAAAAAAAQAAABFT0FwcC1zcGVjaWZpYyBVTE4gY29uZmlndXJhdGlvbiAodXNlZCB3aGVuIGRlZmF1bHRzIGFyZSBub3QgYXBwbGllZCkuAAAAAAAACnVsbl9jb25maWcAAAAAB9AAAAAJVWxuQ29uZmlnAAAAAAAAJVdoZXRoZXIgdG8gdXNlIGRlZmF1bHQgY29uZmlybWF0aW9ucy4AAAAAAAAZdXNlX2RlZmF1bHRfY29uZmlybWF0aW9ucwAAAAAAAAEAAAAlV2hldGhlciB0byB1c2UgZGVmYXVsdCBvcHRpb25hbCBEVk5zLgAAAAAAABl1c2VfZGVmYXVsdF9vcHRpb25hbF9kdm5zAAAAAAAAAQAAACVXaGV0aGVyIHRvIHVzZSBkZWZhdWx0IHJlcXVpcmVkIERWTnMuAAAAAAAAGXVzZV9kZWZhdWx0X3JlcXVpcmVkX2R2bnMAAAAAAAABAAAAAQAAAFJQYXJhbWV0ZXIgZm9yIHNldHRpbmcgZGVmYXVsdCBVTE4gY29uZmlndXJhdGlvbiBmb3IgYSBkZXN0aW5hdGlvbi9zb3VyY2UgZW5kcG9pbnQuAAAAAAAAAAAAGFNldERlZmF1bHRVbG5Db25maWdQYXJhbQAAAAIAAAAoVGhlIFVMTiBjb25maWd1cmF0aW9uIHRvIHNldCBhcyBkZWZhdWx0LgAAAAZjb25maWcAAAAAB9AAAAAJVWxuQ29uZmlnAAAAAAAAS1RoZSBkZXN0aW5hdGlvbiBlbmRwb2ludCBJRCAoZm9yIHNlbmQpIG9yIHNvdXJjZSBlbmRwb2ludCBJRCAoZm9yIHJlY2VpdmUpLgAAAAADZWlkAAAAAAQAAAABAAAALEV4ZWN1dG9yIGNvbmZpZ3VyYXRpb24gZm9yIG1lc3NhZ2UgZGVsaXZlcnkuAAAAAAAAAA5FeGVjdXRvckNvbmZpZwAAAAAAAgAAAENBZGRyZXNzIG9mIHRoZSBleGVjdXRvciBjb250cmFjdCByZXNwb25zaWJsZSBmb3IgbWVzc2FnZSBleGVjdXRpb24uAAAAAAhleGVjdXRvcgAAABMAAAA5TWF4aW11bSBzaXplIG9mIG1lc3NhZ2VzIHRoYXQgY2FuIGJlIGV4ZWN1dGVkIChpbiBieXRlcykuAAAAAAAAEG1heF9tZXNzYWdlX3NpemUAAAAEAAAAAQAAAFtPQXBwLXNwZWNpZmljIGV4ZWN1dG9yIGNvbmZpZ3VyYXRpb24uCgpJZiBleGVjdXRvciBpcyBgTm9uZWAsIHRoZSBkZWZhdWx0IGV4ZWN1dG9yIGlzIHVzZWQuAAAAAAAAAAAST0FwcEV4ZWN1dG9yQ29uZmlnAAAAAAACAAAAaEFkZHJlc3Mgb2YgdGhlIGV4ZWN1dG9yIGNvbnRyYWN0IHRvIGJlIHVzZWQgZm9yIG1lc3NhZ2UgZXhlY3V0aW9uLiBOb25lIG1lYW5zIHVzZSBkZWZhdWx0IGNvbmZpZ3VyYXRpb24uAAAACGV4ZWN1dG9yAAAD6AAAABMAAABcTWF4aW11bSBzaXplIG9mIG1lc3NhZ2VzIHRoYXQgY2FuIGJlIGV4ZWN1dGVkIChpbiBieXRlcykuIDAgbWVhbnMgdXNlIGRlZmF1bHQgY29uZmlndXJhdGlvbi4AAAAQbWF4X21lc3NhZ2Vfc2l6ZQAAAAQAAAABAAAAUFBhcmFtZXRlciBmb3Igc2V0dGluZyBkZWZhdWx0IGV4ZWN1dG9yIGNvbmZpZ3VyYXRpb24gZm9yIGEgZGVzdGluYXRpb24gZW5kcG9pbnQuAAAAAAAAAB1TZXREZWZhdWx0RXhlY3V0b3JDb25maWdQYXJhbQAAAAAAAAIAAAAtVGhlIGV4ZWN1dG9yIGNvbmZpZ3VyYXRpb24gdG8gc2V0IGFzIGRlZmF1bHQuAAAAAAAABmNvbmZpZwAAAAAH0AAAAA5FeGVjdXRvckNvbmZpZwAAAAAAHFRoZSBkZXN0aW5hdGlvbiBlbmRwb2ludCBJRC4AAAAHZHN0X2VpZAAAAAAEAAAABAAAABxCdWZmZXJSZWFkZXJFcnJvcjogMTAwMC0xMDA5AAAAAAAAABFCdWZmZXJSZWFkZXJFcnJvcgAAAAAAAAIAAAAAAAAADUludmFsaWRMZW5ndGgAAAAAAAPoAAAAAAAAABVJbnZhbGlkQWRkcmVzc1BheWxvYWQAAAAAAAPpAAAABAAAABxCdWZmZXJXcml0ZXJFcnJvcjogMTAxMC0xMDE5AAAAAAAAABFCdWZmZXJXcml0ZXJFcnJvcgAAAAAAAAEAAAAAAAAAFUludmFsaWRBZGRyZXNzUGF5bG9hZAAAAAAAA/IAAAAEAAAAH1R0bENvbmZpZ3VyYWJsZUVycm9yOiAxMDIwLTEwMjkAAAAAAAAAABRUdGxDb25maWd1cmFibGVFcnJvcgAAAAMAAAAAAAAAEEludmFsaWRUdGxDb25maWcAAAP8AAAAAAAAAA9UdGxDb25maWdGcm96ZW4AAAAD/QAAAAAAAAAWVHRsQ29uZmlnQWxyZWFkeUZyb3plbgAAAAAD/gAAAAQAAAAXT3duYWJsZUVycm9yOiAxMDMwLTEwMzkAAAAAAAAAAAxPd25hYmxlRXJyb3IAAAAGAAAAAAAAABNJbnZhbGlkUGVuZGluZ093bmVyAAAABAYAAAAAAAAACkludmFsaWRUdGwAAAAABAcAAAAAAAAAEU5vUGVuZGluZ1RyYW5zZmVyAAAAAAAECAAAAAAAAAAPT3duZXJBbHJlYWR5U2V0AAAABAkAAAAAAAAAC093bmVyTm90U2V0AAAABAoAAAAAAAAAElRyYW5zZmVySW5Qcm9ncmVzcwAAAAAECwAAAAQAAAAYQnl0ZXNFeHRFcnJvcjogMTA0MC0xMDQ5AAAAAAAAAA1CeXRlc0V4dEVycm9yAAAAAAAAAQAAAAAAAAAOTGVuZ3RoTWlzbWF0Y2gAAAAABBAAAAAEAAAAG1VwZ3JhZGVhYmxlRXJyb3I6IDEwNTAtMTA1OQAAAAAAAAAAEFVwZ3JhZGVhYmxlRXJyb3IAAAADAAAAAAAAABRJbnZhbGlkTWlncmF0aW9uRGF0YQAABBoAAAAAAAAAE01pZ3JhdGlvbk5vdEFsbG93ZWQAAAAEGwAAAAAAAAAOVXBncmFkZXNGcm96ZW4AAAAABBwAAAAEAAAAGE11bHRpc2lnRXJyb3I6IDEwNjAtMTA2OQAAAAAAAAANTXVsdGlzaWdFcnJvcgAAAAAAAAgAAAAAAAAAEkFscmVhZHlJbml0aWFsaXplZAAAAAAEJAAAAAAAAAANSW52YWxpZFNpZ25lcgAAAAAABCUAAAAAAAAADlNpZ25hdHVyZUVycm9yAAAAAAQmAAAAAAAAABNTaWduZXJBbHJlYWR5RXhpc3RzAAAABCcAAAAAAAAADlNpZ25lck5vdEZvdW5kAAAAAAQoAAAAAAAAAB1Ub3RhbFNpZ25lcnNMZXNzVGhhblRocmVzaG9sZAAAAAAABCkAAAAAAAAAD1Vuc29ydGVkU2lnbmVycwAAAAQqAAAAAAAAAA1aZXJvVGhyZXNob2xkAAAAAAAEKwAAAAUAAAAwRXZlbnQgZW1pdHRlZCB3aGVuIGEgc2lnbmVyIGlzIGFkZGVkIG9yIHJlbW92ZWQuAAAAAAAAAAlTaWduZXJTZXQAAAAAAAABAAAACnNpZ25lcl9zZXQAAAAAAAIAAAAAAAAABnNpZ25lcgAAAAAD7gAAABQAAAABAAAAAAAAAAZhY3RpdmUAAAAAAAEAAAAAAAAAAgAAAAUAAAA2RXZlbnQgZW1pdHRlZCB3aGVuIHRoZSBzaWduYXR1cmUgdGhyZXNob2xkIGlzIGNoYW5nZWQuAAAAAAAAAAAADFRocmVzaG9sZFNldAAAAAEAAAANdGhyZXNob2xkX3NldAAAAAAAAAEAAAAAAAAACXRocmVzaG9sZAAAAAAAAAQAAAAAAAAAAgAAAAIAAAAAAAAAAAAAAA9NdWx0aXNpZ1N0b3JhZ2UAAAAAAgAAAAAAAAAAAAAAB1NpZ25lcnMAAAAAAAAAAAAAAAAJVGhyZXNob2xkAAAAAAAABQAAAFdFdmVudCBlbWl0dGVkIHdoZW4gb3duZXJzaGlwIGlzIHRyYW5zZmVycmVkIChib3RoIHNpbmdsZS1zdGVwIGFuZCB0d28tc3RlcCBjb21wbGV0aW9uKS4AAAAAAAAAABRPd25lcnNoaXBUcmFuc2ZlcnJlZAAAAAEAAAAVb3duZXJzaGlwX3RyYW5zZmVycmVkAAAAAAAAAgAAAAAAAAAJb2xkX293bmVyAAAAAAAAEwAAAAAAAAAAAAAACW5ld19vd25lcgAAAAAAABMAAAAAAAAAAgAAAAUAAAA7RXZlbnQgZW1pdHRlZCB3aGVuIGEgMi1zdGVwIG93bmVyc2hpcCB0cmFuc2ZlciBpcyBwcm9wb3NlZC4AAAAAAAAAABVPd25lcnNoaXBUcmFuc2ZlcnJpbmcAAAAAAAABAAAAFm93bmVyc2hpcF90cmFuc2ZlcnJpbmcAAAAAAAMAAAAAAAAACW9sZF9vd25lcgAAAAAAABMAAAAAAAAAAAAAAAluZXdfb3duZXIAAAAAAAATAAAAAAAAAAAAAAADdHRsAAAAAAQAAAAAAAAAAgAAAAUAAAAqRXZlbnQgZW1pdHRlZCB3aGVuIG93bmVyc2hpcCBpcyByZW5vdW5jZWQuAAAAAAAAAAAAEk93bmVyc2hpcFJlbm91bmNlZAAAAAAAAQAAABNvd25lcnNoaXBfcmVub3VuY2VkAAAAAAEAAAAAAAAACW9sZF9vd25lcgAAAAAAABMAAAAAAAAAAgAAAAIAAAAAAAAAAAAAAA5Pd25hYmxlU3RvcmFnZQAAAAAAAgAAAAAAAAAAAAAABU93bmVyAAAAAAAAAAAAAAAAAAAMUGVuZGluZ093bmVyAAAAAQAAAElUVEwgY29uZmlndXJhdGlvbjogdGhyZXNob2xkICh3aGVuIHRvIGV4dGVuZCkgYW5kIGV4dGVuZF90byAodGFyZ2V0IFRUTCkuAAAAAAAAAAAAAAlUdGxDb25maWcAAAAAAAACAAAAKFRhcmdldCBUVEwgYWZ0ZXIgZXh0ZW5zaW9uIChpbiBsZWRnZXJzKS4AAAAJZXh0ZW5kX3RvAAAAAAAABAAAADNUVEwgdGhyZXNob2xkIHRoYXQgdHJpZ2dlcnMgZXh0ZW5zaW9uIChpbiBsZWRnZXJzKS4AAAAACXRocmVzaG9sZAAAAAAAAAQAAAAFAAAAJ0V2ZW50IGVtaXR0ZWQgd2hlbiBUVEwgY29uZmlncyBhcmUgc2V0LgAAAAAAAAAADVR0bENvbmZpZ3NTZXQAAAAAAAABAAAAD3R0bF9jb25maWdzX3NldAAAAAACAAAAAAAAAAhpbnN0YW5jZQAAA+gAAAfQAAAACVR0bENvbmZpZwAAAAAAAAAAAAAAAAAACnBlcnNpc3RlbnQAAAAAA+gAAAfQAAAACVR0bENvbmZpZwAAAAAAAAAAAAACAAAABQAAACpFdmVudCBlbWl0dGVkIHdoZW4gVFRMIGNvbmZpZ3MgYXJlIGZyb3plbi4AAAAAAAAAAAAQVHRsQ29uZmlnc0Zyb3plbgAAAAEAAAASdHRsX2NvbmZpZ3NfZnJvemVuAAAAAAAAAAAAAgAAAAIAAAAAAAAAAAAAABBUdGxDb25maWdTdG9yYWdlAAAAAwAAAAAAAAAAAAAABkZyb3plbgAAAAAAAAAAAAAAAAAISW5zdGFuY2UAAAAAAAAAAAAAAApQZXJzaXN0ZW50AAAAAAACAAAAAAAAAAAAAAASVXBncmFkZWFibGVTdG9yYWdlAAAAAAACAAAAAAAAAAAAAAAGRnJvemVuAAAAAAAAAAAAAAAAAAlNaWdyYXRpbmcAAAAAiwEOY29udHJhY3RtZXRhdjAAAAAAAAAABmJpbnZlcgAAAAAABTAuMC4xAAAAAAAAAAAAAAVyc3ZlcgAAAAAAAAYxLjkwLjAAAAAAAAAAAAAIcnNzZGt2ZXIAAAAvMjMuNC4wIzY3M2Q2YzRmMjM2OGQyODJkMjVkYTI5YmRhNTVjMjFiOGJlNjljYTYAAB4RY29udHJhY3RlbnZtZXRhdjAAAAAAAAAAFwAAAAA=";
12
+ /**
13
+ * Pre-computed WASM hash (SHA-256)
14
+ * Use this when the WASM is already uploaded on-chain
15
+ */
16
+ export declare const WASM_HASH = "246b8137f2eeccf75191b9fc9862067103af6569599e9bf3df5aa8b8612498dc";
17
+ /**
18
+ * Get the WASM bytecode as a Buffer
19
+ * Use this to upload the WASM to the network
20
+ */
21
+ export declare function getWasmBuffer(): Buffer;
22
+ /**
23
+ * Errors for LayerZeroView contract.
24
+ */
25
+ export declare const LayerZeroViewError: {
26
+ /**
27
+ * Invalid packet header (dst_eid mismatch).
28
+ */
29
+ 1: {
30
+ message: string;
31
+ };
32
+ };
33
+ export type LayerZeroViewStorage = {
34
+ tag: "Endpoint";
35
+ values: void;
36
+ } | {
37
+ tag: "Uln302";
38
+ values: void;
39
+ } | {
40
+ tag: "LocalEid";
41
+ values: void;
42
+ };
43
+ /**
44
+ * Represents the execution state of a cross-chain message.
45
+ *
46
+ * Used by executors to determine when a message is ready to be delivered.
47
+ */
48
+ export type ExecutionState = {
49
+ tag: "NotExecutable";
50
+ values: void;
51
+ } | {
52
+ tag: "VerifiedButNotExecutable";
53
+ values: void;
54
+ } | {
55
+ tag: "Executable";
56
+ values: void;
57
+ } | {
58
+ tag: "Executed";
59
+ values: void;
60
+ };
61
+ /**
62
+ * Represents the verification state of a cross-chain message at the ULN level.
63
+ *
64
+ * Used by DVNs and executors to track verification progress.
65
+ */
66
+ export type VerificationState = {
67
+ tag: "Verifying";
68
+ values: void;
69
+ } | {
70
+ tag: "Verifiable";
71
+ values: void;
72
+ } | {
73
+ tag: "Verified";
74
+ values: void;
75
+ } | {
76
+ tag: "NotInitializable";
77
+ values: void;
78
+ };
79
+ export declare const EndpointError: {
80
+ 1: {
81
+ message: string;
82
+ };
83
+ 2: {
84
+ message: string;
85
+ };
86
+ 3: {
87
+ message: string;
88
+ };
89
+ 4: {
90
+ message: string;
91
+ };
92
+ 5: {
93
+ message: string;
94
+ };
95
+ 6: {
96
+ message: string;
97
+ };
98
+ 7: {
99
+ message: string;
100
+ };
101
+ 8: {
102
+ message: string;
103
+ };
104
+ 9: {
105
+ message: string;
106
+ };
107
+ 10: {
108
+ message: string;
109
+ };
110
+ 11: {
111
+ message: string;
112
+ };
113
+ 12: {
114
+ message: string;
115
+ };
116
+ 13: {
117
+ message: string;
118
+ };
119
+ 14: {
120
+ message: string;
121
+ };
122
+ 15: {
123
+ message: string;
124
+ };
125
+ 16: {
126
+ message: string;
127
+ };
128
+ 17: {
129
+ message: string;
130
+ };
131
+ 18: {
132
+ message: string;
133
+ };
134
+ 19: {
135
+ message: string;
136
+ };
137
+ 20: {
138
+ message: string;
139
+ };
140
+ 21: {
141
+ message: string;
142
+ };
143
+ 22: {
144
+ message: string;
145
+ };
146
+ 23: {
147
+ message: string;
148
+ };
149
+ 24: {
150
+ message: string;
151
+ };
152
+ 25: {
153
+ message: string;
154
+ };
155
+ };
156
+ /**
157
+ * Parameters for sending a cross-chain message.
158
+ */
159
+ export interface MessagingParams {
160
+ /**
161
+ * Destination endpoint ID (chain identifier).
162
+ */
163
+ dst_eid: u32;
164
+ /**
165
+ * The message payload to send.
166
+ */
167
+ message: Buffer;
168
+ /**
169
+ * Encoded executor and DVN options.
170
+ */
171
+ options: Buffer;
172
+ /**
173
+ * Whether to pay fees in ZRO token instead of native token.
174
+ */
175
+ pay_in_zro: boolean;
176
+ /**
177
+ * Receiver address on the destination chain (32 bytes).
178
+ */
179
+ receiver: Buffer;
180
+ }
181
+ /**
182
+ * Source message information identifying where a cross-chain message came from.
183
+ */
184
+ export interface Origin {
185
+ /**
186
+ * Nonce for this pathway.
187
+ */
188
+ nonce: u64;
189
+ /**
190
+ * Sender address on the source chain (32 bytes).
191
+ */
192
+ sender: Buffer;
193
+ /**
194
+ * Source endpoint ID (chain identifier).
195
+ */
196
+ src_eid: u32;
197
+ }
198
+ /**
199
+ * Fee structure for cross-chain messaging.
200
+ */
201
+ export interface MessagingFee {
202
+ /**
203
+ * Fee paid in native token (XLM).
204
+ */
205
+ native_fee: i128;
206
+ /**
207
+ * Fee paid in ZRO token (LayerZero token).
208
+ */
209
+ zro_fee: i128;
210
+ }
211
+ /**
212
+ * Receipt returned after successfully sending a cross-chain message.
213
+ */
214
+ export interface MessagingReceipt {
215
+ /**
216
+ * The fees charged for sending the message.
217
+ */
218
+ fee: MessagingFee;
219
+ /**
220
+ * Globally unique identifier for the message.
221
+ */
222
+ guid: Buffer;
223
+ /**
224
+ * The outbound nonce for this pathway.
225
+ */
226
+ nonce: u64;
227
+ }
228
+ /**
229
+ * Type of message library indicating supported operations.
230
+ */
231
+ export type MessageLibType = {
232
+ tag: "Send";
233
+ values: void;
234
+ } | {
235
+ tag: "Receive";
236
+ values: void;
237
+ } | {
238
+ tag: "SendAndReceive";
239
+ values: void;
240
+ };
241
+ /**
242
+ * Version information for a message library.
243
+ *
244
+ * Note: `minor` and `endpoint_version` use `u32` instead of `u8` because Stellar does not
245
+ * support `u8` types in contract interface functions.
246
+ */
247
+ export interface MessageLibVersion {
248
+ /**
249
+ * Endpoint version (should not exceed u8::MAX = 255).
250
+ */
251
+ endpoint_version: u32;
252
+ /**
253
+ * Major version number.
254
+ */
255
+ major: u64;
256
+ /**
257
+ * Minor version number (should not exceed u8::MAX = 255).
258
+ */
259
+ minor: u32;
260
+ }
261
+ /**
262
+ * Timeout configuration for receive library transitions.
263
+ */
264
+ export interface Timeout {
265
+ /**
266
+ * Unix timestamp when the timeout expires.
267
+ */
268
+ expiry: u64;
269
+ /**
270
+ * The new library address to transition to.
271
+ */
272
+ lib: string;
273
+ }
274
+ /**
275
+ * Parameters for setting message library configuration.
276
+ */
277
+ export interface SetConfigParam {
278
+ /**
279
+ * XDR-encoded configuration data.
280
+ */
281
+ config: Buffer;
282
+ /**
283
+ * The type of configuration (e.g., executor, ULN).
284
+ */
285
+ config_type: u32;
286
+ /**
287
+ * The endpoint ID this config applies to.
288
+ */
289
+ eid: u32;
290
+ }
291
+ /**
292
+ * Resolved library information with default status.
293
+ */
294
+ export interface ResolvedLibrary {
295
+ /**
296
+ * Whether this is the default library (true) or OApp-specific (false).
297
+ */
298
+ is_default: boolean;
299
+ /**
300
+ * The resolved library address.
301
+ */
302
+ lib: string;
303
+ }
304
+ /**
305
+ * Outbound packet containing all information for cross-chain transmission.
306
+ */
307
+ export interface OutboundPacket {
308
+ /**
309
+ * Destination endpoint ID.
310
+ */
311
+ dst_eid: u32;
312
+ /**
313
+ * Globally unique identifier for this message.
314
+ */
315
+ guid: Buffer;
316
+ /**
317
+ * The message payload.
318
+ */
319
+ message: Buffer;
320
+ /**
321
+ * Outbound nonce for this pathway.
322
+ */
323
+ nonce: u64;
324
+ /**
325
+ * Receiver address on destination chain (32 bytes).
326
+ */
327
+ receiver: Buffer;
328
+ /**
329
+ * Sender address on source chain.
330
+ */
331
+ sender: string;
332
+ /**
333
+ * Source endpoint ID.
334
+ */
335
+ src_eid: u32;
336
+ }
337
+ /**
338
+ * A fee recipient with the amount to be paid.
339
+ */
340
+ export interface FeeRecipient {
341
+ /**
342
+ * Amount of fee to pay.
343
+ */
344
+ amount: i128;
345
+ /**
346
+ * The address to send the fee to.
347
+ */
348
+ to: string;
349
+ }
350
+ /**
351
+ * Result of send operation containing fees and encoded packet.
352
+ */
353
+ export interface FeesAndPacket {
354
+ /**
355
+ * The encoded packet ready for transmission.
356
+ */
357
+ encoded_packet: Buffer;
358
+ /**
359
+ * List of native token fee recipients (executor, DVNs, treasury).
360
+ */
361
+ native_fee_recipients: Array<FeeRecipient>;
362
+ /**
363
+ * List of ZRO token fee recipients (treasury).
364
+ */
365
+ zro_fee_recipients: Array<FeeRecipient>;
366
+ }
367
+ /**
368
+ * PacketCodecV1Error: 1100-1109
369
+ */
370
+ export declare const PacketCodecV1Error: {
371
+ 1100: {
372
+ message: string;
373
+ };
374
+ 1101: {
375
+ message: string;
376
+ };
377
+ };
378
+ /**
379
+ * WorkerOptionsError: 1110-1119
380
+ */
381
+ export declare const WorkerOptionsError: {
382
+ 1110: {
383
+ message: string;
384
+ };
385
+ 1111: {
386
+ message: string;
387
+ };
388
+ 1112: {
389
+ message: string;
390
+ };
391
+ 1113: {
392
+ message: string;
393
+ };
394
+ 1114: {
395
+ message: string;
396
+ };
397
+ 1115: {
398
+ message: string;
399
+ };
400
+ 1116: {
401
+ message: string;
402
+ };
403
+ 1117: {
404
+ message: string;
405
+ };
406
+ 1118: {
407
+ message: string;
408
+ };
409
+ };
410
+ export declare const Uln302Error: {
411
+ 1: {
412
+ message: string;
413
+ };
414
+ 2: {
415
+ message: string;
416
+ };
417
+ 3: {
418
+ message: string;
419
+ };
420
+ 4: {
421
+ message: string;
422
+ };
423
+ 5: {
424
+ message: string;
425
+ };
426
+ 6: {
427
+ message: string;
428
+ };
429
+ 7: {
430
+ message: string;
431
+ };
432
+ 8: {
433
+ message: string;
434
+ };
435
+ 9: {
436
+ message: string;
437
+ };
438
+ 10: {
439
+ message: string;
440
+ };
441
+ 11: {
442
+ message: string;
443
+ };
444
+ 12: {
445
+ message: string;
446
+ };
447
+ 13: {
448
+ message: string;
449
+ };
450
+ 14: {
451
+ message: string;
452
+ };
453
+ 15: {
454
+ message: string;
455
+ };
456
+ 16: {
457
+ message: string;
458
+ };
459
+ 17: {
460
+ message: string;
461
+ };
462
+ 18: {
463
+ message: string;
464
+ };
465
+ 19: {
466
+ message: string;
467
+ };
468
+ };
469
+ /**
470
+ * Ultra Light Node configuration for message verification.
471
+ */
472
+ export interface UlnConfig {
473
+ /**
474
+ * Number of block confirmations required before message verification begins.
475
+ */
476
+ confirmations: u64;
477
+ /**
478
+ * Minimum number of optional DVNs required to verify.
479
+ */
480
+ optional_dvn_threshold: u32;
481
+ /**
482
+ * List of DVN addresses from which a threshold number must verify.
483
+ */
484
+ optional_dvns: Array<string>;
485
+ /**
486
+ * List of DVN addresses that must ALL verify the message (no threshold).
487
+ */
488
+ required_dvns: Array<string>;
489
+ }
490
+ /**
491
+ * OApp-specific ULN configuration with default override flags.
492
+ */
493
+ export interface OAppUlnConfig {
494
+ /**
495
+ * OApp-specific ULN configuration (used when defaults are not applied).
496
+ */
497
+ uln_config: UlnConfig;
498
+ /**
499
+ * Whether to use default confirmations.
500
+ */
501
+ use_default_confirmations: boolean;
502
+ /**
503
+ * Whether to use default optional DVNs.
504
+ */
505
+ use_default_optional_dvns: boolean;
506
+ /**
507
+ * Whether to use default required DVNs.
508
+ */
509
+ use_default_required_dvns: boolean;
510
+ }
511
+ /**
512
+ * Parameter for setting default ULN configuration for a destination/source endpoint.
513
+ */
514
+ export interface SetDefaultUlnConfigParam {
515
+ /**
516
+ * The ULN configuration to set as default.
517
+ */
518
+ config: UlnConfig;
519
+ /**
520
+ * The destination endpoint ID (for send) or source endpoint ID (for receive).
521
+ */
522
+ eid: u32;
523
+ }
524
+ /**
525
+ * Executor configuration for message delivery.
526
+ */
527
+ export interface ExecutorConfig {
528
+ /**
529
+ * Address of the executor contract responsible for message execution.
530
+ */
531
+ executor: string;
532
+ /**
533
+ * Maximum size of messages that can be executed (in bytes).
534
+ */
535
+ max_message_size: u32;
536
+ }
537
+ /**
538
+ * OApp-specific executor configuration.
539
+ *
540
+ * If executor is `None`, the default executor is used.
541
+ */
542
+ export interface OAppExecutorConfig {
543
+ /**
544
+ * Address of the executor contract to be used for message execution. None means use default configuration.
545
+ */
546
+ executor: Option<string>;
547
+ /**
548
+ * Maximum size of messages that can be executed (in bytes). 0 means use default configuration.
549
+ */
550
+ max_message_size: u32;
551
+ }
552
+ /**
553
+ * Parameter for setting default executor configuration for a destination endpoint.
554
+ */
555
+ export interface SetDefaultExecutorConfigParam {
556
+ /**
557
+ * The executor configuration to set as default.
558
+ */
559
+ config: ExecutorConfig;
560
+ /**
561
+ * The destination endpoint ID.
562
+ */
563
+ dst_eid: u32;
564
+ }
565
+ /**
566
+ * BufferReaderError: 1000-1009
567
+ */
568
+ export declare const BufferReaderError: {
569
+ 1000: {
570
+ message: string;
571
+ };
572
+ 1001: {
573
+ message: string;
574
+ };
575
+ };
576
+ /**
577
+ * BufferWriterError: 1010-1019
578
+ */
579
+ export declare const BufferWriterError: {
580
+ 1010: {
581
+ message: string;
582
+ };
583
+ };
584
+ /**
585
+ * TtlConfigurableError: 1020-1029
586
+ */
587
+ export declare const TtlConfigurableError: {
588
+ 1020: {
589
+ message: string;
590
+ };
591
+ 1021: {
592
+ message: string;
593
+ };
594
+ 1022: {
595
+ message: string;
596
+ };
597
+ };
598
+ /**
599
+ * OwnableError: 1030-1039
600
+ */
601
+ export declare const OwnableError: {
602
+ 1030: {
603
+ message: string;
604
+ };
605
+ 1031: {
606
+ message: string;
607
+ };
608
+ 1032: {
609
+ message: string;
610
+ };
611
+ 1033: {
612
+ message: string;
613
+ };
614
+ 1034: {
615
+ message: string;
616
+ };
617
+ 1035: {
618
+ message: string;
619
+ };
620
+ };
621
+ /**
622
+ * BytesExtError: 1040-1049
623
+ */
624
+ export declare const BytesExtError: {
625
+ 1040: {
626
+ message: string;
627
+ };
628
+ };
629
+ /**
630
+ * UpgradeableError: 1050-1059
631
+ */
632
+ export declare const UpgradeableError: {
633
+ 1050: {
634
+ message: string;
635
+ };
636
+ 1051: {
637
+ message: string;
638
+ };
639
+ 1052: {
640
+ message: string;
641
+ };
642
+ };
643
+ /**
644
+ * MultisigError: 1060-1069
645
+ */
646
+ export declare const MultisigError: {
647
+ 1060: {
648
+ message: string;
649
+ };
650
+ 1061: {
651
+ message: string;
652
+ };
653
+ 1062: {
654
+ message: string;
655
+ };
656
+ 1063: {
657
+ message: string;
658
+ };
659
+ 1064: {
660
+ message: string;
661
+ };
662
+ 1065: {
663
+ message: string;
664
+ };
665
+ 1066: {
666
+ message: string;
667
+ };
668
+ 1067: {
669
+ message: string;
670
+ };
671
+ };
672
+ export type MultisigStorage = {
673
+ tag: "Signers";
674
+ values: void;
675
+ } | {
676
+ tag: "Threshold";
677
+ values: void;
678
+ };
679
+ export type OwnableStorage = {
680
+ tag: "Owner";
681
+ values: void;
682
+ } | {
683
+ tag: "PendingOwner";
684
+ values: void;
685
+ };
686
+ /**
687
+ * TTL configuration: threshold (when to extend) and extend_to (target TTL).
688
+ */
689
+ export interface TtlConfig {
690
+ /**
691
+ * Target TTL after extension (in ledgers).
692
+ */
693
+ extend_to: u32;
694
+ /**
695
+ * TTL threshold that triggers extension (in ledgers).
696
+ */
697
+ threshold: u32;
698
+ }
699
+ export type TtlConfigStorage = {
700
+ tag: "Frozen";
701
+ values: void;
702
+ } | {
703
+ tag: "Instance";
704
+ values: void;
705
+ } | {
706
+ tag: "Persistent";
707
+ values: void;
708
+ };
709
+ export type UpgradeableStorage = {
710
+ tag: "Frozen";
711
+ values: void;
712
+ } | {
713
+ tag: "Migrating";
714
+ values: void;
715
+ };
716
+ export interface Client {
717
+ /**
718
+ * 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.
719
+ */
720
+ authorizer: (txnOptions?: {
721
+ /**
722
+ * The fee to pay for the transaction. Default: BASE_FEE
723
+ */
724
+ fee?: number;
725
+ /**
726
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
727
+ */
728
+ timeoutInSeconds?: number;
729
+ /**
730
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
731
+ */
732
+ simulate?: boolean;
733
+ }) => Promise<AssembledTransaction<string>>;
734
+ /**
735
+ * Construct and simulate a endpoint 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.
736
+ * Returns the endpoint address.
737
+ */
738
+ endpoint: (txnOptions?: {
739
+ /**
740
+ * The fee to pay for the transaction. Default: BASE_FEE
741
+ */
742
+ fee?: number;
743
+ /**
744
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
745
+ */
746
+ timeoutInSeconds?: number;
747
+ /**
748
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
749
+ */
750
+ simulate?: boolean;
751
+ }) => Promise<AssembledTransaction<string>>;
752
+ /**
753
+ * Construct and simulate a uln302 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.
754
+ * Returns the Uln302 address.
755
+ */
756
+ uln302: (txnOptions?: {
757
+ /**
758
+ * The fee to pay for the transaction. Default: BASE_FEE
759
+ */
760
+ fee?: number;
761
+ /**
762
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
763
+ */
764
+ timeoutInSeconds?: number;
765
+ /**
766
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
767
+ */
768
+ simulate?: boolean;
769
+ }) => Promise<AssembledTransaction<string>>;
770
+ /**
771
+ * Construct and simulate a local_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.
772
+ * Returns the local endpoint ID.
773
+ */
774
+ local_eid: (txnOptions?: {
775
+ /**
776
+ * The fee to pay for the transaction. Default: BASE_FEE
777
+ */
778
+ fee?: number;
779
+ /**
780
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
781
+ */
782
+ timeoutInSeconds?: number;
783
+ /**
784
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
785
+ */
786
+ simulate?: boolean;
787
+ }) => Promise<AssembledTransaction<u32>>;
788
+ /**
789
+ * Construct and simulate a initializable 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.
790
+ * Checks if a messaging path can be initialized for the given origin and receiver.
791
+ */
792
+ initializable: ({ origin, receiver }: {
793
+ origin: Origin;
794
+ receiver: string;
795
+ }, txnOptions?: {
796
+ /**
797
+ * The fee to pay for the transaction. Default: BASE_FEE
798
+ */
799
+ fee?: number;
800
+ /**
801
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
802
+ */
803
+ timeoutInSeconds?: number;
804
+ /**
805
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
806
+ */
807
+ simulate?: boolean;
808
+ }) => Promise<AssembledTransaction<boolean>>;
809
+ /**
810
+ * Construct and simulate a verifiable 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.
811
+ * Checks if a message can be verified at the endpoint.
812
+ *
813
+ * Verifies:
814
+ * 1. Receive library is valid for this receiver and source
815
+ * 2. Endpoint nonce check passes
816
+ * 3. Payload hash is not empty
817
+ */
818
+ verifiable: ({ origin, receiver, receive_lib, payload_hash }: {
819
+ origin: Origin;
820
+ receiver: string;
821
+ receive_lib: string;
822
+ payload_hash: Buffer;
823
+ }, txnOptions?: {
824
+ /**
825
+ * The fee to pay for the transaction. Default: BASE_FEE
826
+ */
827
+ fee?: number;
828
+ /**
829
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
830
+ */
831
+ timeoutInSeconds?: number;
832
+ /**
833
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
834
+ */
835
+ simulate?: boolean;
836
+ }) => Promise<AssembledTransaction<boolean>>;
837
+ /**
838
+ * Construct and simulate a executable 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.
839
+ * Returns the execution state of a message.
840
+ */
841
+ executable: ({ origin, receiver }: {
842
+ origin: Origin;
843
+ receiver: string;
844
+ }, txnOptions?: {
845
+ /**
846
+ * The fee to pay for the transaction. Default: BASE_FEE
847
+ */
848
+ fee?: number;
849
+ /**
850
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
851
+ */
852
+ timeoutInSeconds?: number;
853
+ /**
854
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
855
+ */
856
+ simulate?: boolean;
857
+ }) => Promise<AssembledTransaction<ExecutionState>>;
858
+ /**
859
+ * Construct and simulate a uln_verifiable 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.
860
+ * Returns the combined verification state of a message.
861
+ *
862
+ * This function checks:
863
+ * 1. Packet header validity (dst_eid matches local_eid)
864
+ * 2. Endpoint initializable status
865
+ * 3. Endpoint verifiable status
866
+ * 4. ULN verifiable status (DVN confirmations)
867
+ */
868
+ uln_verifiable: ({ packet_header, payload_hash }: {
869
+ packet_header: Buffer;
870
+ payload_hash: Buffer;
871
+ }, txnOptions?: {
872
+ /**
873
+ * The fee to pay for the transaction. Default: BASE_FEE
874
+ */
875
+ fee?: number;
876
+ /**
877
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
878
+ */
879
+ timeoutInSeconds?: number;
880
+ /**
881
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
882
+ */
883
+ simulate?: boolean;
884
+ }) => Promise<AssembledTransaction<VerificationState>>;
885
+ /**
886
+ * 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.
887
+ * Sets TTL configs for instance and persistent storage.
888
+ *
889
+ * - `None` values remove the corresponding config (disables auto-extension for that type)
890
+ * - Validates that `threshold <= extend_to <= MAX_TTL`
891
+ *
892
+ * # Arguments
893
+ * - `instance` - TTL config for instance storage
894
+ * - `persistent` - TTL config for persistent storage
895
+ *
896
+ * # Panics
897
+ * - `TtlConfigFrozen` if configs are frozen
898
+ * - `InvalidTtlConfig` if validation fails
899
+ */
900
+ set_ttl_configs: ({ instance, persistent }: {
901
+ instance: Option<TtlConfig>;
902
+ persistent: Option<TtlConfig>;
903
+ }, txnOptions?: {
904
+ /**
905
+ * The fee to pay for the transaction. Default: BASE_FEE
906
+ */
907
+ fee?: number;
908
+ /**
909
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
910
+ */
911
+ timeoutInSeconds?: number;
912
+ /**
913
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
914
+ */
915
+ simulate?: boolean;
916
+ }) => Promise<AssembledTransaction<null>>;
917
+ /**
918
+ * 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.
919
+ * Returns the current TTL configs as (instance_config, persistent_config).
920
+ */
921
+ ttl_configs: (txnOptions?: {
922
+ /**
923
+ * The fee to pay for the transaction. Default: BASE_FEE
924
+ */
925
+ fee?: number;
926
+ /**
927
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
928
+ */
929
+ timeoutInSeconds?: number;
930
+ /**
931
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
932
+ */
933
+ simulate?: boolean;
934
+ }) => Promise<AssembledTransaction<readonly [Option<TtlConfig>, Option<TtlConfig>]>>;
935
+ /**
936
+ * 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.
937
+ * Permanently freezes TTL configs, preventing any future modifications.
938
+ *
939
+ * This is irreversible and provides immutability guarantees to users.
940
+ * Emits `TtlConfigsFrozen` event.
941
+ *
942
+ * # Panics
943
+ * - `TtlConfigAlreadyFrozen` if already frozen
944
+ */
945
+ freeze_ttl_configs: (txnOptions?: {
946
+ /**
947
+ * The fee to pay for the transaction. Default: BASE_FEE
948
+ */
949
+ fee?: number;
950
+ /**
951
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
952
+ */
953
+ timeoutInSeconds?: number;
954
+ /**
955
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
956
+ */
957
+ simulate?: boolean;
958
+ }) => Promise<AssembledTransaction<null>>;
959
+ /**
960
+ * 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.
961
+ * Returns whether TTL configs are frozen.
962
+ */
963
+ is_ttl_configs_frozen: (txnOptions?: {
964
+ /**
965
+ * The fee to pay for the transaction. Default: BASE_FEE
966
+ */
967
+ fee?: number;
968
+ /**
969
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
970
+ */
971
+ timeoutInSeconds?: number;
972
+ /**
973
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
974
+ */
975
+ simulate?: boolean;
976
+ }) => Promise<AssembledTransaction<boolean>>;
977
+ /**
978
+ * 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.
979
+ * Extends the instance TTL.
980
+ *
981
+ * # Arguments
982
+ *
983
+ * * `threshold` - The threshold to extend the TTL (if current TTL is below this, extend).
984
+ * * `extend_to` - The TTL to extend to.
985
+ */
986
+ extend_instance_ttl: ({ threshold, extend_to }: {
987
+ threshold: u32;
988
+ extend_to: u32;
989
+ }, txnOptions?: {
990
+ /**
991
+ * The fee to pay for the transaction. Default: BASE_FEE
992
+ */
993
+ fee?: number;
994
+ /**
995
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
996
+ */
997
+ timeoutInSeconds?: number;
998
+ /**
999
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1000
+ */
1001
+ simulate?: boolean;
1002
+ }) => Promise<AssembledTransaction<null>>;
1003
+ /**
1004
+ * 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.
1005
+ * Returns the current owner address, or None if no owner is set.
1006
+ */
1007
+ owner: (txnOptions?: {
1008
+ /**
1009
+ * The fee to pay for the transaction. Default: BASE_FEE
1010
+ */
1011
+ fee?: number;
1012
+ /**
1013
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1014
+ */
1015
+ timeoutInSeconds?: number;
1016
+ /**
1017
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1018
+ */
1019
+ simulate?: boolean;
1020
+ }) => Promise<AssembledTransaction<Option<string>>>;
1021
+ /**
1022
+ * 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.
1023
+ * Returns the pending owner address for 2-step transfer, or None if no transfer is pending.
1024
+ */
1025
+ pending_owner: (txnOptions?: {
1026
+ /**
1027
+ * The fee to pay for the transaction. Default: BASE_FEE
1028
+ */
1029
+ fee?: number;
1030
+ /**
1031
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1032
+ */
1033
+ timeoutInSeconds?: number;
1034
+ /**
1035
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1036
+ */
1037
+ simulate?: boolean;
1038
+ }) => Promise<AssembledTransaction<Option<string>>>;
1039
+ /**
1040
+ * 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.
1041
+ * Transfers ownership immediately to a new address.
1042
+ *
1043
+ * Use with caution - if you transfer to a wrong address, ownership is lost forever.
1044
+ * Consider using `propose_ownership_transfer` instead.
1045
+ *
1046
+ * # Panics
1047
+ * - `OwnerNotSet` if no owner is currently set
1048
+ * - `TransferInProgress` if a 2-step transfer is in progress
1049
+ */
1050
+ transfer_ownership: ({ new_owner }: {
1051
+ new_owner: string;
1052
+ }, txnOptions?: {
1053
+ /**
1054
+ * The fee to pay for the transaction. Default: BASE_FEE
1055
+ */
1056
+ fee?: number;
1057
+ /**
1058
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1059
+ */
1060
+ timeoutInSeconds?: number;
1061
+ /**
1062
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1063
+ */
1064
+ simulate?: boolean;
1065
+ }) => Promise<AssembledTransaction<null>>;
1066
+ /**
1067
+ * 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.
1068
+ * Proposes an ownership transfer to a new address.
1069
+ *
1070
+ * The new owner must call `accept_ownership()` within `ttl` ledgers
1071
+ * to complete the transfer. The pending transfer will automatically expire after.
1072
+ *
1073
+ * # Arguments
1074
+ * - `new_owner` - The proposed new owner
1075
+ * - `ttl` - Number of ledgers the new owner has to accept.
1076
+ * Use `0` to cancel a pending transfer (new_owner must match pending).
1077
+ *
1078
+ * # Panics
1079
+ * - `OwnerNotSet` if no owner is currently set
1080
+ * - `NoPendingTransfer` when cancelling and no pending transfer exists
1081
+ * - `InvalidTtl` if ttl exceeds max TTL
1082
+ * - `InvalidPendingOwner` when cancelling with wrong new_owner address
1083
+ */
1084
+ propose_ownership_transfer: ({ new_owner, ttl }: {
1085
+ new_owner: string;
1086
+ ttl: u32;
1087
+ }, txnOptions?: {
1088
+ /**
1089
+ * The fee to pay for the transaction. Default: BASE_FEE
1090
+ */
1091
+ fee?: number;
1092
+ /**
1093
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1094
+ */
1095
+ timeoutInSeconds?: number;
1096
+ /**
1097
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1098
+ */
1099
+ simulate?: boolean;
1100
+ }) => Promise<AssembledTransaction<null>>;
1101
+ /**
1102
+ * 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.
1103
+ * Accepts a pending 2-step ownership transfer.
1104
+ *
1105
+ * Must be called by the pending owner before the TTL expires.
1106
+ *
1107
+ * # Panics
1108
+ * - `NoPendingTransfer` if there is no pending transfer (or it expired)
1109
+ */
1110
+ accept_ownership: (txnOptions?: {
1111
+ /**
1112
+ * The fee to pay for the transaction. Default: BASE_FEE
1113
+ */
1114
+ fee?: number;
1115
+ /**
1116
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1117
+ */
1118
+ timeoutInSeconds?: number;
1119
+ /**
1120
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1121
+ */
1122
+ simulate?: boolean;
1123
+ }) => Promise<AssembledTransaction<null>>;
1124
+ /**
1125
+ * 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.
1126
+ * Permanently renounces ownership.
1127
+ *
1128
+ * # Panics
1129
+ * - `OwnerNotSet` if no owner is currently set
1130
+ * - `TransferInProgress` if a 2-step transfer is in progress (cancel it first)
1131
+ */
1132
+ renounce_ownership: (txnOptions?: {
1133
+ /**
1134
+ * The fee to pay for the transaction. Default: BASE_FEE
1135
+ */
1136
+ fee?: number;
1137
+ /**
1138
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1139
+ */
1140
+ timeoutInSeconds?: number;
1141
+ /**
1142
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1143
+ */
1144
+ simulate?: boolean;
1145
+ }) => Promise<AssembledTransaction<null>>;
1146
+ /**
1147
+ * 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.
1148
+ * The type of data required for migration.
1149
+ * Upgrades the contract to new WASM bytecode.
1150
+ * Sets a migration flag that must be cleared by calling `migrate`.
1151
+ */
1152
+ upgrade: ({ new_wasm_hash }: {
1153
+ new_wasm_hash: Buffer;
1154
+ }, txnOptions?: {
1155
+ /**
1156
+ * The fee to pay for the transaction. Default: BASE_FEE
1157
+ */
1158
+ fee?: number;
1159
+ /**
1160
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1161
+ */
1162
+ timeoutInSeconds?: number;
1163
+ /**
1164
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1165
+ */
1166
+ simulate?: boolean;
1167
+ }) => Promise<AssembledTransaction<null>>;
1168
+ /**
1169
+ * 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.
1170
+ * Runs migration logic after an upgrade.
1171
+ * Can only be called when the migration flag is set by a previous `upgrade` call.
1172
+ */
1173
+ migrate: ({ migration_data }: {
1174
+ migration_data: Buffer;
1175
+ }, txnOptions?: {
1176
+ /**
1177
+ * The fee to pay for the transaction. Default: BASE_FEE
1178
+ */
1179
+ fee?: number;
1180
+ /**
1181
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1182
+ */
1183
+ timeoutInSeconds?: number;
1184
+ /**
1185
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1186
+ */
1187
+ simulate?: boolean;
1188
+ }) => Promise<AssembledTransaction<null>>;
1189
+ /**
1190
+ * Construct and simulate a freeze 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.
1191
+ * Permanently freezes the contract, preventing any future upgrades.
1192
+ * This action is irreversible.
1193
+ */
1194
+ freeze: (txnOptions?: {
1195
+ /**
1196
+ * The fee to pay for the transaction. Default: BASE_FEE
1197
+ */
1198
+ fee?: number;
1199
+ /**
1200
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1201
+ */
1202
+ timeoutInSeconds?: number;
1203
+ /**
1204
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1205
+ */
1206
+ simulate?: boolean;
1207
+ }) => Promise<AssembledTransaction<null>>;
1208
+ /**
1209
+ * Construct and simulate a is_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.
1210
+ * Returns whether the contract is frozen (upgrades disabled).
1211
+ */
1212
+ is_frozen: (txnOptions?: {
1213
+ /**
1214
+ * The fee to pay for the transaction. Default: BASE_FEE
1215
+ */
1216
+ fee?: number;
1217
+ /**
1218
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1219
+ */
1220
+ timeoutInSeconds?: number;
1221
+ /**
1222
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1223
+ */
1224
+ simulate?: boolean;
1225
+ }) => Promise<AssembledTransaction<boolean>>;
1226
+ }
1227
+ export declare class Client extends ContractClient {
1228
+ readonly options: ContractClientOptions;
1229
+ static deploy<T = Client>(
1230
+ /** Constructor/Initialization Args for the contract's `__constructor` method */
1231
+ { owner, endpoint, uln302 }: {
1232
+ owner: string;
1233
+ endpoint: string;
1234
+ uln302: string;
1235
+ },
1236
+ /** Options for initializing a Client as well as for calling a method, with extras specific to deploying. */
1237
+ options: MethodOptions & Omit<ContractClientOptions, "contractId"> & {
1238
+ /** The hash of the Wasm blob, which must already be installed on-chain. */
1239
+ wasmHash: Buffer | string;
1240
+ /** Salt used to generate the contract's ID. Passed through to {@link Operation.createCustomContract}. Default: random. */
1241
+ salt?: Buffer | Uint8Array;
1242
+ /** The format used to decode `wasmHash`, if it's provided as a string. */
1243
+ format?: "hex" | "base64";
1244
+ }): Promise<AssembledTransaction<T>>;
1245
+ constructor(options: ContractClientOptions);
1246
+ readonly fromJSON: {
1247
+ authorizer: (json: string) => AssembledTransaction<string>;
1248
+ endpoint: (json: string) => AssembledTransaction<string>;
1249
+ uln302: (json: string) => AssembledTransaction<string>;
1250
+ local_eid: (json: string) => AssembledTransaction<number>;
1251
+ initializable: (json: string) => AssembledTransaction<boolean>;
1252
+ verifiable: (json: string) => AssembledTransaction<boolean>;
1253
+ executable: (json: string) => AssembledTransaction<ExecutionState>;
1254
+ uln_verifiable: (json: string) => AssembledTransaction<VerificationState>;
1255
+ set_ttl_configs: (json: string) => AssembledTransaction<null>;
1256
+ ttl_configs: (json: string) => AssembledTransaction<readonly [Option<TtlConfig>, Option<TtlConfig>]>;
1257
+ freeze_ttl_configs: (json: string) => AssembledTransaction<null>;
1258
+ is_ttl_configs_frozen: (json: string) => AssembledTransaction<boolean>;
1259
+ extend_instance_ttl: (json: string) => AssembledTransaction<null>;
1260
+ owner: (json: string) => AssembledTransaction<Option<string>>;
1261
+ pending_owner: (json: string) => AssembledTransaction<Option<string>>;
1262
+ transfer_ownership: (json: string) => AssembledTransaction<null>;
1263
+ propose_ownership_transfer: (json: string) => AssembledTransaction<null>;
1264
+ accept_ownership: (json: string) => AssembledTransaction<null>;
1265
+ renounce_ownership: (json: string) => AssembledTransaction<null>;
1266
+ upgrade: (json: string) => AssembledTransaction<null>;
1267
+ migrate: (json: string) => AssembledTransaction<null>;
1268
+ freeze: (json: string) => AssembledTransaction<null>;
1269
+ is_frozen: (json: string) => AssembledTransaction<boolean>;
1270
+ };
1271
+ }