@layerzerolabs/protocol-stellar-v2 0.2.19 → 0.2.21

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 (249) hide show
  1. package/.turbo/turbo-build.log +795 -791
  2. package/.turbo/turbo-lint.log +325 -155
  3. package/.turbo/turbo-test.log +1398 -1277
  4. package/Cargo.lock +122 -111
  5. package/Cargo.toml +32 -16
  6. package/contracts/common-macros/Cargo.toml +7 -7
  7. package/contracts/common-macros/src/auth.rs +18 -37
  8. package/contracts/common-macros/src/contract_ttl.rs +18 -7
  9. package/contracts/common-macros/src/lib.rs +31 -14
  10. package/contracts/common-macros/src/lz_contract.rs +38 -7
  11. package/contracts/common-macros/src/storage.rs +251 -292
  12. package/contracts/common-macros/src/tests/contract_ttl.rs +1 -1
  13. package/contracts/common-macros/src/tests/snapshots/common_macros__tests__auth__snapshot_generated_multisig_code.snap +6 -12
  14. package/contracts/common-macros/src/tests/snapshots/common_macros__tests__auth__snapshot_generated_ownable_code.snap +12 -17
  15. package/contracts/common-macros/src/tests/snapshots/common_macros__tests__contract_ttl__snapshot_generated_contractimpl_code.snap +2 -1
  16. package/contracts/common-macros/src/tests/snapshots/common_macros__tests__ttl_configurable__snapshot_generated_ttl_configurable_code.snap +2 -7
  17. package/contracts/common-macros/src/tests/snapshots/common_macros__tests__upgradeable__snapshot_generated_upgradeable_code.snap +20 -14
  18. package/contracts/common-macros/src/tests/upgradeable.rs +26 -4
  19. package/contracts/common-macros/src/ttl_configurable.rs +2 -10
  20. package/contracts/common-macros/src/ttl_extendable.rs +2 -10
  21. package/contracts/common-macros/src/upgradeable.rs +61 -26
  22. package/contracts/common-macros/src/utils.rs +0 -9
  23. package/contracts/endpoint-v2/src/lib.rs +3 -2
  24. package/contracts/endpoint-v2/src/tests/endpoint_v2/clear.rs +2 -2
  25. package/contracts/endpoint-v2/src/tests/endpoint_v2/lz_receive_alert.rs +3 -3
  26. package/contracts/endpoint-v2/src/tests/endpoint_v2/send.rs +4 -4
  27. package/contracts/endpoint-v2/src/tests/endpoint_v2/set_delegate.rs +17 -5
  28. package/contracts/endpoint-v2/src/tests/endpoint_v2/set_zro.rs +4 -4
  29. package/contracts/endpoint-v2/src/tests/endpoint_v2/verify.rs +2 -2
  30. package/contracts/endpoint-v2/src/tests/message_lib_manager/register_library.rs +2 -2
  31. package/contracts/endpoint-v2/src/tests/message_lib_manager/set_default_receive_lib_timeout.rs +6 -6
  32. package/contracts/endpoint-v2/src/tests/message_lib_manager/set_default_receive_library.rs +67 -37
  33. package/contracts/endpoint-v2/src/tests/message_lib_manager/set_default_send_library.rs +5 -5
  34. package/contracts/endpoint-v2/src/tests/message_lib_manager/set_receive_library.rs +44 -54
  35. package/contracts/endpoint-v2/src/tests/message_lib_manager/set_receive_library_timeout.rs +7 -7
  36. package/contracts/endpoint-v2/src/tests/message_lib_manager/set_send_library.rs +8 -8
  37. package/contracts/endpoint-v2/src/tests/messaging_channel/burn.rs +3 -3
  38. package/contracts/endpoint-v2/src/tests/messaging_channel/nilify.rs +4 -4
  39. package/contracts/endpoint-v2/src/tests/messaging_channel/skip.rs +3 -3
  40. package/contracts/endpoint-v2/src/tests/messaging_composer/clear_compose.rs +2 -2
  41. package/contracts/endpoint-v2/src/tests/messaging_composer/lz_compose_alert.rs +3 -3
  42. package/contracts/endpoint-v2/src/tests/messaging_composer/send_compose.rs +2 -2
  43. package/contracts/layerzero-views/Cargo.toml +0 -1
  44. package/contracts/layerzero-views/src/layerzero_view.rs +1 -13
  45. package/contracts/macro-integration-tests/Cargo.toml +5 -15
  46. package/contracts/macro-integration-tests/tests/runtime/oapp/mod.rs +48 -0
  47. package/contracts/macro-integration-tests/tests/runtime/oapp/oapp_core.rs +170 -0
  48. package/contracts/macro-integration-tests/tests/runtime/oapp/options_type3.rs +154 -0
  49. package/contracts/macro-integration-tests/tests/runtime/oapp/receiver.rs +338 -0
  50. package/contracts/macro-integration-tests/tests/runtime/oapp/sender.rs +435 -0
  51. package/contracts/macro-integration-tests/tests/runtime.rs +1 -0
  52. package/contracts/macro-integration-tests/tests/ui/oapp/fail/custom_wrong_value.rs +8 -0
  53. package/contracts/macro-integration-tests/tests/ui/oapp/fail/custom_wrong_value.stderr +5 -0
  54. package/contracts/macro-integration-tests/tests/ui/oapp/fail/missing_lz_receive_internal.rs +8 -0
  55. package/contracts/macro-integration-tests/tests/ui/oapp/fail/missing_lz_receive_internal.stderr +71 -0
  56. package/contracts/macro-integration-tests/tests/ui/oapp/fail/non_struct_input.rs +10 -0
  57. package/contracts/macro-integration-tests/tests/ui/oapp/fail/non_struct_input.stderr +5 -0
  58. package/contracts/macro-integration-tests/tests/ui/oapp/fail/unknown_custom_option.rs +8 -0
  59. package/contracts/macro-integration-tests/tests/ui/oapp/fail/unknown_custom_option.stderr +5 -0
  60. package/contracts/macro-integration-tests/tests/ui/oapp/fail/wrong_key.rs +8 -0
  61. package/contracts/macro-integration-tests/tests/ui/oapp/fail/wrong_key.stderr +5 -0
  62. package/contracts/macro-integration-tests/tests/ui/oapp/pass/custom_all.rs +38 -0
  63. package/contracts/macro-integration-tests/tests/ui/oapp/pass/custom_single_trait.rs +96 -0
  64. package/contracts/macro-integration-tests/tests/ui/oapp/pass/minimal_contract.rs +64 -0
  65. package/contracts/macro-integration-tests/tests/ui/oapp/pass/struct_with_fields.rs +46 -0
  66. package/contracts/macro-integration-tests/tests/ui/ownable/fail/only_auth_missing_env.stderr +8 -0
  67. package/contracts/macro-integration-tests/tests/ui/ownable/pass/namespacing_and_imports.rs +1 -1
  68. package/contracts/macro-integration-tests/tests/ui/ownable/pass/only_auth_env_param_variants.rs +1 -1
  69. package/contracts/macro-integration-tests/tests/ui_oapp.rs +11 -0
  70. package/contracts/message-libs/message-lib-common/Cargo.toml +0 -1
  71. package/contracts/message-libs/message-lib-common/src/errors.rs +1 -1
  72. package/contracts/message-libs/treasury/Cargo.toml +0 -2
  73. package/contracts/message-libs/treasury/src/tests/treasury_tests.rs +2 -2
  74. package/contracts/message-libs/uln-302/src/events.rs +4 -0
  75. package/contracts/message-libs/uln-302/src/send_uln.rs +22 -6
  76. package/contracts/message-libs/uln-302/src/tests/receive_uln302/effective_receive_uln_config.rs +2 -2
  77. package/contracts/message-libs/uln-302/src/tests/receive_uln302/set_default_receive_uln_configs.rs +2 -2
  78. package/contracts/message-libs/uln-302/src/tests/receive_uln302/verify.rs +2 -2
  79. package/contracts/message-libs/uln-302/src/tests/send_uln302/effective_executor_config.rs +2 -2
  80. package/contracts/message-libs/uln-302/src/tests/send_uln302/effective_send_uln_config.rs +2 -2
  81. package/contracts/message-libs/uln-302/src/tests/send_uln302/send.rs +21 -67
  82. package/contracts/message-libs/uln-302/src/tests/send_uln302/set_default_executor_configs.rs +2 -2
  83. package/contracts/message-libs/uln-302/src/tests/send_uln302/set_default_send_uln_configs.rs +2 -2
  84. package/contracts/oapps/counter/Cargo.toml +5 -6
  85. package/contracts/oapps/counter/integration_tests/setup_uln.rs +1 -1
  86. package/contracts/oapps/counter/integration_tests/utils.rs +19 -12
  87. package/contracts/oapps/oapp/src/errors.rs +1 -1
  88. package/contracts/oapps/oapp/src/interfaces/mod.rs +3 -0
  89. package/contracts/oapps/oapp/src/interfaces/oapp_msg_inspector.rs +47 -0
  90. package/contracts/oapps/oapp/src/lib.rs +1 -0
  91. package/contracts/oapps/oapp/src/macro_tests/test_macros.rs +4 -4
  92. package/contracts/oapps/oapp/src/oapp_core.rs +5 -5
  93. package/contracts/oapps/oapp/src/oapp_options_type3.rs +12 -4
  94. package/contracts/oapps/oapp/src/oapp_receiver.rs +14 -9
  95. package/contracts/oapps/oapp/src/tests/mod.rs +4 -4
  96. package/contracts/oapps/oapp/src/tests/oapp_core.rs +223 -0
  97. package/contracts/oapps/oapp/src/tests/oapp_options_type3.rs +240 -0
  98. package/contracts/oapps/oapp/src/tests/oapp_receiver.rs +381 -0
  99. package/contracts/oapps/oapp/src/tests/oapp_sender.rs +569 -0
  100. package/contracts/oapps/oapp-macros/Cargo.toml +8 -4
  101. package/contracts/oapps/oapp-macros/src/generators.rs +9 -34
  102. package/contracts/oapps/oapp-macros/src/lib.rs +3 -0
  103. package/contracts/oapps/oapp-macros/src/tests/mod.rs +2 -0
  104. package/contracts/oapps/oapp-macros/src/tests/oapp.rs +88 -0
  105. package/contracts/oapps/oapp-macros/src/tests/parse_custom_impls.rs +86 -0
  106. package/contracts/oapps/oapp-macros/src/tests/snapshots/oapp_macros__tests__oapp__snapshot_generate_oapp.snap +103 -0
  107. package/contracts/oapps/oft/integration-tests/utils.rs +28 -8
  108. package/contracts/oapps/oft/src/extensions/oft_fee.rs +153 -75
  109. package/contracts/oapps/oft/src/extensions/pausable.rs +61 -12
  110. package/contracts/oapps/oft/src/extensions/rate_limiter.rs +198 -134
  111. package/contracts/oapps/oft/src/oft.rs +45 -50
  112. package/contracts/oapps/oft/src/oft_types/lock_unlock.rs +1 -1
  113. package/contracts/oapps/oft/src/oft_types/mint_burn.rs +4 -26
  114. package/contracts/oapps/oft-core/Cargo.toml +1 -4
  115. package/contracts/oapps/oft-core/integration-tests/setup.rs +3 -3
  116. package/contracts/oapps/oft-core/integration-tests/utils.rs +21 -3
  117. package/contracts/oapps/oft-core/src/errors.rs +3 -2
  118. package/contracts/oapps/oft-core/src/events.rs +6 -0
  119. package/contracts/oapps/oft-core/src/lib.rs +1 -1
  120. package/contracts/oapps/oft-core/src/oft_core.rs +341 -246
  121. package/contracts/oapps/oft-core/src/storage.rs +7 -3
  122. package/contracts/oapps/oft-core/src/tests/mod.rs +1 -0
  123. package/contracts/oapps/oft-core/src/tests/test_decimals.rs +37 -2
  124. package/contracts/oapps/oft-core/src/tests/test_lz_receive.rs +2 -2
  125. package/contracts/oapps/oft-core/src/tests/test_msg_inspector.rs +323 -0
  126. package/contracts/oapps/oft-core/src/tests/test_send.rs +2 -2
  127. package/contracts/oapps/oft-core/src/tests/test_utils.rs +61 -16
  128. package/contracts/upgrader/src/lib.rs +30 -57
  129. package/contracts/upgrader/src/tests/test_data/test_upgradeable_contract1.wasm +0 -0
  130. package/contracts/upgrader/src/tests/test_data/test_upgradeable_contract2.wasm +0 -0
  131. package/contracts/upgrader/src/tests/test_upgrader.rs +44 -35
  132. package/contracts/utils/Cargo.toml +0 -1
  133. package/contracts/utils/src/buffer_reader.rs +1 -0
  134. package/contracts/utils/src/errors.rs +4 -2
  135. package/contracts/utils/src/multisig.rs +17 -8
  136. package/contracts/utils/src/ownable.rs +6 -6
  137. package/contracts/utils/src/testing_utils.rs +124 -54
  138. package/contracts/utils/src/tests/multisig.rs +12 -12
  139. package/contracts/utils/src/tests/ownable.rs +6 -6
  140. package/contracts/utils/src/tests/testing_utils.rs +50 -167
  141. package/contracts/utils/src/tests/ttl_configurable.rs +5 -5
  142. package/contracts/utils/src/tests/upgradeable.rs +372 -175
  143. package/contracts/utils/src/ttl_configurable.rs +13 -7
  144. package/contracts/utils/src/upgradeable.rs +48 -23
  145. package/contracts/workers/dvn/Cargo.toml +6 -6
  146. package/contracts/workers/dvn/src/auth.rs +12 -42
  147. package/contracts/workers/dvn/src/dvn.rs +15 -40
  148. package/contracts/workers/dvn/src/errors.rs +0 -1
  149. package/contracts/workers/dvn/src/interfaces/dvn.rs +35 -0
  150. package/contracts/workers/dvn/src/lib.rs +4 -3
  151. package/contracts/workers/dvn/src/tests/auth.rs +1 -1
  152. package/contracts/workers/dvn/src/tests/dvn.rs +19 -15
  153. package/contracts/workers/dvn/src/tests/multisig/set_threshold.rs +2 -4
  154. package/contracts/workers/dvn/src/tests/multisig/verify_signatures.rs +1 -3
  155. package/contracts/workers/dvn/src/tests/setup.rs +5 -9
  156. package/contracts/workers/dvn-fee-lib/Cargo.toml +2 -2
  157. package/contracts/workers/dvn-fee-lib/src/dvn_fee_lib.rs +38 -22
  158. package/contracts/workers/dvn-fee-lib/src/lib.rs +12 -2
  159. package/contracts/workers/dvn-fee-lib/src/tests/dvn_fee_lib.rs +17 -16
  160. package/contracts/workers/executor/Cargo.toml +4 -0
  161. package/contracts/workers/executor/src/executor.rs +15 -36
  162. package/contracts/workers/executor/src/lib.rs +2 -2
  163. package/contracts/workers/executor/src/tests/auth.rs +394 -0
  164. package/contracts/workers/executor/src/tests/executor.rs +410 -0
  165. package/contracts/workers/executor/src/tests/mod.rs +3 -0
  166. package/contracts/workers/executor/src/tests/setup.rs +250 -0
  167. package/contracts/workers/executor-fee-lib/Cargo.toml +7 -1
  168. package/contracts/workers/executor-fee-lib/src/executor_fee_lib.rs +62 -15
  169. package/contracts/workers/executor-fee-lib/src/executor_option.rs +28 -1
  170. package/contracts/workers/executor-fee-lib/src/lib.rs +11 -2
  171. package/contracts/workers/executor-fee-lib/src/tests/executor_fee_lib.rs +701 -0
  172. package/contracts/workers/executor-fee-lib/src/tests/executor_option.rs +370 -0
  173. package/contracts/workers/executor-fee-lib/src/tests/mod.rs +4 -0
  174. package/contracts/workers/executor-fee-lib/src/tests/setup.rs +60 -0
  175. package/contracts/workers/executor-helper/Cargo.toml +0 -1
  176. package/contracts/workers/executor-helper/src/lib.rs +3 -0
  177. package/contracts/workers/executor-helper/src/tests/executor_helper.rs +184 -0
  178. package/contracts/workers/executor-helper/src/tests/mod.rs +2 -0
  179. package/contracts/workers/executor-helper/src/tests/setup.rs +366 -0
  180. package/contracts/workers/fee-lib-interfaces/Cargo.toml +14 -0
  181. package/contracts/workers/{worker/src/interfaces/mod.rs → fee-lib-interfaces/src/lib.rs} +4 -3
  182. package/contracts/workers/price-feed/Cargo.toml +7 -1
  183. package/contracts/workers/price-feed/src/events.rs +1 -1
  184. package/contracts/workers/price-feed/src/lib.rs +12 -4
  185. package/contracts/workers/price-feed/src/price_feed.rs +5 -21
  186. package/contracts/workers/price-feed/src/storage.rs +1 -1
  187. package/contracts/workers/price-feed/src/tests/mod.rs +2 -0
  188. package/contracts/workers/price-feed/src/tests/price_feed.rs +869 -0
  189. package/contracts/workers/price-feed/src/tests/setup.rs +70 -0
  190. package/contracts/workers/price-feed/src/types.rs +1 -1
  191. package/contracts/workers/worker/src/errors.rs +1 -4
  192. package/contracts/workers/worker/src/lib.rs +0 -2
  193. package/contracts/workers/worker/src/storage.rs +32 -29
  194. package/contracts/workers/worker/src/tests/setup.rs +2 -8
  195. package/contracts/workers/worker/src/tests/worker.rs +96 -74
  196. package/contracts/workers/worker/src/worker.rs +75 -75
  197. package/docs/error-spec.md +55 -0
  198. package/docs/layerzero-v2-on-stellar.md +447 -0
  199. package/docs/oapp-guide.md +212 -0
  200. package/docs/oft-guide.md +314 -0
  201. package/package.json +3 -3
  202. package/sdk/.turbo/turbo-test.log +268 -263
  203. package/sdk/dist/generated/bml.d.ts +12 -4
  204. package/sdk/dist/generated/bml.js +9 -7
  205. package/sdk/dist/generated/counter.d.ts +306 -298
  206. package/sdk/dist/generated/counter.js +48 -46
  207. package/sdk/dist/generated/dvn.d.ts +450 -411
  208. package/sdk/dist/generated/dvn.js +66 -64
  209. package/sdk/dist/generated/dvn_fee_lib.d.ts +294 -338
  210. package/sdk/dist/generated/dvn_fee_lib.js +33 -64
  211. package/sdk/dist/generated/endpoint.d.ts +108 -100
  212. package/sdk/dist/generated/endpoint.js +21 -19
  213. package/sdk/dist/generated/executor.d.ts +414 -370
  214. package/sdk/dist/generated/executor.js +58 -55
  215. package/sdk/dist/generated/executor_fee_lib.d.ts +333 -377
  216. package/sdk/dist/generated/executor_fee_lib.js +34 -65
  217. package/sdk/dist/generated/executor_helper.d.ts +26 -190
  218. package/sdk/dist/generated/executor_helper.js +23 -28
  219. package/sdk/dist/generated/layerzero_view.d.ts +1271 -0
  220. package/sdk/dist/generated/layerzero_view.js +294 -0
  221. package/sdk/dist/generated/oft.d.ts +408 -385
  222. package/sdk/dist/generated/oft.js +89 -92
  223. package/sdk/dist/generated/price_feed.d.ts +385 -429
  224. package/sdk/dist/generated/price_feed.js +50 -81
  225. package/sdk/dist/generated/sml.d.ts +108 -100
  226. package/sdk/dist/generated/sml.js +21 -19
  227. package/sdk/dist/generated/treasury.d.ts +108 -100
  228. package/sdk/dist/generated/treasury.js +21 -19
  229. package/sdk/dist/generated/uln302.d.ts +108 -100
  230. package/sdk/dist/generated/uln302.js +23 -21
  231. package/sdk/dist/generated/upgrader.d.ts +189 -18
  232. package/sdk/dist/generated/upgrader.js +84 -4
  233. package/sdk/dist/index.d.ts +1 -0
  234. package/sdk/dist/index.js +2 -0
  235. package/sdk/package.json +1 -1
  236. package/sdk/src/index.ts +3 -0
  237. package/sdk/test/oft-sml.test.ts +4 -4
  238. package/sdk/test/suites/localnet.ts +84 -20
  239. package/sdk/test/upgrader.test.ts +2 -3
  240. package/tools/ts-bindings-gen/src/main.rs +2 -1
  241. package/contracts/ERROR_SPEC.md +0 -44
  242. package/contracts/endpoint-v2/ARCHITECTURE.md +0 -233
  243. package/contracts/oapps/oapp/src/tests/test_oapp_core.rs +0 -175
  244. package/contracts/oapps/oapp/src/tests/test_oapp_options_type3.rs +0 -212
  245. package/contracts/oapps/oapp/src/tests/test_oapp_receiver.rs +0 -153
  246. package/contracts/oapps/oapp/src/tests/test_oapp_sender.rs +0 -294
  247. /package/contracts/workers/{worker/src/interfaces → fee-lib-interfaces/src}/dvn_fee_lib.rs +0 -0
  248. /package/contracts/workers/{worker/src/interfaces → fee-lib-interfaces/src}/executor_fee_lib.rs +0 -0
  249. /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: 34116 bytes (33.32 KB)
10
+ */
11
+ export declare const WASM_BASE64 = "AGFzbQEAAAABmQEaYAJ+fgF+YAN+fn4BfmABfgF+YAR+fn5+AX5gAAF+YAJ/fwBgAX8BfmACfn4Bf2ACf34AYAABf2ABfwBgAX8Bf2AAAGACfn8AYAF+AGADf39/AGACfn4AYAN/fn4AYAJ/fwF+YAR/f39/AX5gA35/fgF/YAR/fn5+AX9gBn9+fn9+fgBgA35/fwBgA35+fgF/YAV+f39/fwACowEbAWwBMQAAAWwBXwABAWEBMAACAXgBMAAAAWwBNgACAWIBMAACAWwBNwADAXgBMQAAAWwBMgAAAXYBXwAEAWQBXwABAWIBOAACAWIBZQAAAWkBXwACAWkBMAACAWIBMwAAAWIBagAAAWIBMQADAW0BOQABAW0BYQADAXYBZwAAAXgBMwAEAXgBOAAEAWwBMAAAAWwBOAAAAXgBNQACAWIBZgABA2FgBQYHCAcHCQoFCwkGDAQECg0MCg4GCg8IBAYCCAoCBAUEBAQABAIOEAAMCRESAhMEDAQAAAgFBQYEBQUSBAQBDAQEBAQECQAIFAMVABYBABIXCwYSGAwGDAgIGQ8IDwYPBQMBABEGIQR/AUGAgMAAC38AQbyCwAALfwBB84TAAAt/AEGAhcAACwefAxwGbWVtb3J5AgAHdXBncmFkZQA1B21pZ3JhdGUAOAZmcmVlemUAOQlpc19mcm96ZW4AOwphdXRob3JpemVyADwFb3duZXIAPQ1wZW5kaW5nX293bmVyAD8SdHJhbnNmZXJfb3duZXJzaGlwAEAacHJvcG9zZV9vd25lcnNoaXBfdHJhbnNmZXIAQxBhY2NlcHRfb3duZXJzaGlwAEoScmVub3VuY2Vfb3duZXJzaGlwAEwTZXh0ZW5kX2luc3RhbmNlX3R0bABND3NldF90dGxfY29uZmlncwBOC3R0bF9jb25maWdzAFMSZnJlZXplX3R0bF9jb25maWdzAFcVaXNfdHRsX2NvbmZpZ3NfZnJvemVuAFgNX19jb25zdHJ1Y3RvcgBZCGVuZHBvaW50AFsGdWxuMzAyAF0JbG9jYWxfZWlkAF8NaW5pdGlhbGl6YWJsZQBhCnZlcmlmaWFibGUAZApleGVjdXRhYmxlAGYOdWxuX3ZlcmlmaWFibGUAaQFfAwEKX19kYXRhX2VuZAMCC19faGVhcF9iYXNlAwMKoFZgTQECfkIAIQICQAJAIAEQnICAgAAiA0ICEJ2AgIAARQ0AIANCAhCAgICAACICQv8Bg0LNAFINASAAIAI3AwhCASECCyAAIAI3AwAPCwALwgECAX8BfiOAgICAAEEQayIBJICAgIAAAkACQAJAAkACQAJAIABB/wFxDgMAAQIACyABQcCAwIAAQQgQsYCAgAAgASgCAA0DIAEgASkDCBCygICAAAwCCyABQciAwIAAQQYQsYCAgAAgASgCAA0CIAEgASkDCBCygICAAAwBCyABQc6AwIAAQQgQsYCAgAAgASgCAA0BIAEgASkDCBCygICAAAsgASkDCCECIAEpAwBQDQELAAsgAUEQaiSAgICAACACCw8AIAAgARCXgICAAEIBUQsVACAAEJyAgIAAIAFCAhCBgICAABoLDwAgACABEKCAgIAAQQFzCw0AIAAgARCDgICAAFALWAECfyOAgICAAEEQayIAJICAgIAAIABBBGoQooCAgAACQCAAKAIEQQFHDQAgACgCCCAAKAIMEKOAgIAAC0EAEKSAgIAAIQEgAEEQaiSAgICAACABQf0BcQsMACAAQQEQ1ICAgAALGwAgAK1CIIZCBIQgAa1CIIZCBIQQmICAgAAaC0cCAX8BfkECIQECQCAAEPmAgIAAIgJCAhCdgICAAEUNAEEBIQECQAJAIAJCAhCAgICAAKdB/wFxDgIBAgALAAtBACEBCyABC4sBAgJ/AX4jgICAgABBEGsiACSAgICAACAAQQRqEKKAgIAAAkAgACgCBEEBRw0AIAAoAgggACgCDBCjgICAAAtBACEBAkBBABCmgICAACICQgIQnYCAgABFDQBBASEBAkACQCACQgIQgICAgACnQf8BcQ4CAQIACwALQQAhAQsgAEEQaiSAgICAACABC8IBAgF/AX4jgICAgABBEGsiASSAgICAAAJAAkACQAJAAkACQCAAQf8BcQ4DAAECAAsgAUHShMCAAEEGELGAgIAAIAEoAgANAyABIAEpAwgQsoCAgAAMAgsgAUHYhMCAAEEIELGAgIAAIAEoAgANAiABIAEpAwgQsoCAgAAMAQsgAUHghMCAAEEKELGAgIAAIAEoAgANASABIAEpAwgQsoCAgAALIAEpAwghAiABKQMAUA0BCwALIAFBEGokgICAgAAgAgsPABCogICAABCCgICAABoLZgIBfwF+I4CAgIAAQRBrIgAkgICAgAAgABCigICAAAJAIAAoAgBBAUcNACAAKAIEIAAoAggQo4CAgAALIAAQqoCAgAAgACkDCCEBIAApAwBBiggQq4CAgAAgAEEQaiSAgICAACABC0oCAX8BfiOAgICAAEEQayIAJICAgIAAIAAQqoCAgAAgACkDCCEBIAApAwBBiggQq4CAgAAgARCCgICAABogAEEQaiSAgICAACABC1ABAX8jgICAgABBEGsiASSAgICAACABQQRqEKKAgIAAAkAgASgCBEEBRw0AIAEoAgggASgCDBCjgICAAAsgABCwgICAACABQRBqJICAgIAACykAAkAgAKdBAXFFDQAPCyABQfp3aq1CIIZCg4CAgOCAAXwQroCAgAAAC0IBAX8jgICAgABBEGsiACSAgICAACAAEK2AgIAAAkAgACkDAFANAEKDgICAsIEBEK6AgIAAAAsgAEEQaiSAgICAAAuTAQIBfwJ+I4CAgIAAQRBrIgEkgICAgAAgAUEEahCigICAAAJAIAEoAgRBAUcNACABKAIIIAEoAgwQo4CAgAALQgAhAgJAAkBBARCvgICAACIDQgAQnYCAgABFDQAgA0IAEICAgIAAIgJC/wGDQs0AUg0BIAAgAjcDCEIBIQILIAAgAjcDACABQRBqJICAgIAADwsACwsAIAAQmYCAgAAaC5IBAgF/AX4jgICAgABBEGsiASSAgICAAAJAAkACQAJAIABBAXFFDQAgAUHlg8CAAEEMELGAgIAAIAEoAgANAiABIAEpAwgQsoCAgAAMAQsgAUHgg8CAAEEFELGAgIAAIAEoAgANASABIAEpAwgQsoCAgAALIAEpAwghAiABKQMAUA0BCwALIAFBEGokgICAgAAgAgtNAQJ+QgAhAQJAAkBBABCvgICAACICQgIQnYCAgABFDQAgAkICEICAgIAAIgFC/wGDQs0AUg0BIAAgATcDCEIBIQELIAAgATcDAA8LAAtRAgF/AX4jgICAgABBEGsiAySAgICAACADIAEgAhD2gICAAEIBIQQCQCADKAIADQAgACADKQMINwMIQgAhBAsgACAENwMAIANBEGokgICAgAALRAEBfyOAgICAAEEQayICJICAgIAAIAIgATcDCCACQQhqQQEQ1oCAgAAhASAAQgA3AwAgACABNwMIIAJBEGokgICAgAALDgBBgIDAgAAQtICAgAALDAAgAEEgEO6AgIAAC5gBAQF/I4CAgIAAQRBrIgEkgICAgAAgASAAELaAgIAAAkACQCABKAIAQQFGDQAgASkDCCEAIAEQooCAgAACQCABKAIAQQFHDQAgASgCBCABKAIIEKOAgIAACxCngICAABChgICAAA0BQQEQt4CAgAAgABCEgICAABogAUEQaiSAgICAAEICDwsAC0KDgICAwIMBEK6AgIAAAAtCAQF+QgEhAgJAIAFC/wGDQsgAUg0AIAEQi4CAgABCgICAgHCDQoCAgICABFINACAAIAE3AwhCACECCyAAIAI3AwALDABBASAAELqAgIAAC60BAQF/I4CAgIAAQRBrIgEkgICAgAACQAJAAkAgAEL/AYNCyABSDQAgAUEEahCigICAAAJAIAEoAgRBAUcNACABKAIIIAEoAgwQo4CAgAALEKeAgIAAQQEQpICAgABB/QFxRQ0BIAAQhYCAgABC/wGDQgJSDQJBABC3gICAACABQRBqJICAgIAAQgIPCwALQoOAgICwgwEQroCAgAAAC0KDgICAoIMBEK6AgIAAAAtaAQF/I4CAgIAAQRBrIgAkgICAgAAgAEEEahCigICAAAJAIAAoAgRBAUcNACAAKAIIIAAoAgwQo4CAgAALEKeAgIAAQQBBARC6gICAACAAQRBqJICAgIAAQgILGgAgABD5gICAACABrUL/AYNCAhCBgICAABoLCQAQoYCAgACtCwgAEKiAgIAACz4CAX8BfiOAgICAAEEQayIAJICAgIAAIAAQqoCAgAAgACkDACAAKQMIEL6AgIAAIQEgAEEQaiSAgICAACABCw0AIAFCAiAAp0EBcRsLPgIBfwF+I4CAgIAAQRBrIgAkgICAgAAgABCtgICAACAAKQMAIAApAwgQvoCAgAAhASAAQRBqJICAgIAAIAELfQIBfwF+I4CAgIAAQRBrIgEkgICAgAACQCAAQv8Bg0LNAFINACABQQRqEKKAgIAAAkAgASgCBEEBRw0AIAEoAgggASgCDBCjgICAAAsQqYCAgAAhAhCsgICAACAAEMGAgIAAIAIgABDCgICAACABQRBqJICAgIAAQgIPCwALDgBBACAAQgIQxoCAgAALYQIBfwF+I4CAgIAAQRBrIgIkgICAgABB14LAgABBFRDHgICAABDIgICAACEDIAIgADcDCCACIAE3AwAgA0GAg8CAAEECIAJBAhDJgICAABCHgICAABogAkEQaiSAgICAAAvdAgIBfwJ+I4CAgIAAQSBrIgIkgICAgAACQAJAAkAgAEL/AYNCzQBSDQAgAUL/AYNCBFINACACQQhqEKKAgIAAAkAgAigCCEEBRw0AIAIoAgwgAigCEBCjgICAAAsQqYCAgAAhAwJAAkAgAUL/////D1YNACACQQhqEK2AgIAAIAIpAxAhASACKQMIQYgIEKuAgIAAIAEgABCDgICAAFBFDQMQxICAgAAMAQsQxYCAgAAgAUIgiKdJDQNBASAAQgAQxoCAgABBARCvgICAAEIAIAFChICAgHCDIgEgARCGgICAABpBkIPAgABBFhDHgICAABDIgICAACEEIAIgATcDGCACIAM3AxAgAiAANwMIIARBrIPAgABBAyACQQhqQQMQyYCAgAAQh4CAgAAaCyACQSBqJICAgIAAQgIPCwALQoOAgIDggAEQroCAgAAAC0KDgICA8IABEK6AgIAAAAsTAEEBEK+AgIAAQgAQiICAgAAaCzMBAn4QlYCAgAAhAAJAEJaAgIAAQiCIIgEgAEIgiCIAVA0AIAGnIACnaw8LENqAgIAAAAsVACAAEK+AgIAAIAEgAhCBgICAABoLRQIBfwF+I4CAgIAAQRBrIgIkgICAgAAgAiAAIAEQ9oCAgAACQCACKAIAQQFHDQAACyACKQMIIQMgAkEQaiSAgICAACADC2MDAX8BfgF/I4CAgIAAQRBrIgEkgICAgAAgASAANwMAQgIhAkEBIQMCQANAIANFDQEgA0F/aiEDIAAhAgwACwsgASACNwMIIAFBCGpBARDWgICAACEAIAFBEGokgICAgAAgAAsuAAJAIAEgA0YNAAALIACtQiCGQgSEIAKtQiCGQgSEIAGtQiCGQgSEEJKAgIAAC6cBAgF/An4jgICAgABBEGsiACSAgICAACAAEKKAgIAAAkAgACgCAEEBRw0AIAAoAgQgACgCCBCjgICAAAsgABCtgICAACAAKQMIIQEgACkDAEGICBCrgICAACABEIKAgIAAGiAAELCAgIAAAkAgACgCAA0AEMuAgIAAAAsgACkDCCECEMSAgIAAIAEQwYCAgAAgAiABEMKAgIAAIABBEGokgICAgABCAgsJABDagICAAAALoAECAX8CfiOAgICAAEEQayIAJICAgIAAIAAQooCAgAACQCAAKAIAQQFHDQAgACgCBCAAKAIIEKOAgIAACxCpgICAACEBEKyAgIAAQQAQr4CAgABCAhCIgICAABpBxIPAgABBExDHgICAABDIgICAACECIAAgATcDACACQdiDwIAAQQEgAEEBEMmAgIAAEIeAgIAAGiAAQRBqJICAgIAAQgILMQACQCAAQv8Bg0IEUg0AIAFC/wGDQgRSDQAgAEIgiKcgAUIgiKcQo4CAgABCAg8LAAveBAEFfyOAgICAAEHQAGsiAiSAgICAACACQShqIAAQz4CAgAACQCACKAIoQQJGDQAgAkEIakEIaiACQShqQQhqIgMoAgA2AgAgAiACKQIoNwMIIAJBKGogARDPgICAACACKAIoQQJGDQAgAkEYakEIaiADKAIANgIAIAIgAikCKDcDGCACQShqEKKAgIAAAkAgAigCKEEBRw0AIAIoAiwgAigCMBCjgICAAAsQp4CAgAACQAJAAkAQpYCAgAANABDFgICAACIDQYD7gAMgA0GA+4ADSRshBCACIAJBGGo2AiwgAiACQQhqNgIoQQAhAwNAIANBCEYNAwJAIAJBKGogA2ooAgAiBSgCAEEBcUUNACAFKAIIIgYgBEsNAyAFKAIEIAZLDQMLIANBBGohAwwACwtCg4CAgND/ABCugICAAAALQoOAgIDA/wAQroCAgAAACwJAAkAgAigCCEEBRw0AIAIoAgwgAigCEBDQgICAAAwBC0EBEKaAgIAAQgIQiICAgAAaCwJAAkAgAigCGEEBRw0AIAIoAhwgAigCIBDRgICAAAwBC0ECEKaAgIAAQgIQiICAgAAaCyACQShqQQhqIAJBCGpBCGooAgA2AgAgAkE8aiACQRhqQQhqKAIANgIAIAIgAikDCDcDKCACIAIpAxg3AjRBjITAgABBDxDHgICAABDIgICAACEAIAJBKGoQ0oCAgAAhASACIAJBNGoQ0oCAgAA3A0ggAiABNwNAIABBsITAgABBAiACQcAAakECEMmAgIAAEIeAgIAAGiACQdAAaiSAgICAAEICDwsAC2gBAX8jgICAgABBEGsiAiSAgICAAAJAAkAgAUICUQ0AIAJBBGogARD3gICAAAJAIAIoAgRFDQAgAEECNgIADAILIAAgAikCCDcCBCAAQQE2AgAMAQsgAEEANgIACyACQRBqJICAgIAACw4AQQEgACABEPqAgIAACw4AQQIgACABEPqAgIAAC0MCAX8BfiOAgICAAEEQayIBJICAgIAAIAEgABDVgICAAAJAIAEoAgBBAUcNAAALIAEpAwghAiABQRBqJICAgIAAIAILxAECAn8BfiOAgICAAEHAAGsiACSAgICAACAAQQhqEKKAgIAAAkAgACgCCEEBRw0AIAAoAgwgACgCEBCjgICAAAsgAEEIahCigICAACAAQRRqIgFBAhDUgICAACAAQTBqIABBCGoQ1YCAgAACQAJAIAAoAjANACAAKQM4IQIgAEEwaiABENWAgIAAIAAoAjBBAUcNAQsACyAAIAApAzg3AyggACACNwMgIABBIGpBAhDWgICAACECIABBwABqJICAgIAAIAILdwICfwF+I4CAgIAAQRBrIgIkgICAgABBACEDAkACQCABEKaAgIAAIgRCAhCdgICAAEUNACACQQRqIARCAhCAgICAABD3gICAAEEBIQMgAigCBEEBRg0BIAAgAikCCDcCBAsgACADNgIAIAJBEGokgICAgAAPCwALMAACQCABKAIAQQFHDQAgACABKAIEIAEoAggQ+ICAgAAPCyAAQgA3AwAgAEICNwMICxoAIACtQiCGQgSEIAGtQiCGQgSEEJSAgIAAC6oBAQF/I4CAgIAAQSBrIgAkgICAgAAgAEEMahCigICAAAJAIAAoAgxBAUcNACAAKAIQIAAoAhQQo4CAgAALEKeAgIAAAkAQpYCAgABFDQBCg4CAgOD/ABCugICAAAALQQAQpoCAgABCAUICEIGAgIAAGkHAhMCAAEESEMeAgIAAEMiAgIAAQQRBACAAQRhqQQAQyYCAgAAQh4CAgAAaIABBIGokgICAgABCAgsJABClgICAAK0LywEAAkACQAJAIABC/wGDQs0AUg0AIAFC/wGDQs0AUg0AIAJC/wGDQs0AUg0AQYDLHkGA0h8Q0ICAgABBgMseQYDSHxDRgICAAEEAEK+AgIAAQgIQnYCAgAANASAAEMGAgIAAQQAgARCegICAAEEBIAIQnoCAgAAgAUKO0q4VEImAgIAAEIqAgIAAIgFC/wGDQgRSDQJBAhCcgICAACABQoSAgIBwg0ICEIGAgIAAGkICDwsAC0KDgICAkIEBEK6AgIAAAAsQ2oCAgAAACwkAEPKAgIAAAAsIABDcgICAAAtrAgF/AX4jgICAgABBEGsiACSAgICAACAAEKKAgIAAAkAgACgCAEEBRw0AIAAoAgQgACgCCBCjgICAAAsgAEEAEJuAgIAAAkAgACgCAA0AEMuAgIAAAAsgACkDCCEBIABBEGokgICAgAAgAQsIABDegICAAAtrAgF/AX4jgICAgABBEGsiACSAgICAACAAEKKAgIAAAkAgACgCAEEBRw0AIAAoAgQgACgCCBCjgICAAAsgAEEBEJuAgIAAAkAgACgCAA0AEMuAgIAAAAsgACkDCCEBIABBEGokgICAgAAgAQsPABDggICAAK1CIIZCBIQLiAECAX8BfiOAgICAAEEQayIAJICAgIAAIABBBGoQooCAgAACQCAAKAIEQQFHDQAgACgCCCAAKAIMEKOAgIAACwJAAkBBAhCcgICAACIBQgIQnYCAgABFDQAgAUICEICAgIAAIgFC/wGDQgRRDQEACxDLgICAAAALIABBEGokgICAgAAgAUIgiKcLugEBAn8jgICAgABBwABrIgIkgICAgAAgAkEgaiAAEOKAgIAAAkAgAigCIEEBRg0AIAJBCGpBEGogAkE4aikDADcDACACQRBqIAJBIGpBEGopAwA3AwAgAiACKQMoNwMIIAFC/wGDQs0AUg0AIAJBIGoQooCAgAACQCACKAIgQQFHDQAgAigCJCACKAIoEKOAgIAACxDcgICAACACQQhqIAEQ44CAgAAhAyACQcAAaiSAgICAACADrQ8LAAviAQICfwJ+I4CAgIAAQTBrIgIkgICAgABBACEDAkADQCADQRhGDQEgAkEIaiADakICNwMAIANBCGohAwwACwtCASEEAkAgAUL/AYNCzABSDQAgAUHMgcCAAEEDIAJBCGpBAxD1gICAACACQSBqIAIpAwgQ9ICAgAAgAigCIA0AIAIpAyghASACQSBqIAIpAxAQtoCAgAAgAigCIA0AIAIpAxgiBUL/AYNCBFINACACKQMoIQQgACABNwMQIAAgBDcDCCAAIAVCIIg+AhhCACEECyAAIAQ3AwAgAkEwaiSAgICAAAu6AQIBfwJ+I4CAgIAAQSBrIgMkgICAgABB5IHAgABBDRDHgICAACEEIAEQ8YCAgAAhBSADIAI3AwggAyAFNwMAQQAhAQN/AkAgAUEQRw0AQQAhAQJAA0AgAUEQRg0BIANBEGogAWogAyABaikDADcDACABQQhqIQEMAAsLIAAgBCADQRBqQQIQ1oCAgAAQ74CAgAAhASADQSBqJICAgIAAIAEPCyADQRBqIAFqQgI3AwAgAUEIaiEBDAALC7YBAQJ/I4CAgIAAQcAAayIEJICAgIAAIARBIGogABDigICAAAJAIAQoAiBBAUYNACAEQQhqQRBqIARBOGopAwA3AwAgBEEQaiAEQSBqQRBqKQMANwMAIAQgBCkDKDcDCCABQv8Bg0LNAFINACACQv8Bg0LNAFINACAEQSBqIAMQtoCAgAAgBCgCIEEBRg0AIARBCGogASACIAQpAygQ5YCAgAAhBSAEQcAAaiSAgICAACAFrQ8LAAurAwMBfwN+AX8jgICAgABBMGsiBCSAgICAACAEQRhqEKKAgIAAAkAgBCgCGEEBRw0AIAQoAhwgBCgCIBCjgICAAAsQ3ICAgAAhBSAANQIQIQZB8YHAgABBGBDHgICAACEHIAQgAjcDECAEIAZCIIZCBIQ3AwggBCABNwMAQQAhCAJAAkADQAJAIAhBGEcNAEEAIQgCQANAIAhBGEYNASAEQRhqIAhqIAQgCGopAwA3AwAgCEEIaiEIDAALCyAFIAcgBEEYakEDENaAgIAAEO+AgIAARQ0CQcSCwIAAQQoQx4CAgAAhAiAAEPGAgIAAIQYgBCABNwMIIAQgBjcDAEEAIQgDQAJAIAhBEEcNAEEAIQgCQANAIAhBEEYNASAEQRhqIAhqIAQgCGopAwA3AwAgCEEIaiEIDAALCyAFIAIgBEEYakECENaAgIAAEO+AgIAARQ0EIAMQs4CAgAAQoICAgABBAXMhCAwFCyAEQRhqIAhqQgI3AwAgCEEIaiEIDAALCyAEQRhqIAhqQgI3AwAgCEEIaiEIDAALC0EAIQgLIARBMGokgICAgAAgCAv6BQICfwZ+I4CAgIAAQdAAayICJICAgIAAIAJBCGogABDigICAAAJAAkAgAigCCEEBRg0AIAFC/wGDQs0AUg0AIAIoAiAhAyACKQMYIQAgAikDECEEIAJBCGoQooCAgAACQCACKAIIQQFHDQAgAigCDCACKAIQEKOAgIAACyACQShqENyAgIAAIgUgASADIAQgABDngICAABCzgICAACEGQaCAwIAAELSAgIAAIQcCQAJAAkACQCACKAIoDQBBloLAgABBEhDHgICAACEHIAIgBDcDSCACIAE3AzggAiADrUIghkIEhDcDQEEAIQMDQAJAIANBGEcNAEEAIQMCQANAIANBGEYNASACQQhqIANqIAJBOGogA2opAwA3AwAgA0EIaiEDDAALCyAAIAUgByACQQhqQQMQ1oCAgAAQ6ICAgABWDQMgAkEIakGFgcCAAEEIELGAgIAAIAIoAggNBiACQQhqIAIpAxAQsoCAgAAMBQsgAkEIaiADakICNwMAIANBCGohAwwACwsCQCACKQMwIgggBxCfgICAAEUNAEGJgsCAAEENEMeAgIAAIQkgAiAENwNIIAIgATcDOCACIAOtQiCGQgSENwNAQQAhAwNAAkAgA0EYRw0AQQAhAwJAA0AgA0EYRg0BIAJBCGogA2ogAkE4aiADaikDADcDACADQQhqIQMMAAsLIAAgBSAJIAJBCGpBAxDWgICAABDogICAAFYNAiACQQhqQfuAwIAAQQoQsYCAgAAgAigCCA0GIAJBCGogAikDEBCygICAAAwFCyACQQhqIANqQgI3AwAgA0EIaiEDDAALCyAIIAYQn4CAgABFDQAgCCAHEJ+AgIAADQELIAJBCGpB1oDAgABBDRCxgICAACACKAIIDQIgAkEIaiACKQMQELKAgIAADAELIAJBCGpB44DAgABBGBCxgICAACACKAIIDQEgAkEIaiACKQMQELKAgIAACyACKQMQIQEgAikDCFANAQsACyACQdAAaiSAgICAACABC64CAgF/AX4jgICAgABBwABrIgYkgICAgABBqILAgABBFBDHgICAACEHIAZBIGogBRDzgICAAAJAIAYoAiBBAUYNACAGIAYpAyg3AxggBiAENwMQIAYgAjcDACAGIAOtQiCGQgSENwMIQQAhAwJAA0ACQCADQSBHDQBBACEDAkADQCADQSBGDQEgBkEgaiADaiAGIANqKQMANwMAIANBCGohAwwACwsCQAJAIAEgByAGQSBqQQQQ1oCAgAAQioCAgAAiBUICUg0AQgAhBQwBCyAGQSBqIAUQtoCAgAAgBigCIEEBRg0DIAYpAyghBEIBIQULIAAgBDcDCCAAIAU3AwAgBkHAAGokgICAgAAPCyAGQSBqIANqQgI3AwAgA0EIaiEDDAALCxDagICAAAALAAtRAQF/I4CAgIAAQRBrIgMkgICAgAAgAyAAIAEgAhCKgICAABD0gICAAAJAIAMoAgBBAUcNABDagICAAAALIAMpAwghAiADQRBqJICAgIAAIAIL5QgGAX8BfgF/AX4BfwF+I4CAgIAAQcAAayICJICAgIAAAkACQCAAQv8Bg0LIAFINACACIAA3AwAgAkEIaiABELaAgIAAIAIoAghBAUYNACACKQMQIQMgAkEIahCigICAAAJAIAIoAghBAUcNACACKAIMIAIoAhAQo4CAgAALAkACQCACKQMAEIuAgIAAQoCAgIBwg0KAgICAkApSDQAgAkEANgI0IAIgAjYCMAJAIAJBMGpBARDqgICAACIAEIuAgIAAQoCAgIBwg0KAgICAEFINACACQQA6AAgCQCAAEIuAgIAAQoCAgIBwg0KAgICAEFINACAAIAJBCGpBARDrgICAAAJAIAItAAhBAUcNAAJAIAJBMGpBCBDqgICAACIAEIuAgIAAQoCAgIBwg0KAgICAgAFSDQAgAkIANwMIIAAQi4CAgABCgICAgHCDQoCAgICAAVINAiAAIAJBCGpBCBDrgICAACACKQMIIQAgAkEwahDsgICAACEEIAJBMGoQ7YCAgAAhBSACQTBqEOyAgIAAIQYgAkEwahDtgICAACEBAkAgBhDggICAAEcNAEG8gsCAAEEIEO6AgIAAIAEQjICAgAAQhYCAgAAiAUL/AYNCzQBSDQcgAiAAQjiGIABCgP4Dg0IohoQgAEKAgPwHg0IYhiAAQoCAgPgPg0IIhoSEIABCCIhCgICA+A+DIABCGIhCgID8B4OEIABCKIhCgP4DgyAAQjiIhISEIgA3AxAgAiAFNwMIIAIgBDYCGAJAENyAgIAAIAJBCGogARDjgICAAA0AIAJBCGpBqIHAgABBEBCxgICAACACKAIIDQggAkEIaiACKQMQELKAgIAADAcLAkACQCACQQhqIAEQ3oCAgAAiByADEOWAgIAARQ0AIAJBMGoQ3ICAgAAgASAEIAUgABDngICAACACKAIwRQ0BIAIpAzggAxCggICAAEUNAQsgAkEIakGggcCAAEEIELGAgIAAIAIoAggNCCACQQhqIAIpAxAQsoCAgAAMBwsgAikDACEAQcSCwIAAQQoQx4CAgAAhASACIAM3AyggAiAANwMgQQAhBANAAkAgBEEQRw0AQQAhBAJAA0AgBEEQRg0BIAJBMGogBGogAkEgaiAEaikDADcDACAEQQhqIQQMAAsLAkAgByABIAJBMGpBAhDWgICAABDvgICAAA0AIAJBCGpBjYHAgABBCRCxgICAACACKAIIDQogAkEIaiACKQMQELKAgIAADAkLIAJBCGpBloHAgABBChCxgICAACACKAIIDQkgAkEIaiACKQMQELKAgIAADAgLIAJBMGogBGpCAjcDACAEQQhqIQQMAAsLQoOAgIAQEK6AgIAAAAtCg4CAgICCARCugICAAAALQoOAgIDQiQEQroCAgAAACxDwgICAAAALQoOAgICAggEQroCAgAAAC0KDgICAwIkBEK6AgIAAAAsgAikDECEAIAIpAwhQDQELAAsgAkHAAGokgICAgAAgAAt1AgJ/AX4CQAJAIAAoAgQiAiABaiIBIAJJDQAgASAAKAIAIgMpAwAQi4CAgABCIIinSw0BIAMpAwAgAq1CIIZCBIQgAa1CIIZCBIQQmoCAgAAhBCAAIAE2AgQgBA8LENqAgIAAAAtCg4CAgID9ABCugICAAAALHwAgAEIEIAGtQiCGQgSEIAKtQiCGQgSEEJGAgIAAGgu5AQIBfwF+I4CAgIAAQRBrIgEkgICAgAACQAJAIABBBBDqgICAACICEIuAgIAAQoCAgIBwg0KAgICAwABSDQAgAUEANgIMIAIQi4CAgABCgICAgHCDQoCAgIDAAFINASACIAFBDGpBBBDrgICAACABKAIMIQAgAUEQaiSAgICAACAAQRh0IABBgP4DcUEIdHIgAEEIdkGA/gNxIABBGHZycg8LQoOAgICAggEQroCAgAAACxDwgICAAAAL/wEDAX8BfgJ/I4CAgIAAQcAAayIBJICAgIAAAkACQCAAQSAQ6oCAgAAiAhCLgICAAEKAgICAcINCgICAgIAEUg0AIAFBIGpBGGoiAEIANwMAIAFBIGpBEGoiA0IANwMAIAFBIGpBCGoiBEIANwMAIAFCADcDICACEIuAgIAAQoCAgIBwg0KAgICAgARSDQEgAiABQSBqQSAQ64CAgAAgAUEYaiAAKQMANwMAIAFBEGogAykDADcDACABQQhqIAQpAwA3AwAgASABKQMgNwMAIAEQtICAgAAhAiABQcAAaiSAgICAACACDwtCg4CAgICCARCugICAAAALEPCAgIAAAAsaACAArUIghkIEhCABrUIghkIEhBCPgICAAAs0AQF/QQEhAwJAAkACQCAAIAEgAhCKgICAAKdB/wFxDgIBAgALENqAgIAAAAtBACEDCyADCwkAENqAgIAAAAt9AgF/AX4jgICAgABBMGsiASSAgICAACABQSBqIAApAwgQ84CAgAACQCABKAIgQQFHDQAACyABIAEpAyg3AwggASAAKQMANwMQIAEgADUCEEIghkIEhDcDGEHMgcCAAEEDIAFBCGpBAxDJgICAACECIAFBMGokgICAgAAgAgsDAAALOwACQAJAIAFC//////////8AVg0AIAFCCIZCBoQhAQwBCyABEI2AgIAAIQELIABCADcDACAAIAE3AwgLXQIBfwF+AkACQCABp0H/AXEiAkHAAEYNAAJAIAJBBkYNAEIBIQNCg5CAgIABIQEMAgsgAUIIiCEBQgAhAwwBC0IAIQMgARCOgICAACEBCyAAIAM3AwAgACABNwMICzEAAkAgAiAERg0AAAsgACABrUIghkIEhCADrUIghkIEhCACrUIghkIEhBCTgICAABoL2wECAX4EfwJAAkAgAkEJSw0AQgAhAyACIQQgASEFA0ACQCAEDQAgA0IIhkIOhCEDDAMLQQEhBgJAIAUtAAAiB0HfAEYNAAJAIAdBUGpB/wFxQQpJDQACQCAHQb9/akH/AXFBGkkNACAHQZ9/akH/AXFBGUsNBCAHQUVqIQYMAgsgB0FLaiEGDAELIAdBUmohBgsgA0IGhiAGrUL/AYOEIQMgBEF/aiEEIAVBAWohBQwACwsgAa1CIIZCBIQgAq1CIIZCBIQQkICAgAAhAwsgAEIANwMAIAAgAzcDCAutAQICfwF+I4CAgIAAQRBrIgIkgICAgABBACEDAkADQCADQRBGDQEgAiADakICNwMAIANBCGohAwwACwtBASEDAkAgAUL/AYNCzABSDQAgAUH8g8CAAEECIAJBAhD1gICAACACKQMAIgFC/wGDQgRSDQAgAikDCCIEQv8Bg0IEUg0AIAAgAUIgiKc2AgggACAEQiCIPgIEQQAhAwsgACADNgIAIAJBEGokgICAgAALYAIBfwF+I4CAgIAAQRBrIgMkgICAgAAgAyABrUIghkIEhDcDCCADIAKtQiCGQgSENwMAQfyDwIAAQQIgA0ECEMmAgIAAIQQgAEIANwMAIAAgBDcDCCADQRBqJICAgIAAC5IBAgF/AX4jgICAgABBEGsiASSAgICAAAJAAkACQAJAIABBAXFFDQAgAUHqhMCAAEEJELGAgIAAIAEoAgANAiABIAEpAwgQsoCAgAAMAQsgAUHShMCAAEEGELGAgIAAIAEoAgANASABIAEpAwgQsoCAgAALIAEpAwghAiABKQMAUA0BCwALIAFBEGokgICAgAAgAgtWAgF/AX4jgICAgABBEGsiAySAgICAACAAEKaAgIAAIQQgAyABIAIQ+ICAgAACQCADKAIAQQFHDQAACyAEIAMpAwhCAhCBgICAABogA0EQaiSAgICAAAsL/QQBAEGAgMAAC/MEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAD//////////////////////////////////////////0VuZHBvaW50VWxuMzAyTG9jYWxFaWROb3RFeGVjdXRhYmxlVmVyaWZpZWRCdXROb3RFeGVjdXRhYmxlRXhlY3V0YWJsZUV4ZWN1dGVkVmVyaWZ5aW5nVmVyaWZpYWJsZVZlcmlmaWVkTm90SW5pdGlhbGl6YWJsZW5vbmNlc2VuZGVyc3JjX2VpZAAAuAAQAAUAAAC9ABAABgAAAMMAEAAHAAAAaW5pdGlhbGl6YWJsZWlzX3ZhbGlkX3JlY2VpdmVfbGlicmFyeWluYm91bmRfbm9uY2VsYXp5X2luYm91bmRfbm9uY2VpbmJvdW5kX3BheWxvYWRfaGFzaAAAABIAAAABdmVyaWZpYWJsZXRocmVzaG9sZG93bmVyc2hpcF90cmFuc2ZlcnJlZG5ld19vd25lcm9sZF9vd25lcgAAbAEQAAkAAAB1ARAACQAAAG93bmVyc2hpcF90cmFuc2ZlcnJpbmd0dGwAAABsARAACQAAAHUBEAAJAAAApgEQAAMAAABvd25lcnNoaXBfcmVub3VuY2VkAHUBEAAJAAAAT3duZXJQZW5kaW5nT3duZXJleHRlbmRfdG8AAPEBEAAJAAAATgEQAAkAAAB0dGxfY29uZmlnc19zZXRpbnN0YW5jZXBlcnNpc3RlbnQAAAAbAhAACAAAACMCEAAKAAAAdHRsX2NvbmZpZ3NfZnJvemVuRnJvemVuSW5zdGFuY2VQZXJzaXN0ZW50TWlncmF0aW5nAKOmAQ5jb250cmFjdHNwZWN2MAAAAAQAAAAiRXJyb3JzIGZvciBMYXllclplcm9WaWV3IGNvbnRyYWN0LgAAAAAAAAAAABJMYXllclplcm9WaWV3RXJyb3IAAAAAAAEAAAApSW52YWxpZCBwYWNrZXQgaGVhZGVyIChkc3RfZWlkIG1pc21hdGNoKS4AAAAAAAAKSW52YWxpZEVJRAAAAAAAAQAAAAAAAACVVGhlIHR5cGUgb2YgZGF0YSByZXF1aXJlZCBmb3IgbWlncmF0aW9uLgpVcGdyYWRlcyB0aGUgY29udHJhY3QgdG8gbmV3IFdBU00gYnl0ZWNvZGUuClNldHMgYSBtaWdyYXRpb24gZmxhZyB0aGF0IG11c3QgYmUgY2xlYXJlZCBieSBjYWxsaW5nIGBtaWdyYXRlYC4AAAAAAAAHdXBncmFkZQAAAAABAAAAAAAAAA1uZXdfd2FzbV9oYXNoAAAAAAAD7gAAACAAAAAAAAAAAAAAAHZSdW5zIG1pZ3JhdGlvbiBsb2dpYyBhZnRlciBhbiB1cGdyYWRlLgpDYW4gb25seSBiZSBjYWxsZWQgd2hlbiB0aGUgbWlncmF0aW9uIGZsYWcgaXMgc2V0IGJ5IGEgcHJldmlvdXMgYHVwZ3JhZGVgIGNhbGwuAAAAAAAHbWlncmF0ZQAAAAABAAAAAAAAAA5taWdyYXRpb25fZGF0YQAAAAAADgAAAAAAAAAAAAAAXlBlcm1hbmVudGx5IGZyZWV6ZXMgdGhlIGNvbnRyYWN0LCBwcmV2ZW50aW5nIGFueSBmdXR1cmUgdXBncmFkZXMuClRoaXMgYWN0aW9uIGlzIGlycmV2ZXJzaWJsZS4AAAAAAAZmcmVlemUAAAAAAAAAAAAAAAAAAAAAADtSZXR1cm5zIHdoZXRoZXIgdGhlIGNvbnRyYWN0IGlzIGZyb3plbiAodXBncmFkZXMgZGlzYWJsZWQpLgAAAAAJaXNfZnJvemVuAAAAAAAAAAAAAAEAAAABAAAAAAAAAAAAAAAKYXV0aG9yaXplcgAAAAAAAAAAAAEAAAATAAAAAAAAAD5SZXR1cm5zIHRoZSBjdXJyZW50IG93bmVyIGFkZHJlc3MsIG9yIE5vbmUgaWYgbm8gb3duZXIgaXMgc2V0LgAAAAAABW93bmVyAAAAAAAAAAAAAAEAAAPoAAAAEwAAAAAAAABZUmV0dXJucyB0aGUgcGVuZGluZyBvd25lciBhZGRyZXNzIGZvciAyLXN0ZXAgdHJhbnNmZXIsIG9yIE5vbmUgaWYgbm8gdHJhbnNmZXIgaXMgcGVuZGluZy4AAAAAAAANcGVuZGluZ19vd25lcgAAAAAAAAAAAAABAAAD6AAAABMAAAAAAAABK1RyYW5zZmVycyBvd25lcnNoaXAgaW1tZWRpYXRlbHkgdG8gYSBuZXcgYWRkcmVzcy4KClVzZSB3aXRoIGNhdXRpb24gLSBpZiB5b3UgdHJhbnNmZXIgdG8gYSB3cm9uZyBhZGRyZXNzLCBvd25lcnNoaXAgaXMgbG9zdCBmb3JldmVyLgpDb25zaWRlciB1c2luZyBgcHJvcG9zZV9vd25lcnNoaXBfdHJhbnNmZXJgIGluc3RlYWQuCgojIFBhbmljcwotIGBPd25lck5vdFNldGAgaWYgbm8gb3duZXIgaXMgY3VycmVudGx5IHNldAotIGBUcmFuc2ZlckluUHJvZ3Jlc3NgIGlmIGEgMi1zdGVwIHRyYW5zZmVyIGlzIGluIHByb2dyZXNzAAAAABJ0cmFuc2Zlcl9vd25lcnNoaXAAAAAAAAEAAAAAAAAACW5ld19vd25lcgAAAAAAABMAAAAAAAAAAAAAAlxQcm9wb3NlcyBhbiBvd25lcnNoaXAgdHJhbnNmZXIgdG8gYSBuZXcgYWRkcmVzcy4KClRoZSBuZXcgb3duZXIgbXVzdCBjYWxsIGBhY2NlcHRfb3duZXJzaGlwKClgIHdpdGhpbiBgdHRsYCBsZWRnZXJzCnRvIGNvbXBsZXRlIHRoZSB0cmFuc2Zlci4gVGhlIHBlbmRpbmcgdHJhbnNmZXIgd2lsbCBhdXRvbWF0aWNhbGx5IGV4cGlyZSBhZnRlci4KCiMgQXJndW1lbnRzCi0gYG5ld19vd25lcmAgLSBUaGUgcHJvcG9zZWQgbmV3IG93bmVyCi0gYHR0bGAgLSBOdW1iZXIgb2YgbGVkZ2VycyB0aGUgbmV3IG93bmVyIGhhcyB0byBhY2NlcHQuClVzZSBgMGAgdG8gY2FuY2VsIGEgcGVuZGluZyB0cmFuc2ZlciAobmV3X293bmVyIG11c3QgbWF0Y2ggcGVuZGluZykuCgojIFBhbmljcwotIGBPd25lck5vdFNldGAgaWYgbm8gb3duZXIgaXMgY3VycmVudGx5IHNldAotIGBOb1BlbmRpbmdUcmFuc2ZlcmAgd2hlbiBjYW5jZWxsaW5nIGFuZCBubyBwZW5kaW5nIHRyYW5zZmVyIGV4aXN0cwotIGBJbnZhbGlkVHRsYCBpZiB0dGwgZXhjZWVkcyBtYXggVFRMCi0gYEludmFsaWRQZW5kaW5nT3duZXJgIHdoZW4gY2FuY2VsbGluZyB3aXRoIHdyb25nIG5ld19vd25lciBhZGRyZXNzAAAAGnByb3Bvc2Vfb3duZXJzaGlwX3RyYW5zZmVyAAAAAAACAAAAAAAAAAluZXdfb3duZXIAAAAAAAATAAAAAAAAAAN0dGwAAAAABAAAAAAAAAAAAAAAuUFjY2VwdHMgYSBwZW5kaW5nIDItc3RlcCBvd25lcnNoaXAgdHJhbnNmZXIuCgpNdXN0IGJlIGNhbGxlZCBieSB0aGUgcGVuZGluZyBvd25lciBiZWZvcmUgdGhlIFRUTCBleHBpcmVzLgoKIyBQYW5pY3MKLSBgTm9QZW5kaW5nVHJhbnNmZXJgIGlmIHRoZXJlIGlzIG5vIHBlbmRpbmcgdHJhbnNmZXIgKG9yIGl0IGV4cGlyZWQpAAAAAAAAEGFjY2VwdF9vd25lcnNoaXAAAAAAAAAAAAAAAAAAAACkUGVybWFuZW50bHkgcmVub3VuY2VzIG93bmVyc2hpcC4KCiMgUGFuaWNzCi0gYE93bmVyTm90U2V0YCBpZiBubyBvd25lciBpcyBjdXJyZW50bHkgc2V0Ci0gYFRyYW5zZmVySW5Qcm9ncmVzc2AgaWYgYSAyLXN0ZXAgdHJhbnNmZXIgaXMgaW4gcHJvZ3Jlc3MgKGNhbmNlbCBpdCBmaXJzdCkAAAAScmVub3VuY2Vfb3duZXJzaGlwAAAAAAAAAAAAAAAAAAAAAAClRXh0ZW5kcyB0aGUgaW5zdGFuY2UgVFRMLgoKIyBBcmd1bWVudHMKCiogYHRocmVzaG9sZGAgLSBUaGUgdGhyZXNob2xkIHRvIGV4dGVuZCB0aGUgVFRMIChpZiBjdXJyZW50IFRUTCBpcyBiZWxvdyB0aGlzLCBleHRlbmQpLgoqIGBleHRlbmRfdG9gIC0gVGhlIFRUTCB0byBleHRlbmQgdG8uAAAAAAAAE2V4dGVuZF9pbnN0YW5jZV90dGwAAAAAAgAAAAAAAAAJdGhyZXNob2xkAAAAAAAABAAAAAAAAAAJZXh0ZW5kX3RvAAAAAAAABAAAAAAAAAAAAAABj1NldHMgVFRMIGNvbmZpZ3MgZm9yIGluc3RhbmNlIGFuZCBwZXJzaXN0ZW50IHN0b3JhZ2UuCgotIGBOb25lYCB2YWx1ZXMgcmVtb3ZlIHRoZSBjb3JyZXNwb25kaW5nIGNvbmZpZyAoZGlzYWJsZXMgYXV0by1leHRlbnNpb24gZm9yIHRoYXQgdHlwZSkKLSBWYWxpZGF0ZXMgdGhhdCBgdGhyZXNob2xkIDw9IGV4dGVuZF90byA8PSBNQVhfVFRMYAoKIyBBcmd1bWVudHMKLSBgaW5zdGFuY2VgIC0gVFRMIGNvbmZpZyBmb3IgaW5zdGFuY2Ugc3RvcmFnZQotIGBwZXJzaXN0ZW50YCAtIFRUTCBjb25maWcgZm9yIHBlcnNpc3RlbnQgc3RvcmFnZQoKIyBQYW5pY3MKLSBgVHRsQ29uZmlnRnJvemVuYCBpZiBjb25maWdzIGFyZSBmcm96ZW4KLSBgSW52YWxpZFR0bENvbmZpZ2AgaWYgdmFsaWRhdGlvbiBmYWlscwAAAAAPc2V0X3R0bF9jb25maWdzAAAAAAIAAAAAAAAACGluc3RhbmNlAAAD6AAAB9AAAAAJVHRsQ29uZmlnAAAAAAAAAAAAAApwZXJzaXN0ZW50AAAAAAPoAAAH0AAAAAlUdGxDb25maWcAAAAAAAAAAAAAAAAAAEhSZXR1cm5zIHRoZSBjdXJyZW50IFRUTCBjb25maWdzIGFzIChpbnN0YW5jZV9jb25maWcsIHBlcnNpc3RlbnRfY29uZmlnKS4AAAALdHRsX2NvbmZpZ3MAAAAAAAAAAAEAAAPtAAAAAgAAA+gAAAfQAAAACVR0bENvbmZpZwAAAAAAA+gAAAfQAAAACVR0bENvbmZpZwAAAAAAAAAAAADhUGVybWFuZW50bHkgZnJlZXplcyBUVEwgY29uZmlncywgcHJldmVudGluZyBhbnkgZnV0dXJlIG1vZGlmaWNhdGlvbnMuCgpUaGlzIGlzIGlycmV2ZXJzaWJsZSBhbmQgcHJvdmlkZXMgaW1tdXRhYmlsaXR5IGd1YXJhbnRlZXMgdG8gdXNlcnMuCkVtaXRzIGBUdGxDb25maWdzRnJvemVuYCBldmVudC4KCiMgUGFuaWNzCi0gYFR0bENvbmZpZ0FscmVhZHlGcm96ZW5gIGlmIGFscmVhZHkgZnJvemVuAAAAAAAAEmZyZWV6ZV90dGxfY29uZmlncwAAAAAAAAAAAAAAAAAAAAAAJ1JldHVybnMgd2hldGhlciBUVEwgY29uZmlncyBhcmUgZnJvemVuLgAAAAAVaXNfdHRsX2NvbmZpZ3NfZnJvemVuAAAAAAAAAAAAAAEAAAABAAAAAAAAAAAAAAANX19jb25zdHJ1Y3RvcgAAAAAAAAMAAAAAAAAABW93bmVyAAAAAAAAEwAAAAAAAAAIZW5kcG9pbnQAAAATAAAAAAAAAAZ1bG4zMDIAAAAAABMAAAAAAAAAAAAAAB1SZXR1cm5zIHRoZSBlbmRwb2ludCBhZGRyZXNzLgAAAAAAAAhlbmRwb2ludAAAAAAAAAABAAAAEwAAAAAAAAAbUmV0dXJucyB0aGUgVWxuMzAyIGFkZHJlc3MuAAAAAAZ1bG4zMDIAAAAAAAAAAAABAAAAEwAAAAAAAAAeUmV0dXJucyB0aGUgbG9jYWwgZW5kcG9pbnQgSUQuAAAAAAAJbG9jYWxfZWlkAAAAAAAAAAAAAAEAAAAEAAAAAAAAAFBDaGVja3MgaWYgYSBtZXNzYWdpbmcgcGF0aCBjYW4gYmUgaW5pdGlhbGl6ZWQgZm9yIHRoZSBnaXZlbiBvcmlnaW4gYW5kIHJlY2VpdmVyLgAAAA1pbml0aWFsaXphYmxlAAAAAAAAAgAAAAAAAAAGb3JpZ2luAAAAAAfQAAAABk9yaWdpbgAAAAAAAAAAAAhyZWNlaXZlcgAAABMAAAABAAAAAQAAAAAAAAC0Q2hlY2tzIGlmIGEgbWVzc2FnZSBjYW4gYmUgdmVyaWZpZWQgYXQgdGhlIGVuZHBvaW50LgoKVmVyaWZpZXM6CjEuIFJlY2VpdmUgbGlicmFyeSBpcyB2YWxpZCBmb3IgdGhpcyByZWNlaXZlciBhbmQgc291cmNlCjIuIEVuZHBvaW50IG5vbmNlIGNoZWNrIHBhc3NlcwozLiBQYXlsb2FkIGhhc2ggaXMgbm90IGVtcHR5AAAACnZlcmlmaWFibGUAAAAAAAQAAAAAAAAABm9yaWdpbgAAAAAH0AAAAAZPcmlnaW4AAAAAAAAAAAAIcmVjZWl2ZXIAAAATAAAAAAAAAAtyZWNlaXZlX2xpYgAAAAATAAAAAAAAAAxwYXlsb2FkX2hhc2gAAAPuAAAAIAAAAAEAAAABAAAAAAAAAClSZXR1cm5zIHRoZSBleGVjdXRpb24gc3RhdGUgb2YgYSBtZXNzYWdlLgAAAAAAAApleGVjdXRhYmxlAAAAAAACAAAAAAAAAAZvcmlnaW4AAAAAB9AAAAAGT3JpZ2luAAAAAAAAAAAACHJlY2VpdmVyAAAAEwAAAAEAAAfQAAAADkV4ZWN1dGlvblN0YXRlAAAAAAAAAAAA7lJldHVybnMgdGhlIGNvbWJpbmVkIHZlcmlmaWNhdGlvbiBzdGF0ZSBvZiBhIG1lc3NhZ2UuCgpUaGlzIGZ1bmN0aW9uIGNoZWNrczoKMS4gUGFja2V0IGhlYWRlciB2YWxpZGl0eSAoZHN0X2VpZCBtYXRjaGVzIGxvY2FsX2VpZCkKMi4gRW5kcG9pbnQgaW5pdGlhbGl6YWJsZSBzdGF0dXMKMy4gRW5kcG9pbnQgdmVyaWZpYWJsZSBzdGF0dXMKNC4gVUxOIHZlcmlmaWFibGUgc3RhdHVzIChEVk4gY29uZmlybWF0aW9ucykAAAAAAA51bG5fdmVyaWZpYWJsZQAAAAAAAgAAAAAAAAANcGFja2V0X2hlYWRlcgAAAAAAAA4AAAAAAAAADHBheWxvYWRfaGFzaAAAA+4AAAAgAAAAAQAAB9AAAAARVmVyaWZpY2F0aW9uU3RhdGUAAAAAAAACAAAAAAAAAAAAAAAUTGF5ZXJaZXJvVmlld1N0b3JhZ2UAAAADAAAAAAAAAAAAAAAIRW5kcG9pbnQAAAAAAAAAAAAAAAZVbG4zMDIAAAAAAAAAAAAAAAAACExvY2FsRWlkAAAAAgAAAIFSZXByZXNlbnRzIHRoZSBleGVjdXRpb24gc3RhdGUgb2YgYSBjcm9zcy1jaGFpbiBtZXNzYWdlLgoKVXNlZCBieSBleGVjdXRvcnMgdG8gZGV0ZXJtaW5lIHdoZW4gYSBtZXNzYWdlIGlzIHJlYWR5IHRvIGJlIGRlbGl2ZXJlZC4AAAAAAAAAAAAADkV4ZWN1dGlvblN0YXRlAAAAAAAEAAAAAAAAAD5NZXNzYWdlIGlzIG5vdCByZWFkeSBmb3IgZXhlY3V0aW9uIC0gd2FpdGluZyBmb3IgdmVyaWZpY2F0aW9uLgAAAAAADU5vdEV4ZWN1dGFibGUAAAAAAAAAAAAARk1lc3NhZ2UgaXMgdmVyaWZpZWQgYnV0IGNhbm5vdCBiZSBleGVjdXRlZCB5ZXQgKHByaW9yIG5vbmNlcyBwZW5kaW5nKS4AAAAAABhWZXJpZmllZEJ1dE5vdEV4ZWN1dGFibGUAAAAAAAAAIE1lc3NhZ2UgaXMgcmVhZHkgdG8gYmUgZXhlY3V0ZWQuAAAACkV4ZWN1dGFibGUAAAAAAAAAAAAiTWVzc2FnZSBoYXMgYWxyZWFkeSBiZWVuIGV4ZWN1dGVkLgAAAAAACEV4ZWN1dGVkAAAAAgAAAIhSZXByZXNlbnRzIHRoZSB2ZXJpZmljYXRpb24gc3RhdGUgb2YgYSBjcm9zcy1jaGFpbiBtZXNzYWdlIGF0IHRoZSBVTE4gbGV2ZWwuCgpVc2VkIGJ5IERWTnMgYW5kIGV4ZWN1dG9ycyB0byB0cmFjayB2ZXJpZmljYXRpb24gcHJvZ3Jlc3MuAAAAAAAAABFWZXJpZmljYXRpb25TdGF0ZQAAAAAAAAQAAAAAAAAAM0RWTnMgYXJlIHN0aWxsIGNvbGxlY3Rpbmcgc2lnbmF0dXJlcy9jb25maXJtYXRpb25zLgAAAAAJVmVyaWZ5aW5nAAAAAAAAAAAAAEBIYXMgZW5vdWdoIERWTiBjb25maXJtYXRpb25zLCByZWFkeSB0byBiZSBjb21taXR0ZWQgdG8gZW5kcG9pbnQuAAAAClZlcmlmaWFibGUAAAAAAAAAAAAhQWxyZWFkeSB2ZXJpZmllZCBhdCB0aGUgZW5kcG9pbnQuAAAAAAAACFZlcmlmaWVkAAAAAAAAACVDYW5ub3QgYmUgaW5pdGlhbGl6ZWQgKHBhdGggYmxvY2tlZCkuAAAAAAAAEE5vdEluaXRpYWxpemFibGUAAAAFAAAAAAAAAAAAAAAKUGFja2V0U2VudAAAAAAAAQAAAAtwYWNrZXRfc2VudAAAAAADAAAAAAAAAA5lbmNvZGVkX3BhY2tldAAAAAAADgAAAAAAAAAAAAAAB29wdGlvbnMAAAAADgAAAAAAAAAAAAAADHNlbmRfbGlicmFyeQAAABMAAAAAAAAAAgAAAAUAAAAAAAAAAAAAAA5QYWNrZXRWZXJpZmllZAAAAAAA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Clplcm9acm9GZWUAAAAAABgAAAAAAAAADlpyb1VuYXZhaWxhYmxlAAAAAAAZAAAAAQAAAC1QYXJhbWV0ZXJzIGZvciBzZW5kaW5nIGEgY3Jvc3MtY2hhaW4gbWVzc2FnZS4AAAAAAAAAAAAAD01lc3NhZ2luZ1BhcmFtcwAAAAAFAAAAK0Rlc3RpbmF0aW9uIGVuZHBvaW50IElEIChjaGFpbiBpZGVudGlmaWVyKS4AAAAAB2RzdF9laWQAAAAABAAAABxUaGUgbWVzc2FnZSBwYXlsb2FkIHRvIHNlbmQuAAAAB21lc3NhZ2UAAAAADgAAACFFbmNvZGVkIGV4ZWN1dG9yIGFuZCBEVk4gb3B0aW9ucy4AAAAAAAAHb3B0aW9ucwAAAAAOAAAAOVdoZXRoZXIgdG8gcGF5IGZlZXMgaW4gWlJPIHRva2VuIGluc3RlYWQgb2YgbmF0aXZlIHRva2VuLgAAAAAAAApwYXlfaW5fenJvAAAAAAABAAAANVJlY2VpdmVyIGFkZHJlc3Mgb24gdGhlIGRlc3RpbmF0aW9uIGNoYWluICgzMiBieXRlcykuAAAAAAAACHJlY2VpdmVyAAAD7gAAACAAAAABAAAATVNvdXJjZSBtZXNzYWdlIGluZm9ybWF0aW9uIGlkZW50aWZ5aW5nIHdoZXJlIGEgY3Jvc3MtY2hhaW4gbWVzc2FnZSBjYW1lIGZyb20uAAAAAAAAAAAAAAZPcmlnaW4AAAAAAAMAAAAXTm9uY2UgZm9yIHRoaXMgcGF0aHdheS4AAAAABW5vbmNlAAAAAAAABgAAAC5TZW5kZXIgYWRkcmVzcyBvbiB0aGUgc291cmNlIGNoYWluICgzMiBieXRlcykuAAAAAAAGc2VuZGVyAAAAAAPuAAAAIAAAACZTb3VyY2UgZW5kcG9pbnQgSUQgKGNoYWluIGlkZW50aWZpZXIpLgAAAAAAB3NyY19laWQAAAAABAAAAAEAAAAoRmVlIHN0cnVjdHVyZSBmb3IgY3Jvc3MtY2hhaW4gbWVzc2FnaW5nLgAAAAAAAAAMTWVzc2FnaW5nRmVlAAAAAgAAAB9GZWUgcGFpZCBpbiBuYXRpdmUgdG9rZW4gKFhMTSkuAAAAAApuYXRpdmVfZmVlAAAAAAALAAAAKEZlZSBwYWlkIGluIFpSTyB0b2tlbiAoTGF5ZXJaZXJvIHRva2VuKS4AAAAHenJvX2ZlZQAAAAALAAAAAQAAAEJSZWNlaXB0IHJldHVybmVkIGFmdGVyIHN1Y2Nlc3NmdWxseSBzZW5kaW5nIGEgY3Jvc3MtY2hhaW4gbWVzc2FnZS4AAAAAAAAAAAAQTWVzc2FnaW5nUmVjZWlwdAAAAAMAAAApVGhlIGZlZXMgY2hhcmdlZCBmb3Igc2VuZGluZyB0aGUgbWVzc2FnZS4AAAAAAAADZmVlAAAAB9AAAAAMTWVzc2FnaW5nRmVlAAAAK0dsb2JhbGx5IHVuaXF1ZSBpZGVudGlmaWVyIGZvciB0aGUgbWVzc2FnZS4AAAAABGd1aWQAAAPuAAAAIAAAACRUaGUgb3V0Ym91bmQgbm9uY2UgZm9yIHRoaXMgcGF0aHdheS4AAAAFbm9uY2UAAAAAAAAGAAAAAgAAADhUeXBlIG9mIG1lc3NhZ2UgbGlicmFyeSBpbmRpY2F0aW5nIHN1cHBvcnRlZCBvcGVyYXRpb25zLgAAAAAAAAAOTWVzc2FnZUxpYlR5cGUAAAAAAAMAAAAAAAAAH1N1cHBvcnRzIG9ubHkgc2VuZGluZyBtZXNzYWdlcy4AAAAABFNlbmQAAAAAAAAAIVN1cHBvcnRzIG9ubHkgcmVjZWl2aW5nIG1lc3NhZ2VzLgAAAAAAAAdSZWNlaXZlAAAAAAAAAAAtU3VwcG9ydHMgYm90aCBzZW5kaW5nIGFuZCByZWNlaXZpbmcgbWVzc2FnZXMuAAAAAAAADlNlbmRBbmRSZWNlaXZlAAAAAAABAAAAt1ZlcnNpb24gaW5mb3JtYXRpb24gZm9yIGEgbWVzc2FnZSBsaWJyYXJ5LgoKTm90ZTogYG1pbm9yYCBhbmQgYGVuZHBvaW50X3ZlcnNpb25gIHVzZSBgdTMyYCBpbnN0ZWFkIG9mIGB1OGAgYmVjYXVzZSBTdGVsbGFyIGRvZXMgbm90CnN1cHBvcnQgYHU4YCB0eXBlcyBpbiBjb250cmFjdCBpbnRlcmZhY2UgZnVuY3Rpb25zLgAAAAAAAAAAEU1lc3NhZ2VMaWJWZXJzaW9uAAAAAAAAAwAAADNFbmRwb2ludCB2ZXJzaW9uIChzaG91bGQgbm90IGV4Y2VlZCB1ODo6TUFYID0gMjU1KS4AAAAAEGVuZHBvaW50X3ZlcnNpb24AAAAEAAAAFU1ham9yIHZlcnNpb24gbnVtYmVyLgAAAAAAAAVtYWpvcgAAAAAAAAYAAAA3TWlub3IgdmVyc2lvbiBudW1iZXIgKHNob3VsZCBub3QgZXhjZWVkIHU4OjpNQVggPSAyNTUpLgAAAAAFbWlub3IAAAAAAAAEAAAAAQAAADZUaW1lb3V0IGNvbmZpZ3VyYXRpb24gZm9yIHJlY2VpdmUgbGlicmFyeSB0cmFuc2l0aW9ucy4AAAAAAAAAAAAHVGltZW91dAAAAAACAAAAKFVuaXggdGltZXN0YW1wIHdoZW4gdGhlIHRpbWVvdXQgZXhwaXJlcy4AAAAGZXhwaXJ5AAAAAAAGAAAAKVRoZSBuZXcgbGlicmFyeSBhZGRyZXNzIHRvIHRyYW5zaXRpb24gdG8uAAAAAAAAA2xpYgAAAAATAAAAAQAAADVQYXJhbWV0ZXJzIGZvciBzZXR0aW5nIG1lc3NhZ2UgbGlicmFyeSBjb25maWd1cmF0aW9uLgAAAAAAAAAAAAAOU2V0Q29uZmlnUGFyYW0AAAAAAAMAAAAfWERSLWVuY29kZWQgY29uZmlndXJhdGlvbiBkYXRhLgAAAAAGY29uZmlnAAAAAAAOAAAAMFRoZSB0eXBlIG9mIGNvbmZpZ3VyYXRpb24gKGUuZy4sIGV4ZWN1dG9yLCBVTE4pLgAAAAtjb25maWdfdHlwZQAAAAAEAAAAJ1RoZSBlbmRwb2ludCBJRCB0aGlzIGNvbmZpZyBhcHBsaWVzIHRvLgAAAAADZWlkAAAAAAQAAAABAAAAMVJlc29sdmVkIGxpYnJhcnkgaW5mb3JtYXRpb24gd2l0aCBkZWZhdWx0IHN0YXR1cy4AAAAAAAAAAAAAD1Jlc29sdmVkTGlicmFyeQAAAAACAAAARFdoZXRoZXIgdGhpcyBpcyB0aGUgZGVmYXVsdCBsaWJyYXJ5ICh0cnVlKSBvciBPQXBwLXNwZWNpZmljIChmYWxzZSkuAAAACmlzX2RlZmF1bHQAAAAAAAEAAAAdVGhlIHJlc29sdmVkIGxpYnJhcnkgYWRkcmVzcy4AAAAAAAADbGliAAAAABMAAAABAAAASE91dGJvdW5kIHBhY2tldCBjb250YWluaW5nIGFsbCBpbmZvcm1hdGlvbiBmb3IgY3Jvc3MtY2hhaW4gdHJhbnNtaXNzaW9uLgAAAAAAAAAOT3V0Ym91bmRQYWNrZXQAAAAAAAcAAAAYRGVzdGluYXRpb24gZW5kcG9pbnQgSUQuAAAAB2RzdF9laWQAAAAABAAAACxHbG9iYWxseSB1bmlxdWUgaWRlbnRpZmllciBmb3IgdGhpcyBtZXNzYWdlLgAAAARndWlkAAAD7gAAACAAAAAUVGhlIG1lc3NhZ2UgcGF5bG9hZC4AAAAHbWVzc2FnZQAAAAAOAAAAIE91dGJvdW5kIG5vbmNlIGZvciB0aGlzIHBhdGh3YXkuAAAABW5vbmNlAAAAAAAABgAAADFSZWNlaXZlciBhZGRyZXNzIG9uIGRlc3RpbmF0aW9uIGNoYWluICgzMiBieXRlcykuAAAAAAAACHJlY2VpdmVyAAAD7gAAACAAAAAfU2VuZGVyIGFkZHJlc3Mgb24gc291cmNlIGNoYWluLgAAAAAGc2VuZGVyAAAAAAATAAAAE1NvdXJjZSBlbmRwb2ludCBJRC4AAAAAB3NyY19laWQAAAAABAAAAAEAAAArQSBmZWUgcmVjaXBpZW50IHdpdGggdGhlIGFtb3VudCB0byBiZSBwYWlkLgAAAAAAAAAADEZlZVJlY2lwaWVudAAAAAIAAAAVQW1vdW50IG9mIGZlZSB0byBwYXkuAAAAAAAABmFtb3VudAAAAAAACwAAAB9UaGUgYWRkcmVzcyB0byBzZW5kIHRoZSBmZWUgdG8uAAAAAAJ0bwAAAAAAEwAAAAEAAAA8UmVzdWx0IG9mIHNlbmQgb3BlcmF0aW9uIGNvbnRhaW5pbmcgZmVlcyBhbmQgZW5jb2RlZCBwYWNrZXQuAAAAAAAAAA1GZWVzQW5kUGFja2V0AAAAAAAAAwAAACpUaGUgZW5jb2RlZCBwYWNrZXQgcmVhZHkgZm9yIHRyYW5zbWlzc2lvbi4AAAAAAA5lbmNvZGVkX3BhY2tldAAAAAAADgAAAD9MaXN0IG9mIG5hdGl2ZSB0b2tlbiBmZWUgcmVjaXBpZW50cyAoZXhlY3V0b3IsIERWTnMsIHRyZWFzdXJ5KS4AAAAAFW5hdGl2ZV9mZWVfcmVjaXBpZW50cwAAAAAAA+oAAAfQAAAADEZlZVJlY2lwaWVudAAAACxMaXN0IG9mIFpSTyB0b2tlbiBmZWUgcmVjaXBpZW50cyAodHJlYXN1cnkpLgAAABJ6cm9fZmVlX3JlY2lwaWVudHMAAAAAA+oAAAfQAAAADEZlZVJlY2lwaWVudAAAAAQAAAAdUGFja2V0Q29kZWNWMUVycm9yOiAxMTAwLTExMDkAAAAAAAAAAAAAElBhY2tldENvZGVjVjFFcnJvcgAAAAAAAgAAAAAAAAATSW52YWxpZFBhY2tldEhlYWRlcgAAAARMAAAAAAAAABRJbnZhbGlkUGFja2V0VmVyc2lvbgAABE0AAAAEAAAAHVdvcmtlck9wdGlvbnNFcnJvcjogMTExMC0xMTE5AAAAAAAAAAAAABJXb3JrZXJPcHRpb25zRXJyb3IAAAAAAAkAAAAAAAAAEkludmFsaWRCeXRlc0xlbmd0aAAAAAAEVgAAAAAAAAAZSW52YWxpZExlZ2FjeU9wdGlvbnNUeXBlMQAAAAAABFcAAAAAAAAAGUludmFsaWRMZWdhY3lPcHRpb25zVHlwZTIAAAAAAARYAAAAAAAAABFJbnZhbGlkT3B0aW9uVHlwZQAAAAAABFkAAAAAAAAADkludmFsaWRPcHRpb25zAAAAAARaAAAAAAAAAA9JbnZhbGlkV29ya2VySWQAAAAEWwAAAAAAAAAdTGVnYWN5T3B0aW9uc1R5cGUxR2FzT3ZlcmZsb3cAAAAAAARcAAAAAAAAACBMZWdhY3lPcHRpb25zVHlwZTJBbW91bnRPdmVyZmxvdwAABF0AAAAAAAAAHUxlZ2FjeU9wdGlvbnNUeXBlMkdhc092ZXJmbG93AAAAAAAEXgAAAAQAAAAAAAAAAAAAAAtVbG4zMDJFcnJvcgAAAAATAAAAAAAAAB1EZWZhdWx0RXhlY3V0b3JDb25maWdOb3RGb3VuZAAAAAAAAAEAAAAAAAAAH0RlZmF1bHRSZWNlaXZlVWxuQ29uZmlnTm90Rm91bmQAAAAAAgAAAAAAAAAcRGVmYXVsdFNlbmRVbG5Db25maWdOb3RGb3VuZAAAAAMAAAAAAAAAFUR1cGxpY2F0ZU9wdGlvbmFsRFZOcwAAAAAAAAQAAAAAAAAAFUR1cGxpY2F0ZVJlcXVpcmVkRFZOcwAAAAAAAAUAAAAAAAAADUludmFsaWRDb25maWcAAAAAAAAGAAAAAAAAABFJbnZhbGlkQ29uZmlnVHlwZQAAAAAAAAcAAAAAAAAAFEludmFsaWRDb25maXJtYXRpb25zAAAACAAAAAAAAAAKSW52YWxpZEVJRAAAAAAACQAAAAAAAAASSW52YWxpZE1lc3NhZ2VTaXplAAAAAAAKAAAAAAAAABdJbnZhbGlkT3B0aW9uYWxEVk5Db3VudAAAAAALAAAAAAAAABNJbnZhbGlkT3B0aW9uYWxEVk5zAAAAAAwAAAAAAAAAG0ludmFsaWRPcHRpb25hbERWTlRocmVzaG9sZAAAAAANAAAAAAAAABdJbnZhbGlkUmVxdWlyZWREVk5Db3VudAAAAAAOAAAAAAAAABNJbnZhbGlkUmVxdWlyZWREVk5zAAAAAA8AAAAAAAAAEFVsbkF0TGVhc3RPbmVEVk4AAAAQAAAAAAAAAA5VbnN1cHBvcnRlZEVpZAAAAAAAEQAAAAAAAAAJVmVyaWZ5aW5nAAAAAAAAEgAAAAAAAAAPWmVyb01lc3NhZ2VTaXplAAAAABMAAAAFAAAAAAAAAAAAAAARRXhlY3V0b3JDb25maWdTZXQAAAAAAAABAAAAE2V4ZWN1dG9yX2NvbmZpZ19zZXQAAAAAAwAAAAAAAAAGc2VuZGVyAAAAAAATAAAAAQAAAAAAAAAHZHN0X2VpZAAAAAAEAAAAAQAAAAAAAAAGY29uZmlnAAAAAAfQAAAAEk9BcHBFeGVjdXRvckNvbmZpZwAAAAAAAAAAAAIAAAAFAAAAAAAAAAAAAAAQU2VuZFVsbkNvbmZpZ1NldAAAAAEAAAATc2VuZF91bG5fY29uZmlnX3NldAAAAAADAAAAAAAAAAZzZW5kZXIAAAAAABMAAAABAAAAAAAAAAdkc3RfZWlkAAAAAAQAAAABAAAAAAAAAAZjb25maWcAAAAAB9AAAAANT0FwcFVsbkNvbmZpZwAAAAAAAAAAAAACAAAABQAAAAAAAAAAAAAAE1JlY2VpdmVVbG5Db25maWdTZXQAAAAAAQAAABZyZWNlaXZlX3Vsbl9jb25maWdfc2V0AAAAAAADAAAAAAAAAAhyZWNlaXZlcgAAABMAAAABAAAAAAAAAAdzcmNfZWlkAAAAAAQAAAABAAAAAAAAAAZjb25maWcAAAAAB9AAAAANT0FwcFVsbkNvbmZpZwAAAAAAAAAAAAACAAAABQAAAAAAAAAAAAAAGURlZmF1bHRFeGVjdXRvckNvbmZpZ3NTZXQAAAAAAAABAAAAHGRlZmF1bHRfZXhlY3V0b3JfY29uZmlnc19zZXQAAAABAAAAAAAAAAZwYXJhbXMAAAAAA+oAAAfQAAAAHVNldERlZmF1bHRFeGVjdXRvckNvbmZpZ1BhcmFtAAAAAAAAAAAAAAIAAAAFAAAAAAAAAAAAAAAYRGVmYXVsdFNlbmRVbG5Db25maWdzU2V0AAAAAQAAABxkZWZhdWx0X3NlbmRfdWxuX2NvbmZpZ3Nfc2V0AAAAAQAAAAAAAAAGcGFyYW1zAAAAAAPqAAAH0AAAABhTZXREZWZhdWx0VWxuQ29uZmlnUGFyYW0AAAAAAAAAAgAAAAUAAAAAAAAAAAAAABtEZWZhdWx0UmVjZWl2ZVVsbkNvbmZpZ3NTZXQAAAAAAQAAAB9kZWZhdWx0X3JlY2VpdmVfdWxuX2NvbmZpZ3Nfc2V0AAAAAAEAAAAAAAAABnBhcmFtcwAAAAAD6gAAB9AAAAAYU2V0RGVmYXVsdFVsbkNvbmZpZ1BhcmFtAAAAAAAAAAIAAAAFAAAAAAAAAAAAAAAPRXhlY3V0b3JGZWVQYWlkAAAAAAEAAAARZXhlY3V0b3JfZmVlX3BhaWQAAAAAAAADAAAAAAAAAAhleGVjdXRvcgAAABMAAAABAAAAAAAAAARndWlkAAAD7gAAACAAAAABAAAAAAAAAANmZWUAAAAH0AAAAAxGZWVSZWNpcGllbnQAAAAAAAAAAgAAAAUAAAAAAAAAAAAAAApEVk5GZWVQYWlkAAAAAAABAAAADGR2bl9mZWVfcGFpZAAAAAMAAAAAAAAABGd1aWQAAAPuAAAAIAAAAAEAAAAAAAAABGR2bnMAAAPqAAAAEwAAAAAAAAAAAAAABGZlZXMAAAPqAAAH0AAAAAxGZWVSZWNpcGllbnQAAAAAAAAAAgAAAAUAAAAAAAAAAAAAAA9QYXlsb2FkVmVyaWZpZWQAAAAAAQAAABBwYXlsb2FkX3ZlcmlmaWVkAAAABAAAAAAAAAADZHZuAAAAABMAAAABAAAAAAAAAAZoZWFkZXIAAAAAAA4AAAAAAAAAAAAAAA1jb25maXJtYXRpb25zAAAAAAAABgAAAAAAAAAAAAAACnByb29mX2hhc2gAAAAAA+4AAAAgAAAAAAAAAAIAAAABAAAAOFVsdHJhIExpZ2h0IE5vZGUgY29uZmlndXJhdGlvbiBmb3IgbWVzc2FnZSB2ZXJpZmljYXRpb24uAAAAAAAAAAlVbG5Db25maWcAAAAAAAAEAAAASk51bWJlciBvZiBibG9jayBjb25maXJtYXRpb25zIHJlcXVpcmVkIGJlZm9yZSBtZXNzYWdlIHZlcmlmaWNhdGlvbiBiZWdpbnMuAAAAAAANY29uZmlybWF0aW9ucwAAAAAAAAYAAAAzTWluaW11bSBudW1iZXIgb2Ygb3B0aW9uYWwgRFZOcyByZXF1aXJlZCB0byB2ZXJpZnkuAAAAABZvcHRpb25hbF9kdm5fdGhyZXNob2xkAAAAAAAEAAAAQExpc3Qgb2YgRFZOIGFkZHJlc3NlcyBmcm9tIHdoaWNoIGEgdGhyZXNob2xkIG51bWJlciBtdXN0IHZlcmlmeS4AAAANb3B0aW9uYWxfZHZucwAAAAAAA+oAAAATAAAARkxpc3Qgb2YgRFZOIGFkZHJlc3NlcyB0aGF0IG11c3QgQUxMIHZlcmlmeSB0aGUgbWVzc2FnZSAobm8gdGhyZXNob2xkKS4AAAAAAA1yZXF1aXJlZF9kdm5zAAAAAAAD6gAAABMAAAABAAAAPE9BcHAtc3BlY2lmaWMgVUxOIGNvbmZpZ3VyYXRpb24gd2l0aCBkZWZhdWx0IG92ZXJyaWRlIGZsYWdzLgAAAAAAAAANT0FwcFVsbkNvbmZpZwAAAAAAAAQAAABFT0FwcC1zcGVjaWZpYyBVTE4gY29uZmlndXJhdGlvbiAodXNlZCB3aGVuIGRlZmF1bHRzIGFyZSBub3QgYXBwbGllZCkuAAAAAAAACnVsbl9jb25maWcAAAAAB9AAAAAJVWxuQ29uZmlnAAAAAAAAJVdoZXRoZXIgdG8gdXNlIGRlZmF1bHQgY29uZmlybWF0aW9ucy4AAAAAAAAZdXNlX2RlZmF1bHRfY29uZmlybWF0aW9ucwAAAAAAAAEAAAAlV2hldGhlciB0byB1c2UgZGVmYXVsdCBvcHRpb25hbCBEVk5zLgAAAAAAABl1c2VfZGVmYXVsdF9vcHRpb25hbF9kdm5zAAAAAAAAAQAAACVXaGV0aGVyIHRvIHVzZSBkZWZhdWx0IHJlcXVpcmVkIERWTnMuAAAAAAAAGXVzZV9kZWZhdWx0X3JlcXVpcmVkX2R2bnMAAAAAAAABAAAAAQAAAFJQYXJhbWV0ZXIgZm9yIHNldHRpbmcgZGVmYXVsdCBVTE4gY29uZmlndXJhdGlvbiBmb3IgYSBkZXN0aW5hdGlvbi9zb3VyY2UgZW5kcG9pbnQuAAAAAAAAAAAAGFNldERlZmF1bHRVbG5Db25maWdQYXJhbQAAAAIAAAAoVGhlIFVMTiBjb25maWd1cmF0aW9uIHRvIHNldCBhcyBkZWZhdWx0LgAAAAZjb25maWcAAAAAB9AAAAAJVWxuQ29uZmlnAAAAAAAAS1RoZSBkZXN0aW5hdGlvbiBlbmRwb2ludCBJRCAoZm9yIHNlbmQpIG9yIHNvdXJjZSBlbmRwb2ludCBJRCAoZm9yIHJlY2VpdmUpLgAAAAADZWlkAAAAAAQAAAABAAAALEV4ZWN1dG9yIGNvbmZpZ3VyYXRpb24gZm9yIG1lc3NhZ2UgZGVsaXZlcnkuAAAAAAAAAA5FeGVjdXRvckNvbmZpZwAAAAAAAgAAAENBZGRyZXNzIG9mIHRoZSBleGVjdXRvciBjb250cmFjdCByZXNwb25zaWJsZSBmb3IgbWVzc2FnZSBleGVjdXRpb24uAAAAAAhleGVjdXRvcgAAABMAAAA5TWF4aW11bSBzaXplIG9mIG1lc3NhZ2VzIHRoYXQgY2FuIGJlIGV4ZWN1dGVkIChpbiBieXRlcykuAAAAAAAAEG1heF9tZXNzYWdlX3NpemUAAAAEAAAAAQAAAFtPQXBwLXNwZWNpZmljIGV4ZWN1dG9yIGNvbmZpZ3VyYXRpb24uCgpJZiBleGVjdXRvciBpcyBgTm9uZWAsIHRoZSBkZWZhdWx0IGV4ZWN1dG9yIGlzIHVzZWQuAAAAAAAAAAAST0FwcEV4ZWN1dG9yQ29uZmlnAAAAAAACAAAAaEFkZHJlc3Mgb2YgdGhlIGV4ZWN1dG9yIGNvbnRyYWN0IHRvIGJlIHVzZWQgZm9yIG1lc3NhZ2UgZXhlY3V0aW9uLiBOb25lIG1lYW5zIHVzZSBkZWZhdWx0IGNvbmZpZ3VyYXRpb24uAAAACGV4ZWN1dG9yAAAD6AAAABMAAABcTWF4aW11bSBzaXplIG9mIG1lc3NhZ2VzIHRoYXQgY2FuIGJlIGV4ZWN1dGVkIChpbiBieXRlcykuIDAgbWVhbnMgdXNlIGRlZmF1bHQgY29uZmlndXJhdGlvbi4AAAAQbWF4X21lc3NhZ2Vfc2l6ZQAAAAQAAAABAAAAUFBhcmFtZXRlciBmb3Igc2V0dGluZyBkZWZhdWx0IGV4ZWN1dG9yIGNvbmZpZ3VyYXRpb24gZm9yIGEgZGVzdGluYXRpb24gZW5kcG9pbnQuAAAAAAAAAB1TZXREZWZhdWx0RXhlY3V0b3JDb25maWdQYXJhbQAAAAAAAAIAAAAtVGhlIGV4ZWN1dG9yIGNvbmZpZ3VyYXRpb24gdG8gc2V0IGFzIGRlZmF1bHQuAAAAAAAABmNvbmZpZwAAAAAH0AAAAA5FeGVjdXRvckNvbmZpZwAAAAAAHFRoZSBkZXN0aW5hdGlvbiBlbmRwb2ludCBJRC4AAAAHZHN0X2VpZAAAAAAEAAAABAAAABxCdWZmZXJSZWFkZXJFcnJvcjogMTAwMC0xMDA5AAAAAAAAABFCdWZmZXJSZWFkZXJFcnJvcgAAAAAAAAIAAAAAAAAADUludmFsaWRMZW5ndGgAAAAAAAPoAAAAAAAAABVJbnZhbGlkQWRkcmVzc1BheWxvYWQAAAAAAAPpAAAABAAAABxCdWZmZXJXcml0ZXJFcnJvcjogMTAxMC0xMDE5AAAAAAAAABFCdWZmZXJXcml0ZXJFcnJvcgAAAAAAAAEAAAAAAAAAFUludmFsaWRBZGRyZXNzUGF5bG9hZAAAAAAAA/IAAAAEAAAAH1R0bENvbmZpZ3VyYWJsZUVycm9yOiAxMDIwLTEwMjkAAAAAAAAAABRUdGxDb25maWd1cmFibGVFcnJvcgAAAAMAAAAAAAAAEEludmFsaWRUdGxDb25maWcAAAP8AAAAAAAAAA9UdGxDb25maWdGcm96ZW4AAAAD/QAAAAAAAAAWVHRsQ29uZmlnQWxyZWFkeUZyb3plbgAAAAAD/gAAAAQAAAAXT3duYWJsZUVycm9yOiAxMDMwLTEwMzkAAAAAAAAAAAxPd25hYmxlRXJyb3IAAAAGAAAAAAAAABNJbnZhbGlkUGVuZGluZ093bmVyAAAABAYAAAAAAAAACkludmFsaWRUdGwAAAAABAcAAAAAAAAAEU5vUGVuZGluZ1RyYW5zZmVyAAAAAAAECAAAAAAAAAAPT3duZXJBbHJlYWR5U2V0AAAABAkAAAAAAAAAC093bmVyTm90U2V0AAAABAoAAAAAAAAAElRyYW5zZmVySW5Qcm9ncmVzcwAAAAAECwAAAAQAAAAYQnl0ZXNFeHRFcnJvcjogMTA0MC0xMDQ5AAAAAAAAAA1CeXRlc0V4dEVycm9yAAAAAAAAAQAAAAAAAAAOTGVuZ3RoTWlzbWF0Y2gAAAAABBAAAAAEAAAAG1VwZ3JhZGVhYmxlRXJyb3I6IDEwNTAtMTA1OQAAAAAAAAAAEFVwZ3JhZGVhYmxlRXJyb3IAAAADAAAAAAAAABRJbnZhbGlkTWlncmF0aW9uRGF0YQAABBoAAAAAAAAAE01pZ3JhdGlvbk5vdEFsbG93ZWQAAAAEGwAAAAAAAAAOVXBncmFkZXNGcm96ZW4AAAAABBwAAAAEAAAAGE11bHRpc2lnRXJyb3I6IDEwNjAtMTA2OQAAAAAAAAANTXVsdGlzaWdFcnJvcgAAAAAAAAgAAAAAAAAAEkFscmVhZHlJbml0aWFsaXplZAAAAAAEJAAAAAAAAAANSW52YWxpZFNpZ25lcgAAAAAABCUAAAAAAAAADlNpZ25hdHVyZUVycm9yAAAAAAQmAAAAAAAAABNTaWduZXJBbHJlYWR5RXhpc3RzAAAABCcAAAAAAAAADlNpZ25lck5vdEZvdW5kAAAAAAQoAAAAAAAAAB1Ub3RhbFNpZ25lcnNMZXNzVGhhblRocmVzaG9sZAAAAAAABCkAAAAAAAAAD1Vuc29ydGVkU2lnbmVycwAAAAQqAAAAAAAAAA1aZXJvVGhyZXNob2xkAAAAAAAEKwAAAAUAAAAwRXZlbnQgZW1pdHRlZCB3aGVuIGEgc2lnbmVyIGlzIGFkZGVkIG9yIHJlbW92ZWQuAAAAAAAAAAlTaWduZXJTZXQAAAAAAAABAAAACnNpZ25lcl9zZXQAAAAAAAIAAAAAAAAABnNpZ25lcgAAAAAD7gAAABQAAAABAAAAAAAAAAZhY3RpdmUAAAAAAAEAAAAAAAAAAgAAAAUAAAA2RXZlbnQgZW1pdHRlZCB3aGVuIHRoZSBzaWduYXR1cmUgdGhyZXNob2xkIGlzIGNoYW5nZWQuAAAAAAAAAAAADFRocmVzaG9sZFNldAAAAAEAAAANdGhyZXNob2xkX3NldAAAAAAAAAEAAAAAAAAACXRocmVzaG9sZAAAAAAAAAQAAAAAAAAAAgAAAAIAAAAAAAAAAAAAAA9NdWx0aXNpZ1N0b3JhZ2UAAAAAAgAAAAAAAAAAAAAAB1NpZ25lcnMAAAAAAAAAAAAAAAAJVGhyZXNob2xkAAAAAAAABQAAAFdFdmVudCBlbWl0dGVkIHdoZW4gb3duZXJzaGlwIGlzIHRyYW5zZmVycmVkIChib3RoIHNpbmdsZS1zdGVwIGFuZCB0d28tc3RlcCBjb21wbGV0aW9uKS4AAAAAAAAAABRPd25lcnNoaXBUcmFuc2ZlcnJlZAAAAAEAAAAVb3duZXJzaGlwX3RyYW5zZmVycmVkAAAAAAAAAgAAAAAAAAAJb2xkX293bmVyAAAAAAAAEwAAAAAAAAAAAAAACW5ld19vd25lcgAAAAAAABMAAAAAAAAAAgAAAAUAAAA7RXZlbnQgZW1pdHRlZCB3aGVuIGEgMi1zdGVwIG93bmVyc2hpcCB0cmFuc2ZlciBpcyBwcm9wb3NlZC4AAAAAAAAAABVPd25lcnNoaXBUcmFuc2ZlcnJpbmcAAAAAAAABAAAAFm93bmVyc2hpcF90cmFuc2ZlcnJpbmcAAAAAAAMAAAAAAAAACW9sZF9vd25lcgAAAAAAABMAAAAAAAAAAAAAAAluZXdfb3duZXIAAAAAAAATAAAAAAAAAAAAAAADdHRsAAAAAAQAAAAAAAAAAgAAAAUAAAAqRXZlbnQgZW1pdHRlZCB3aGVuIG93bmVyc2hpcCBpcyByZW5vdW5jZWQuAAAAAAAAAAAAEk93bmVyc2hpcFJlbm91bmNlZAAAAAAAAQAAABNvd25lcnNoaXBfcmVub3VuY2VkAAAAAAEAAAAAAAAACW9sZF9vd25lcgAAAAAAABMAAAAAAAAAAgAAAAIAAAAAAAAAAAAAAA5Pd25hYmxlU3RvcmFnZQAAAAAAAgAAAAAAAAAAAAAABU93bmVyAAAAAAAAAAAAAAAAAAAMUGVuZGluZ093bmVyAAAAAQAAAElUVEwgY29uZmlndXJhdGlvbjogdGhyZXNob2xkICh3aGVuIHRvIGV4dGVuZCkgYW5kIGV4dGVuZF90byAodGFyZ2V0IFRUTCkuAAAAAAAAAAAAAAlUdGxDb25maWcAAAAAAAACAAAAKFRhcmdldCBUVEwgYWZ0ZXIgZXh0ZW5zaW9uIChpbiBsZWRnZXJzKS4AAAAJZXh0ZW5kX3RvAAAAAAAABAAAADNUVEwgdGhyZXNob2xkIHRoYXQgdHJpZ2dlcnMgZXh0ZW5zaW9uIChpbiBsZWRnZXJzKS4AAAAACXRocmVzaG9sZAAAAAAAAAQAAAAFAAAAJ0V2ZW50IGVtaXR0ZWQgd2hlbiBUVEwgY29uZmlncyBhcmUgc2V0LgAAAAAAAAAADVR0bENvbmZpZ3NTZXQAAAAAAAABAAAAD3R0bF9jb25maWdzX3NldAAAAAACAAAAAAAAAAhpbnN0YW5jZQAAA+gAAAfQAAAACVR0bENvbmZpZwAAAAAAAAAAAAAAAAAACnBlcnNpc3RlbnQAAAAAA+gAAAfQAAAACVR0bENvbmZpZwAAAAAAAAAAAAACAAAABQAAACpFdmVudCBlbWl0dGVkIHdoZW4gVFRMIGNvbmZpZ3MgYXJlIGZyb3plbi4AAAAAAAAAAAAQVHRsQ29uZmlnc0Zyb3plbgAAAAEAAAASdHRsX2NvbmZpZ3NfZnJvemVuAAAAAAAAAAAAAgAAAAIAAAAAAAAAAAAAABBUdGxDb25maWdTdG9yYWdlAAAAAwAAAAAAAAAAAAAABkZyb3plbgAAAAAAAAAAAAAAAAAISW5zdGFuY2UAAAAAAAAAAAAAAApQZXJzaXN0ZW50AAAAAAACAAAAAAAAAAAAAAASVXBncmFkZWFibGVTdG9yYWdlAAAAAAACAAAAAAAAAAAAAAAGRnJvemVuAAAAAAAAAAAAAAAAAAlNaWdyYXRpbmcAAAAAiwEOY29udHJhY3RtZXRhdjAAAAAAAAAABmJpbnZlcgAAAAAABTAuMC4xAAAAAAAAAAAAAAVyc3ZlcgAAAAAAAAYxLjkwLjAAAAAAAAAAAAAIcnNzZGt2ZXIAAAAvMjUuMC4xIzk0MTQ0ODA3OWVjY2Y5NTYyN2QyZmZlYTEzYmEyNjhlMzA1YTkwNzcAAB4RY29udHJhY3RlbnZtZXRhdjAAAAAAAAAAGQAAAAAAUw5jb250cmFjdG1ldGF2MAAAAAAAAAAGY2xpdmVyAAAAAAAvMjUuMC4wI2E2NDkyNWU5MzkxYzNkM2IzZWY4ZTUzZGM2MGMyM2RiOWU2YTgyZTQA";
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 = "f98131c421cf42155df337d9d65de113f3dcd82c9546edbb1cdc2aaa51a930f9";
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 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.
719
+ * The type of data required for migration.
720
+ * Upgrades the contract to new WASM bytecode.
721
+ * Sets a migration flag that must be cleared by calling `migrate`.
722
+ */
723
+ upgrade: ({ new_wasm_hash }: {
724
+ new_wasm_hash: Buffer;
725
+ }, txnOptions?: {
726
+ /**
727
+ * The fee to pay for the transaction. Default: BASE_FEE
728
+ */
729
+ fee?: number;
730
+ /**
731
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
732
+ */
733
+ timeoutInSeconds?: number;
734
+ /**
735
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
736
+ */
737
+ simulate?: boolean;
738
+ }) => Promise<AssembledTransaction<null>>;
739
+ /**
740
+ * 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.
741
+ * Runs migration logic after an upgrade.
742
+ * Can only be called when the migration flag is set by a previous `upgrade` call.
743
+ */
744
+ migrate: ({ migration_data }: {
745
+ migration_data: Buffer;
746
+ }, txnOptions?: {
747
+ /**
748
+ * The fee to pay for the transaction. Default: BASE_FEE
749
+ */
750
+ fee?: number;
751
+ /**
752
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
753
+ */
754
+ timeoutInSeconds?: number;
755
+ /**
756
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
757
+ */
758
+ simulate?: boolean;
759
+ }) => Promise<AssembledTransaction<null>>;
760
+ /**
761
+ * 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.
762
+ * Permanently freezes the contract, preventing any future upgrades.
763
+ * This action is irreversible.
764
+ */
765
+ freeze: (txnOptions?: {
766
+ /**
767
+ * The fee to pay for the transaction. Default: BASE_FEE
768
+ */
769
+ fee?: number;
770
+ /**
771
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
772
+ */
773
+ timeoutInSeconds?: number;
774
+ /**
775
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
776
+ */
777
+ simulate?: boolean;
778
+ }) => Promise<AssembledTransaction<null>>;
779
+ /**
780
+ * 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.
781
+ * Returns whether the contract is frozen (upgrades disabled).
782
+ */
783
+ is_frozen: (txnOptions?: {
784
+ /**
785
+ * The fee to pay for the transaction. Default: BASE_FEE
786
+ */
787
+ fee?: number;
788
+ /**
789
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
790
+ */
791
+ timeoutInSeconds?: number;
792
+ /**
793
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
794
+ */
795
+ simulate?: boolean;
796
+ }) => Promise<AssembledTransaction<boolean>>;
797
+ /**
798
+ * 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.
799
+ */
800
+ authorizer: (txnOptions?: {
801
+ /**
802
+ * The fee to pay for the transaction. Default: BASE_FEE
803
+ */
804
+ fee?: number;
805
+ /**
806
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
807
+ */
808
+ timeoutInSeconds?: number;
809
+ /**
810
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
811
+ */
812
+ simulate?: boolean;
813
+ }) => Promise<AssembledTransaction<string>>;
814
+ /**
815
+ * 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.
816
+ * Returns the current owner address, or None if no owner is set.
817
+ */
818
+ owner: (txnOptions?: {
819
+ /**
820
+ * The fee to pay for the transaction. Default: BASE_FEE
821
+ */
822
+ fee?: number;
823
+ /**
824
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
825
+ */
826
+ timeoutInSeconds?: number;
827
+ /**
828
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
829
+ */
830
+ simulate?: boolean;
831
+ }) => Promise<AssembledTransaction<Option<string>>>;
832
+ /**
833
+ * 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.
834
+ * Returns the pending owner address for 2-step transfer, or None if no transfer is pending.
835
+ */
836
+ pending_owner: (txnOptions?: {
837
+ /**
838
+ * The fee to pay for the transaction. Default: BASE_FEE
839
+ */
840
+ fee?: number;
841
+ /**
842
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
843
+ */
844
+ timeoutInSeconds?: number;
845
+ /**
846
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
847
+ */
848
+ simulate?: boolean;
849
+ }) => Promise<AssembledTransaction<Option<string>>>;
850
+ /**
851
+ * 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.
852
+ * Transfers ownership immediately to a new address.
853
+ *
854
+ * Use with caution - if you transfer to a wrong address, ownership is lost forever.
855
+ * Consider using `propose_ownership_transfer` instead.
856
+ *
857
+ * # Panics
858
+ * - `OwnerNotSet` if no owner is currently set
859
+ * - `TransferInProgress` if a 2-step transfer is in progress
860
+ */
861
+ transfer_ownership: ({ new_owner }: {
862
+ new_owner: string;
863
+ }, txnOptions?: {
864
+ /**
865
+ * The fee to pay for the transaction. Default: BASE_FEE
866
+ */
867
+ fee?: number;
868
+ /**
869
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
870
+ */
871
+ timeoutInSeconds?: number;
872
+ /**
873
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
874
+ */
875
+ simulate?: boolean;
876
+ }) => Promise<AssembledTransaction<null>>;
877
+ /**
878
+ * 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.
879
+ * Proposes an ownership transfer to a new address.
880
+ *
881
+ * The new owner must call `accept_ownership()` within `ttl` ledgers
882
+ * to complete the transfer. The pending transfer will automatically expire after.
883
+ *
884
+ * # Arguments
885
+ * - `new_owner` - The proposed new owner
886
+ * - `ttl` - Number of ledgers the new owner has to accept.
887
+ * Use `0` to cancel a pending transfer (new_owner must match pending).
888
+ *
889
+ * # Panics
890
+ * - `OwnerNotSet` if no owner is currently set
891
+ * - `NoPendingTransfer` when cancelling and no pending transfer exists
892
+ * - `InvalidTtl` if ttl exceeds max TTL
893
+ * - `InvalidPendingOwner` when cancelling with wrong new_owner address
894
+ */
895
+ propose_ownership_transfer: ({ new_owner, ttl }: {
896
+ new_owner: string;
897
+ ttl: u32;
898
+ }, txnOptions?: {
899
+ /**
900
+ * The fee to pay for the transaction. Default: BASE_FEE
901
+ */
902
+ fee?: number;
903
+ /**
904
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
905
+ */
906
+ timeoutInSeconds?: number;
907
+ /**
908
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
909
+ */
910
+ simulate?: boolean;
911
+ }) => Promise<AssembledTransaction<null>>;
912
+ /**
913
+ * 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.
914
+ * Accepts a pending 2-step ownership transfer.
915
+ *
916
+ * Must be called by the pending owner before the TTL expires.
917
+ *
918
+ * # Panics
919
+ * - `NoPendingTransfer` if there is no pending transfer (or it expired)
920
+ */
921
+ accept_ownership: (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<null>>;
935
+ /**
936
+ * 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.
937
+ * Permanently renounces ownership.
938
+ *
939
+ * # Panics
940
+ * - `OwnerNotSet` if no owner is currently set
941
+ * - `TransferInProgress` if a 2-step transfer is in progress (cancel it first)
942
+ */
943
+ renounce_ownership: (txnOptions?: {
944
+ /**
945
+ * The fee to pay for the transaction. Default: BASE_FEE
946
+ */
947
+ fee?: number;
948
+ /**
949
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
950
+ */
951
+ timeoutInSeconds?: number;
952
+ /**
953
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
954
+ */
955
+ simulate?: boolean;
956
+ }) => Promise<AssembledTransaction<null>>;
957
+ /**
958
+ * 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.
959
+ * Extends the instance TTL.
960
+ *
961
+ * # Arguments
962
+ *
963
+ * * `threshold` - The threshold to extend the TTL (if current TTL is below this, extend).
964
+ * * `extend_to` - The TTL to extend to.
965
+ */
966
+ extend_instance_ttl: ({ threshold, extend_to }: {
967
+ threshold: u32;
968
+ extend_to: u32;
969
+ }, txnOptions?: {
970
+ /**
971
+ * The fee to pay for the transaction. Default: BASE_FEE
972
+ */
973
+ fee?: number;
974
+ /**
975
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
976
+ */
977
+ timeoutInSeconds?: number;
978
+ /**
979
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
980
+ */
981
+ simulate?: boolean;
982
+ }) => Promise<AssembledTransaction<null>>;
983
+ /**
984
+ * 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.
985
+ * Sets TTL configs for instance and persistent storage.
986
+ *
987
+ * - `None` values remove the corresponding config (disables auto-extension for that type)
988
+ * - Validates that `threshold <= extend_to <= MAX_TTL`
989
+ *
990
+ * # Arguments
991
+ * - `instance` - TTL config for instance storage
992
+ * - `persistent` - TTL config for persistent storage
993
+ *
994
+ * # Panics
995
+ * - `TtlConfigFrozen` if configs are frozen
996
+ * - `InvalidTtlConfig` if validation fails
997
+ */
998
+ set_ttl_configs: ({ instance, persistent }: {
999
+ instance: Option<TtlConfig>;
1000
+ persistent: Option<TtlConfig>;
1001
+ }, txnOptions?: {
1002
+ /**
1003
+ * The fee to pay for the transaction. Default: BASE_FEE
1004
+ */
1005
+ fee?: number;
1006
+ /**
1007
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1008
+ */
1009
+ timeoutInSeconds?: number;
1010
+ /**
1011
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1012
+ */
1013
+ simulate?: boolean;
1014
+ }) => Promise<AssembledTransaction<null>>;
1015
+ /**
1016
+ * 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.
1017
+ * Returns the current TTL configs as (instance_config, persistent_config).
1018
+ */
1019
+ ttl_configs: (txnOptions?: {
1020
+ /**
1021
+ * The fee to pay for the transaction. Default: BASE_FEE
1022
+ */
1023
+ fee?: number;
1024
+ /**
1025
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1026
+ */
1027
+ timeoutInSeconds?: number;
1028
+ /**
1029
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1030
+ */
1031
+ simulate?: boolean;
1032
+ }) => Promise<AssembledTransaction<readonly [Option<TtlConfig>, Option<TtlConfig>]>>;
1033
+ /**
1034
+ * 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.
1035
+ * Permanently freezes TTL configs, preventing any future modifications.
1036
+ *
1037
+ * This is irreversible and provides immutability guarantees to users.
1038
+ * Emits `TtlConfigsFrozen` event.
1039
+ *
1040
+ * # Panics
1041
+ * - `TtlConfigAlreadyFrozen` if already frozen
1042
+ */
1043
+ freeze_ttl_configs: (txnOptions?: {
1044
+ /**
1045
+ * The fee to pay for the transaction. Default: BASE_FEE
1046
+ */
1047
+ fee?: number;
1048
+ /**
1049
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1050
+ */
1051
+ timeoutInSeconds?: number;
1052
+ /**
1053
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1054
+ */
1055
+ simulate?: boolean;
1056
+ }) => Promise<AssembledTransaction<null>>;
1057
+ /**
1058
+ * 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.
1059
+ * Returns whether TTL configs are frozen.
1060
+ */
1061
+ is_ttl_configs_frozen: (txnOptions?: {
1062
+ /**
1063
+ * The fee to pay for the transaction. Default: BASE_FEE
1064
+ */
1065
+ fee?: number;
1066
+ /**
1067
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1068
+ */
1069
+ timeoutInSeconds?: number;
1070
+ /**
1071
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1072
+ */
1073
+ simulate?: boolean;
1074
+ }) => Promise<AssembledTransaction<boolean>>;
1075
+ /**
1076
+ * 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.
1077
+ * Returns the endpoint address.
1078
+ */
1079
+ endpoint: (txnOptions?: {
1080
+ /**
1081
+ * The fee to pay for the transaction. Default: BASE_FEE
1082
+ */
1083
+ fee?: number;
1084
+ /**
1085
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1086
+ */
1087
+ timeoutInSeconds?: number;
1088
+ /**
1089
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1090
+ */
1091
+ simulate?: boolean;
1092
+ }) => Promise<AssembledTransaction<string>>;
1093
+ /**
1094
+ * 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.
1095
+ * Returns the Uln302 address.
1096
+ */
1097
+ uln302: (txnOptions?: {
1098
+ /**
1099
+ * The fee to pay for the transaction. Default: BASE_FEE
1100
+ */
1101
+ fee?: number;
1102
+ /**
1103
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1104
+ */
1105
+ timeoutInSeconds?: number;
1106
+ /**
1107
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1108
+ */
1109
+ simulate?: boolean;
1110
+ }) => Promise<AssembledTransaction<string>>;
1111
+ /**
1112
+ * 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.
1113
+ * Returns the local endpoint ID.
1114
+ */
1115
+ local_eid: (txnOptions?: {
1116
+ /**
1117
+ * The fee to pay for the transaction. Default: BASE_FEE
1118
+ */
1119
+ fee?: number;
1120
+ /**
1121
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1122
+ */
1123
+ timeoutInSeconds?: number;
1124
+ /**
1125
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1126
+ */
1127
+ simulate?: boolean;
1128
+ }) => Promise<AssembledTransaction<u32>>;
1129
+ /**
1130
+ * 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.
1131
+ * Checks if a messaging path can be initialized for the given origin and receiver.
1132
+ */
1133
+ initializable: ({ origin, receiver }: {
1134
+ origin: Origin;
1135
+ receiver: string;
1136
+ }, txnOptions?: {
1137
+ /**
1138
+ * The fee to pay for the transaction. Default: BASE_FEE
1139
+ */
1140
+ fee?: number;
1141
+ /**
1142
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1143
+ */
1144
+ timeoutInSeconds?: number;
1145
+ /**
1146
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1147
+ */
1148
+ simulate?: boolean;
1149
+ }) => Promise<AssembledTransaction<boolean>>;
1150
+ /**
1151
+ * 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.
1152
+ * Checks if a message can be verified at the endpoint.
1153
+ *
1154
+ * Verifies:
1155
+ * 1. Receive library is valid for this receiver and source
1156
+ * 2. Endpoint nonce check passes
1157
+ * 3. Payload hash is not empty
1158
+ */
1159
+ verifiable: ({ origin, receiver, receive_lib, payload_hash }: {
1160
+ origin: Origin;
1161
+ receiver: string;
1162
+ receive_lib: string;
1163
+ payload_hash: Buffer;
1164
+ }, txnOptions?: {
1165
+ /**
1166
+ * The fee to pay for the transaction. Default: BASE_FEE
1167
+ */
1168
+ fee?: number;
1169
+ /**
1170
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1171
+ */
1172
+ timeoutInSeconds?: number;
1173
+ /**
1174
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1175
+ */
1176
+ simulate?: boolean;
1177
+ }) => Promise<AssembledTransaction<boolean>>;
1178
+ /**
1179
+ * 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.
1180
+ * Returns the execution state of a message.
1181
+ */
1182
+ executable: ({ origin, receiver }: {
1183
+ origin: Origin;
1184
+ receiver: string;
1185
+ }, txnOptions?: {
1186
+ /**
1187
+ * The fee to pay for the transaction. Default: BASE_FEE
1188
+ */
1189
+ fee?: number;
1190
+ /**
1191
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1192
+ */
1193
+ timeoutInSeconds?: number;
1194
+ /**
1195
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1196
+ */
1197
+ simulate?: boolean;
1198
+ }) => Promise<AssembledTransaction<ExecutionState>>;
1199
+ /**
1200
+ * 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.
1201
+ * Returns the combined verification state of a message.
1202
+ *
1203
+ * This function checks:
1204
+ * 1. Packet header validity (dst_eid matches local_eid)
1205
+ * 2. Endpoint initializable status
1206
+ * 3. Endpoint verifiable status
1207
+ * 4. ULN verifiable status (DVN confirmations)
1208
+ */
1209
+ uln_verifiable: ({ packet_header, payload_hash }: {
1210
+ packet_header: Buffer;
1211
+ payload_hash: Buffer;
1212
+ }, 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<VerificationState>>;
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
+ upgrade: (json: string) => AssembledTransaction<null>;
1248
+ migrate: (json: string) => AssembledTransaction<null>;
1249
+ freeze: (json: string) => AssembledTransaction<null>;
1250
+ is_frozen: (json: string) => AssembledTransaction<boolean>;
1251
+ authorizer: (json: string) => AssembledTransaction<string>;
1252
+ owner: (json: string) => AssembledTransaction<Option<string>>;
1253
+ pending_owner: (json: string) => AssembledTransaction<Option<string>>;
1254
+ transfer_ownership: (json: string) => AssembledTransaction<null>;
1255
+ propose_ownership_transfer: (json: string) => AssembledTransaction<null>;
1256
+ accept_ownership: (json: string) => AssembledTransaction<null>;
1257
+ renounce_ownership: (json: string) => AssembledTransaction<null>;
1258
+ extend_instance_ttl: (json: string) => AssembledTransaction<null>;
1259
+ set_ttl_configs: (json: string) => AssembledTransaction<null>;
1260
+ ttl_configs: (json: string) => AssembledTransaction<readonly [Option<TtlConfig>, Option<TtlConfig>]>;
1261
+ freeze_ttl_configs: (json: string) => AssembledTransaction<null>;
1262
+ is_ttl_configs_frozen: (json: string) => AssembledTransaction<boolean>;
1263
+ endpoint: (json: string) => AssembledTransaction<string>;
1264
+ uln302: (json: string) => AssembledTransaction<string>;
1265
+ local_eid: (json: string) => AssembledTransaction<number>;
1266
+ initializable: (json: string) => AssembledTransaction<boolean>;
1267
+ verifiable: (json: string) => AssembledTransaction<boolean>;
1268
+ executable: (json: string) => AssembledTransaction<ExecutionState>;
1269
+ uln_verifiable: (json: string) => AssembledTransaction<VerificationState>;
1270
+ };
1271
+ }