@layerzerolabs/protocol-stellar-v2 0.2.18 → 0.2.20

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (213) hide show
  1. package/.turbo/turbo-build.log +303 -253
  2. package/.turbo/turbo-lint.log +66 -65
  3. package/.turbo/turbo-test.log +1312 -1282
  4. package/Cargo.lock +21 -8
  5. package/Cargo.toml +2 -0
  6. package/contracts/ERROR_SPEC.md +9 -2
  7. package/contracts/common-macros/src/contract_ttl.rs +18 -7
  8. package/contracts/common-macros/src/lib.rs +4 -4
  9. package/contracts/common-macros/src/tests/contract_ttl.rs +1 -1
  10. package/contracts/common-macros/src/tests/snapshots/common_macros__tests__contract_ttl__snapshot_generated_contractimpl_code.snap +2 -1
  11. package/contracts/common-macros/src/tests/snapshots/common_macros__tests__upgradeable__snapshot_generated_upgradeable_code.snap +7 -12
  12. package/contracts/common-macros/src/upgradeable.rs +15 -21
  13. package/contracts/message-libs/uln-302/src/events.rs +4 -0
  14. package/contracts/message-libs/uln-302/src/send_uln.rs +23 -7
  15. package/contracts/message-libs/uln-302/src/tests/send_uln302/send.rs +38 -64
  16. package/contracts/oapps/counter/Cargo.toml +1 -0
  17. package/contracts/oapps/counter/integration_tests/setup_uln.rs +1 -1
  18. package/contracts/oapps/oapp/src/oapp_receiver.rs +1 -1
  19. package/contracts/oapps/oapp/src/tests/test_oapp_core.rs +113 -65
  20. package/contracts/oapps/oapp/src/tests/test_oapp_options_type3.rs +111 -82
  21. package/contracts/oapps/oapp/src/tests/test_oapp_receiver.rs +293 -65
  22. package/contracts/oapps/oapp/src/tests/test_oapp_sender.rs +331 -56
  23. package/contracts/oapps/oft/Cargo.toml +10 -7
  24. package/contracts/oapps/{oft-std → oft}/integration-tests/extensions/test_oft_fee.rs +3 -4
  25. package/contracts/oapps/{oft-std → oft}/integration-tests/extensions/test_pausable.rs +2 -3
  26. package/contracts/oapps/{oft-std → oft}/integration-tests/extensions/test_rate_limiter.rs +1 -1
  27. package/contracts/oapps/oft/integration-tests/mod.rs +1 -1
  28. package/contracts/oapps/oft/integration-tests/setup.rs +28 -127
  29. package/contracts/oapps/oft/integration-tests/utils.rs +254 -21
  30. package/contracts/oapps/oft/src/extensions/oft_fee.rs +23 -8
  31. package/contracts/oapps/oft/src/extensions/pausable.rs +19 -4
  32. package/contracts/oapps/oft/src/extensions/rate_limiter.rs +52 -28
  33. package/contracts/oapps/oft/src/lib.rs +10 -14
  34. package/contracts/oapps/oft/src/oft.rs +143 -193
  35. package/contracts/oapps/oft/src/oft_types/lock_unlock.rs +9 -11
  36. package/contracts/oapps/oft/src/oft_types/mint_burn.rs +12 -14
  37. package/contracts/oapps/oft/src/oft_types/mod.rs +13 -0
  38. package/contracts/oapps/{oft-std → oft-core}/Cargo.toml +6 -4
  39. package/contracts/oapps/{oft-std → oft-core}/integration-tests/mod.rs +1 -1
  40. package/contracts/oapps/{oft-std → oft-core}/integration-tests/setup.rs +126 -29
  41. package/contracts/oapps/{oft → oft-core}/integration-tests/test_with_sml.rs +3 -3
  42. package/contracts/oapps/oft-core/integration-tests/utils.rs +201 -0
  43. package/contracts/oapps/oft-core/src/lib.rs +18 -0
  44. package/contracts/oapps/oft-core/src/oft_core.rs +479 -0
  45. package/contracts/oapps/{oft → oft-core}/src/tests/mod.rs +0 -2
  46. package/contracts/oapps/{oft → oft-core}/src/tests/test_lz_receive.rs +7 -7
  47. package/contracts/oapps/{oft → oft-core}/src/tests/test_oft_msg_codec.rs +4 -4
  48. package/contracts/oapps/{oft → oft-core}/src/tests/test_resolve_address.rs +3 -3
  49. package/contracts/oapps/{oft → oft-core}/src/tests/test_utils.rs +46 -27
  50. package/contracts/oapps/{oft → oft-core}/src/utils.rs +1 -1
  51. package/contracts/upgrader/src/lib.rs +30 -57
  52. package/contracts/upgrader/src/tests/test_data/test_upgradeable_contract1.wasm +0 -0
  53. package/contracts/upgrader/src/tests/test_data/test_upgradeable_contract2.wasm +0 -0
  54. package/contracts/upgrader/src/tests/test_upgrader.rs +44 -35
  55. package/contracts/utils/src/buffer_reader.rs +1 -0
  56. package/contracts/utils/src/errors.rs +8 -2
  57. package/contracts/utils/src/ownable.rs +125 -3
  58. package/contracts/utils/src/tests/option_ext.rs +1 -1
  59. package/contracts/utils/src/tests/ownable.rs +445 -7
  60. package/contracts/utils/src/tests/ttl_configurable.rs +2 -2
  61. package/contracts/utils/src/tests/upgradeable.rs +372 -175
  62. package/contracts/utils/src/ttl_configurable.rs +3 -3
  63. package/contracts/utils/src/upgradeable.rs +48 -23
  64. package/contracts/workers/dvn/Cargo.toml +1 -0
  65. package/contracts/workers/dvn/src/auth.rs +12 -42
  66. package/contracts/workers/dvn/src/dvn.rs +16 -31
  67. package/contracts/workers/dvn/src/errors.rs +0 -1
  68. package/contracts/workers/dvn/src/interfaces/dvn.rs +35 -0
  69. package/contracts/workers/dvn/src/lib.rs +4 -3
  70. package/contracts/workers/dvn/src/tests/auth.rs +1 -1
  71. package/contracts/workers/dvn/src/tests/dvn.rs +19 -15
  72. package/contracts/workers/dvn/src/tests/multisig/set_threshold.rs +2 -4
  73. package/contracts/workers/dvn/src/tests/multisig/verify_signatures.rs +1 -3
  74. package/contracts/workers/dvn/src/tests/setup.rs +5 -9
  75. package/contracts/workers/dvn-fee-lib/Cargo.toml +1 -1
  76. package/contracts/workers/dvn-fee-lib/src/dvn_fee_lib.rs +3 -5
  77. package/contracts/workers/dvn-fee-lib/src/tests/dvn_fee_lib.rs +2 -3
  78. package/contracts/workers/executor/Cargo.toml +1 -0
  79. package/contracts/workers/executor/src/executor.rs +15 -26
  80. package/contracts/workers/executor-fee-lib/Cargo.toml +2 -1
  81. package/contracts/workers/executor-fee-lib/src/executor_fee_lib.rs +63 -5
  82. package/contracts/workers/executor-fee-lib/src/executor_option.rs +28 -1
  83. package/contracts/workers/executor-fee-lib/src/lib.rs +3 -0
  84. package/contracts/workers/executor-fee-lib/src/tests/executor_fee_lib.rs +701 -0
  85. package/contracts/workers/executor-fee-lib/src/tests/executor_option.rs +370 -0
  86. package/contracts/workers/executor-fee-lib/src/tests/mod.rs +4 -0
  87. package/contracts/workers/executor-fee-lib/src/tests/setup.rs +60 -0
  88. package/contracts/workers/executor-helper/src/lib.rs +3 -0
  89. package/contracts/workers/executor-helper/src/tests/executor_helper.rs +184 -0
  90. package/contracts/workers/executor-helper/src/tests/mod.rs +2 -0
  91. package/contracts/workers/executor-helper/src/tests/setup.rs +366 -0
  92. package/contracts/workers/fee-lib-interfaces/Cargo.toml +14 -0
  93. package/contracts/workers/{worker/src/interfaces/mod.rs → fee-lib-interfaces/src/lib.rs} +4 -3
  94. package/contracts/workers/price-feed/Cargo.toml +2 -1
  95. package/contracts/workers/price-feed/src/events.rs +1 -1
  96. package/contracts/workers/price-feed/src/lib.rs +3 -0
  97. package/contracts/workers/price-feed/src/price_feed.rs +6 -12
  98. package/contracts/workers/price-feed/src/storage.rs +1 -1
  99. package/contracts/workers/price-feed/src/tests/mod.rs +2 -0
  100. package/contracts/workers/price-feed/src/tests/price_feed.rs +869 -0
  101. package/contracts/workers/price-feed/src/tests/setup.rs +70 -0
  102. package/contracts/workers/price-feed/src/types.rs +1 -1
  103. package/contracts/workers/worker/src/errors.rs +0 -3
  104. package/contracts/workers/worker/src/lib.rs +0 -2
  105. package/contracts/workers/worker/src/storage.rs +32 -29
  106. package/contracts/workers/worker/src/tests/setup.rs +1 -7
  107. package/contracts/workers/worker/src/tests/worker.rs +50 -42
  108. package/contracts/workers/worker/src/worker.rs +49 -58
  109. package/package.json +4 -5
  110. package/sdk/.turbo/turbo-test.log +229 -217
  111. package/sdk/dist/generated/bml.d.ts +39 -1
  112. package/sdk/dist/generated/bml.js +33 -8
  113. package/sdk/dist/generated/counter.d.ts +131 -3
  114. package/sdk/dist/generated/counter.js +41 -10
  115. package/sdk/dist/generated/dvn.d.ts +431 -362
  116. package/sdk/dist/generated/dvn.js +80 -55
  117. package/sdk/dist/generated/dvn_fee_lib.d.ts +327 -251
  118. package/sdk/dist/generated/dvn_fee_lib.js +55 -57
  119. package/sdk/dist/generated/endpoint.d.ts +131 -3
  120. package/sdk/dist/generated/endpoint.js +41 -10
  121. package/sdk/dist/generated/executor.d.ts +503 -339
  122. package/sdk/dist/generated/executor.js +80 -48
  123. package/sdk/dist/generated/executor_fee_lib.d.ts +395 -319
  124. package/sdk/dist/generated/executor_fee_lib.js +54 -56
  125. package/sdk/dist/generated/executor_helper.d.ts +53 -187
  126. package/sdk/dist/generated/executor_helper.js +47 -29
  127. package/sdk/dist/generated/layerzero_view.d.ts +1271 -0
  128. package/sdk/dist/generated/layerzero_view.js +294 -0
  129. package/sdk/dist/generated/oft.d.ts +1851 -0
  130. package/sdk/dist/generated/oft.js +347 -0
  131. package/sdk/dist/generated/price_feed.d.ts +329 -253
  132. package/sdk/dist/generated/price_feed.js +55 -57
  133. package/sdk/dist/generated/sml.d.ts +131 -3
  134. package/sdk/dist/generated/sml.js +41 -10
  135. package/sdk/dist/generated/treasury.d.ts +131 -3
  136. package/sdk/dist/generated/treasury.js +41 -10
  137. package/sdk/dist/generated/uln302.d.ts +131 -3
  138. package/sdk/dist/generated/uln302.js +43 -12
  139. package/sdk/dist/generated/upgrader.d.ts +201 -15
  140. package/sdk/dist/generated/upgrader.js +99 -1
  141. package/sdk/dist/index.d.ts +2 -2
  142. package/sdk/dist/index.js +3 -3
  143. package/sdk/package.json +3 -2
  144. package/sdk/src/index.ts +3 -3
  145. package/sdk/test/oft-sml.test.ts +20 -20
  146. package/sdk/test/upgrader.test.ts +2 -3
  147. package/sdk/turbo.json +8 -0
  148. package/tools/ts-bindings-gen/Cargo.toml +2 -0
  149. package/tools/ts-bindings-gen/src/main.rs +53 -5
  150. package/turbo.json +0 -2
  151. package/contracts/oapps/oft/src/interfaces/mint_burn_token.rs +0 -23
  152. package/contracts/oapps/oft/src/interfaces/mod.rs +0 -3
  153. package/contracts/oapps/oft/src/oft_impl.rs +0 -201
  154. package/contracts/oapps/oft/src/tests/extensions/mod.rs +0 -11
  155. package/contracts/oapps/oft/src/tests/extensions/setup.rs +0 -917
  156. package/contracts/oapps/oft/src/tests/extensions/test_oft_fee.rs +0 -751
  157. package/contracts/oapps/oft/src/tests/extensions/test_pausable.rs +0 -434
  158. package/contracts/oapps/oft/src/tests/extensions/test_rate_limiter.rs +0 -1080
  159. package/contracts/oapps/oft-std/integration-tests/utils.rs +0 -427
  160. package/contracts/oapps/oft-std/src/lib.rs +0 -16
  161. package/contracts/oapps/oft-std/src/oft.rs +0 -174
  162. package/sdk/dist/generated/oft_std.d.ts +0 -1722
  163. package/sdk/dist/generated/oft_std.js +0 -316
  164. package/sdk/dist/wasm/blocked-message-lib.d.ts +0 -1
  165. package/sdk/dist/wasm/blocked-message-lib.js +0 -2
  166. package/sdk/dist/wasm/counter.d.ts +0 -1
  167. package/sdk/dist/wasm/counter.js +0 -2
  168. package/sdk/dist/wasm/dvn-fee-lib.d.ts +0 -1
  169. package/sdk/dist/wasm/dvn-fee-lib.js +0 -2
  170. package/sdk/dist/wasm/dvn.d.ts +0 -1
  171. package/sdk/dist/wasm/dvn.js +0 -2
  172. package/sdk/dist/wasm/endpoint-v2.d.ts +0 -1
  173. package/sdk/dist/wasm/endpoint-v2.js +0 -2
  174. package/sdk/dist/wasm/executor-fee-lib.d.ts +0 -1
  175. package/sdk/dist/wasm/executor-fee-lib.js +0 -2
  176. package/sdk/dist/wasm/executor-helper.d.ts +0 -1
  177. package/sdk/dist/wasm/executor-helper.js +0 -2
  178. package/sdk/dist/wasm/executor.d.ts +0 -1
  179. package/sdk/dist/wasm/executor.js +0 -2
  180. package/sdk/dist/wasm/layerzero-views.d.ts +0 -1
  181. package/sdk/dist/wasm/layerzero-views.js +0 -2
  182. package/sdk/dist/wasm/oft-std.d.ts +0 -1
  183. package/sdk/dist/wasm/oft-std.js +0 -2
  184. package/sdk/dist/wasm/price-feed.d.ts +0 -1
  185. package/sdk/dist/wasm/price-feed.js +0 -2
  186. package/sdk/dist/wasm/simple-message-lib.d.ts +0 -1
  187. package/sdk/dist/wasm/simple-message-lib.js +0 -2
  188. package/sdk/dist/wasm/treasury.d.ts +0 -1
  189. package/sdk/dist/wasm/treasury.js +0 -2
  190. package/sdk/dist/wasm/uln302.d.ts +0 -1
  191. package/sdk/dist/wasm/uln302.js +0 -2
  192. package/sdk/dist/wasm/upgrader.d.ts +0 -1
  193. package/sdk/dist/wasm/upgrader.js +0 -2
  194. package/sdk/dist/wasm.d.ts +0 -15
  195. package/sdk/dist/wasm.js +0 -15
  196. /package/contracts/oapps/{oft-std → oft}/integration-tests/extensions/mod.rs +0 -0
  197. /package/contracts/oapps/{oft → oft-core}/src/codec/mod.rs +0 -0
  198. /package/contracts/oapps/{oft → oft-core}/src/codec/oft_compose_msg_codec.rs +0 -0
  199. /package/contracts/oapps/{oft → oft-core}/src/codec/oft_msg_codec.rs +0 -0
  200. /package/contracts/oapps/{oft → oft-core}/src/errors.rs +0 -0
  201. /package/contracts/oapps/{oft → oft-core}/src/events.rs +0 -0
  202. /package/contracts/oapps/{oft → oft-core}/src/storage.rs +0 -0
  203. /package/contracts/oapps/{oft → oft-core}/src/tests/test_decimals.rs +0 -0
  204. /package/contracts/oapps/{oft → oft-core}/src/tests/test_oft_compose_msg_codec.rs +0 -0
  205. /package/contracts/oapps/{oft → oft-core}/src/tests/test_oft_version.rs +0 -0
  206. /package/contracts/oapps/{oft → oft-core}/src/tests/test_quote_oft.rs +0 -0
  207. /package/contracts/oapps/{oft → oft-core}/src/tests/test_quote_send.rs +0 -0
  208. /package/contracts/oapps/{oft → oft-core}/src/tests/test_send.rs +0 -0
  209. /package/contracts/oapps/{oft → oft-core}/src/tests/test_token.rs +0 -0
  210. /package/contracts/oapps/{oft → oft-core}/src/types.rs +0 -0
  211. /package/contracts/workers/{worker/src/interfaces → fee-lib-interfaces/src}/dvn_fee_lib.rs +0 -0
  212. /package/contracts/workers/{worker/src/interfaces → fee-lib-interfaces/src}/executor_fee_lib.rs +0 -0
  213. /package/contracts/workers/{worker/src/interfaces → fee-lib-interfaces/src}/price_feed.rs +0 -0
@@ -0,0 +1,1851 @@
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: 59665 bytes (58.27 KB)
10
+ */
11
+ export declare const WASM_BASE64 = "AGFzbQEAAAAB+gEoYAF+AX5gAn5+AX5gA35+fgF+YAR+fn5+AX5gAAF+YAF+AX9gAn9/AX9gBX5+fn5+AGACf38BfmADfn5+AGADf39/AGAEf39/fwBgBH9/fn4AYAN/f38BfmABfwBgAn9/AGACfn8BfmABfgBgAn5+AX9gAn9+AGAAAGAAAX9gAX8BfmACfn8AYAN/fn4AYAV/fn9+fgBgA35/fwBgAX8Bf2ACf34Bf2AFfn9/f38AYAR/f39/AX5gBn9+fn5+fwBgBX9+fn5+AGAGfn5+fn5+AX5gBH5+fn4AYAJ+fwF/YAR+fn9/AX5gAn5+AGAEf35+fwBgA39/fwF/AuUBJgF2ATMAAAF2ATEAAQFiAW0AAgFsATcAAwFsAV8AAgFiATgAAAFiAWUAAQFsATEAAQFiATQABAFhATAAAAFiAV8AAAFiAWYAAgF4ATEAAQFsATIAAQF2AV8ABAF4ATcABAFkAV8AAgFhATYAAAFpAV8AAAFpATAAAAFiATEAAwFiATMAAQF2AWcAAQFpATgAAAFpATcAAAFpATYAAQFiAWoAAQFiATIAAwFtATkAAgFtAWEAAwF4ATAAAQFiATAAAAF4ATQABAF4ATMABAF4ATgABAFsATAAAQFsATgAAQF4ATUAAAO4AbYBBQYHAQgJBwoICwgMAA0ODwgOEBEIEg4LDwgTCgQUFRYUBAQOFxQOFg4EChMPBBYYERkOExoTGxwcFBYTBAQUFQwGDwoKDAoEBBMPGw4WFR0YEx4KHwMIAAEBAQEAAQAAEgAABAAEAAQAEwggBAQFFAQEAhYTIAMVABMhDw8RIgQEAQACABMBIRYIIwEUJAIEBAABAQABExUWBA8EBAEEBAAlARQYBAQUChMKDwofJiAgJiAnJyAEBQFwAQEBBQMBABEGIQR/AUGAgMAAC38AQZCJwAALfwBBvovAAAt/AEHAi8AACwesBzYGbWVtb3J5AgAOc2V0X3JhdGVfbGltaXQAexB1bnNldF9yYXRlX2xpbWl0AH4RcmF0ZV9saW1pdF9jb25maWcAfxRyYXRlX2xpbWl0X2luX2ZsaWdodACAARNyYXRlX2xpbWl0X2NhcGFjaXR5AIEBE3NldF9kZWZhdWx0X2ZlZV9icHMAggELc2V0X2ZlZV9icHMAgwENdW5zZXRfZmVlX2JwcwCEARdzZXRfZmVlX2RlcG9zaXRfYWRkcmVzcwCFAQtoYXNfZmVlX2JwcwCHARFlZmZlY3RpdmVfZmVlX2JwcwCIAQ9kZWZhdWx0X2ZlZV9icHMAiQEHZmVlX2JwcwCKARNmZWVfZGVwb3NpdF9hZGRyZXNzAIsBCnNldF9wYXVzZWQAjAEJaXNfcGF1c2VkAI0BCXF1b3RlX29mdACOAQV0b2tlbgCSAQ9zaGFyZWRfZGVjaW1hbHMAkwEXZGVjaW1hbF9jb252ZXJzaW9uX3JhdGUAlgERYXBwcm92YWxfcmVxdWlyZWQAlwEKcXVvdGVfc2VuZACYAQRzZW5kAJwBDV9fY29uc3RydWN0b3IAoAEIb2Z0X3R5cGUApQEKYXV0aG9yaXplcgCmARBlbmZvcmNlZF9vcHRpb25zAKcBFHNldF9lbmZvcmNlZF9vcHRpb25zAKgBD2NvbWJpbmVfb3B0aW9ucwCpARVhbGxvd19pbml0aWFsaXplX3BhdGgAqgEKbmV4dF9ub25jZQCsAQpsel9yZWNlaXZlAK0BFWlzX2NvbXBvc2VfbXNnX3NlbmRlcgC0AQxvYXBwX3ZlcnNpb24AtQEIZW5kcG9pbnQAtgEEcGVlcgC3AQhzZXRfcGVlcgC5AQxzZXRfZGVsZWdhdGUAugEPc2V0X3R0bF9jb25maWdzALsBC3R0bF9jb25maWdzAL8BEmZyZWV6ZV90dGxfY29uZmlncwDBARVpc190dGxfY29uZmlnc19mcm96ZW4AwgETZXh0ZW5kX2luc3RhbmNlX3R0bADDAQVvd25lcgDEAQ1wZW5kaW5nX293bmVyAMUBEnRyYW5zZmVyX293bmVyc2hpcADGARpwcm9wb3NlX293bmVyc2hpcF90cmFuc2ZlcgDIARBhY2NlcHRfb3duZXJzaGlwAMsBEnJlbm91bmNlX293bmVyc2hpcADMAQFfAwELb2Z0X3ZlcnNpb24AtQEKX19kYXRhX2VuZAMCC19faGVhcF9iYXNlAwMK3OsBtgGuAQMBfwF+An9BAiEBAkAgAEL/AYNCywBSDQAgABCAgICAACICQoCAgIAQVA0AAkAgAEIEEIGAgIAAIgCnQf8BcSIDQcoARg0AIANBDkcNAQsgAkIgiKchAwJAAkACQCAAQeCBwIAArUIghkIEhEKEgICAIBCCgICAAEIgiKcOAgABAwtBASADEKeAgIAADQJBACEEDAELQQEhBEEBIAMQp4CAgAANAQsgBCEBCyABCxkAAkAgASAASQ0AIAEgAGsPCxDfgICAAAALsQEBAn8jgICAgABBMGsiBSSAgICAACAFIAMgBBCpgICAADcDECAFIAI3AwggBSABNwMAQQAhBgNAAkAgBkEYRw0AQQAhBgJAA0AgBkEYRg0BIAVBGGogBmogBSAGaikDADcDACAGQQhqIQYMAAsLIABCju7qlb623vMAIAVBGGpBAxCqgICAABCrgICAACAFQTBqJICAgIAADwsgBUEYaiAGakICNwMAIAZBCGohBgwACwtDAQF/I4CAgIAAQRBrIgIkgICAgAAgAiAAIAEQ9oCAgAACQCACKAIAQQFHDQAACyACKQMIIQEgAkEQaiSAgICAACABCxoAIACtQiCGQgSEIAGtQiCGQgSEEJaAgIAACyEAAkAgACABIAIQkICAgABC/wGDQgJRDQAQ34CAgAAACwuxAQECfyOAgICAAEEwayIFJICAgIAAIAUgAyAEEKmAgIAANwMQIAUgAjcDCCAFIAE3AwBBACEGA0ACQCAGQRhHDQBBACEGAkADQCAGQRhGDQEgBUEYaiAGaiAFIAZqKQMANwMAIAZBCGohBgwACwsgAEKO7uqVvrbe8wAgBUEYakEDEKqAgIAAEKuAgIAAIAVBMGokgICAgAAPCyAFQRhqIAZqQgI3AwAgBkEIaiEGDAALCycAQQEgABCugICAAEIBIAGtQiCGQgSEIAKtQiCGQgSEEIOAgIAAGgvHAQIBfwF+I4CAgIAAQRBrIgIkgICAgAACQAJAAkACQAJAAkAgAA4DAAECAAsgAkGAgMCAAEENENCAgIAAIAIoAgANAyACIAIpAwgQ0YCAgAAMAgsgAkGNgMCAAEEGENCAgIAAIAIoAgANAiACIAIpAwggAa1CIIZCBIQQ1YCAgAAMAQsgAkGTgMCAAEERENCAgIAAIAIoAgANASACIAIpAwgQ0YCAgAALIAIpAwghAyACKQMAUA0BCwALIAJBEGokgICAgAAgAwsnACAAIAEQsICAgABCASACrUIghkIEhCADrUIghkIEhBCDgICAABoL+gECAX8CfiOAgICAAEEwayICJICAgIAAIAJBIGpByILAgABBCRDQgICAAAJAAkAgAigCIA0AIAIpAyghAwJAAkAgAUEBcUUNACACQSBqQdeBwIAAQQgQ0ICAgAAgAigCIA0CIAJBIGogAikDKBDRgICAAAwBCyACQSBqQdCBwIAAQQcQ0ICAgAAgAigCIA0BIAJBIGogAikDKBDRgICAAAsgAikDKCEEIAIpAyCnDQAgAiAENwMQIAIgAzcDCCACIACtQiCGQgSENwMYIAJBIGogAkEIahDSgICAACACKAIgRQ0BCwALIAIpAyghAyACQTBqJICAgIAAIAMLHQAgACABEK6AgIAAIAIQsoCAgAAgAxCEgICAABoLQQEBfyOAgICAAEEQayIBJICAgIAAIAEgABD3gICAAAJAIAEoAgBBAUcNAAALIAEpAwghACABQRBqJICAgIAAIAALzwECAX8DfiOAgICAAEEQayIDJICAgIAAIANBBGoQtICAgAACQCADKAIEQQFHDQAgAygCCCADKAIMELWAgIAACyAAIAEQtoCAgAAiBBCFgICAACEFIAIpAwAhBgJAAkAgBUKAgICAEFQNAAJAIAYQhYCAgABCgICAgBBaDQAgBCEGDAELIAYQhYCAgABC/////x9YDQEgAhC3gICAACAEIAZBAhC4gICAABCGgICAACEGCyADQRBqJICAgIAAIAYPC0KDgICAgPoBELmAgIAAAAsMACAAQQEQ0YGAgAALGwAgAK1CIIZCBIQgAa1CIIZCBIQQpICAgAAaC70BBAF/AX4BfwF+I4CAgIAAQRBrIgIkgICAgAAgAkEEahC0gICAAAJAIAIoAgRBAUcNACACKAIIIAIoAgwQtYCAgAALAkACQCAAIAEQuoCAgAAiA0IBELuAgIAAIgRFDQAgA0IBEIeAgIAAIgVC/wGDQsgAUg0BIAJBBGoQvICAgAAgAigCBEEBRw0AIAAgASACKAIIIAIoAgwQvYCAgAALEIiAgIAAIQMgAkEQaiSAgICAACAFIAMgBBsPCwALvQECAX8BfiOAgICAAEEQayIBJICAgIAAIAFBADYCCCABIAA2AgQCQAJAAkAgAUEEakECEK+BgIAAIgIQhYCAgABCgICAgHCDQoCAgIAgUg0AIAFBADsBDiACEIWAgIAAQoCAgIBwg0KAgICAIFINASACIAFBDmpBAhDagICAACABLwEOQYAGRw0CIAFBEGokgICAgAAPC0KDgICAgIIBELmAgIAAAAsQsoGAgAAAC0KDgICAgPoBELmAgIAAAAslACAAIAGtQiCGQgSEIAAQhYCAgABCgICAgHCDQgSEEIuAgIAACwsAIAAQpYCAgAAaC4oBAgF/AX4jgICAgABBMGsiAiSAgICAACACQSBqQeCFwIAAQQ8Q0ICAgAACQAJAIAIoAiANACACIAIpAyg3AwggAiABrUIghkIEhDcDGCACIACtQiCGQgSENwMQIAJBIGogAkEIahDSgICAACACKAIgRQ0BCwALIAIpAyghAyACQTBqJICAgIAAIAMLDwAgACABEKOAgIAAQgFRCwwAIABBAhDRgYCAAAsnACAAIAEQuoCAgABCASACrUIghkIEhCADrUIghkIEhBCDgICAABoLxgECAX8BfiOAgICAAEEQayICJICAgIAAIAIQtICAgAACQCACKAIAQQFHDQAgAigCBCACKAIIELWAgIAACwJAAkACQEEBIAEQv4CAgAAiA0IBELuAgIAARQ0AIAIgA0IBEIeAgIAAEMCAgIAAIAIoAgBBAUcNAQALIABCADcDAAwBCyACKQMIIQMgAEIBNwMAIAAgAzcDCCACELyAgIAAIAIoAgBBAUcNACABIAIoAgQgAigCCBDBgICAAAsgAkEQaiSAgICAAAubAQIBfwF+I4CAgIAAQRBrIgIkgICAgAACQAJAAkACQCAAQQFxRQ0AIAJBnIXAgABBBBDQgICAACACKAIADQIgAiACKQMIIAGtQiCGQgSEENWAgIAADAELIAJBlIXAgABBCBDQgICAACACKAIADQEgAiACKQMIENGAgIAACyACKQMIIQMgAikDAFANAQsACyACQRBqJICAgIAAIAMLIwACQCABQv8Bg0LIAFENACAAQgE3AwAPCyAAIAEQ24CAgAALJwBBASAAEL+AgIAAQgEgAa1CIIZCBIQgAq1CIIZCBIQQg4CAgAAaC4cBAgF/AX4jgICAgABBEGsiACSAgICAACAAQQRqELSAgIAAAkAgACgCBEEBRw0AIAAoAgggACgCDBC1gICAAAsCQAJAQQAgABC/gICAACIBQgIQu4CAgABFDQAgAUICEIeAgIAAIgFC/wGDQs0AUQ0BAAsQw4CAgAAACyAAQRBqJICAgIAAIAELCQAQ34CAgAAAC4sBAgJ/AX4jgICAgABBEGsiACSAgICAACAAQQRqELSAgIAAAkAgACgCBEEBRw0AIAAoAgggACgCDBC1gICAAAtBACEBAkBBABDFgICAACICQgIQu4CAgABFDQBBASEBAkACQCACQgIQh4CAgACnQf8BcQ4CAQIACwALQQAhAQsgAEEQaiSAgICAACABC8IBAgF/AX4jgICAgABBEGsiASSAgICAAAJAAkACQAJAAkACQCAAQf8BcQ4DAAECAAsgAUGmi8CAAEEGENCAgIAAIAEoAgANAyABIAEpAwgQ0YCAgAAMAgsgAUGsi8CAAEEIENCAgIAAIAEoAgANAiABIAEpAwgQ0YCAgAAMAQsgAUG0i8CAAEEKENCAgIAAIAEoAgANASABIAEpAwgQ0YCAgAALIAEpAwghAiABKQMAUA0BCwALIAFBEGokgICAgAAgAgsPABDHgICAABCJgICAABoLZgIBfwF+I4CAgIAAQRBrIgAkgICAgAAgABC0gICAAAJAIAAoAgBBAUcNACAAKAIEIAAoAggQtYCAgAALIAAQyYCAgAAgACkDCCEBIAApAwBBiggQyoCAgAAgAEEQaiSAgICAACABC0oCAX8BfiOAgICAAEEQayIAJICAgIAAIAAQyYCAgAAgACkDCCEBIAApAwBBiggQyoCAgAAgARCJgICAABogAEEQaiSAgICAACABC1ABAX8jgICAgABBEGsiASSAgICAACABQQRqELSAgIAAAkAgASgCBEEBRw0AIAEoAgggASgCDBC1gICAAAsgABDOgICAACABQRBqJICAgIAACykAAkAgAKdBAXFFDQAPCyABQfp3aq1CIIZCg4CAgOCAAXwQuYCAgAAAC0IBAX8jgICAgABBEGsiACSAgICAACAAEMyAgIAAAkAgACkDAFANAEKDgICAsIEBELmAgIAAAAsgAEEQaiSAgICAAAuTAQIBfwJ+I4CAgIAAQRBrIgEkgICAgAAgAUEEahC0gICAAAJAIAEoAgRBAUcNACABKAIIIAEoAgwQtYCAgAALQgAhAgJAAkBBARDNgICAACIDQgAQu4CAgABFDQAgA0IAEIeAgIAAIgJC/wGDQs0AUg0BIAAgAjcDCEIBIQILIAAgAjcDACABQRBqJICAgIAADwsAC5IBAgF/AX4jgICAgABBEGsiASSAgICAAAJAAkACQAJAIABBAXFFDQAgAUG5isCAAEEMENCAgIAAIAEoAgANAiABIAEpAwgQ0YCAgAAMAQsgAUG0isCAAEEFENCAgIAAIAEoAgANASABIAEpAwgQ0YCAgAALIAEpAwghAiABKQMAUA0BCwALIAFBEGokgICAgAAgAgtNAQJ+QgAhAQJAAkBBABDNgICAACICQgIQu4CAgABFDQAgAkICEIeAgIAAIgFC/wGDQs0AUg0BIAAgATcDCEIBIQELIAAgATcDAA8LAAtgAgF/AX4jgICAgABBEGsiACSAgICAACAAQcODwIAAQQcQ0ICAgAACQAJAIAAoAgANACAAIAApAwgQ0YCAgAAgACgCAEEBRw0BCwALIAApAwghASAAQRBqJICAgIAAIAELUQIBfwF+I4CAgIAAQRBrIgMkgICAgAAgAyABIAIQzoGAgABCASEEAkAgAygCAA0AIAAgAykDCDcDCEIAIQQLIAAgBDcDACADQRBqJICAgIAAC0QBAX8jgICAgABBEGsiAiSAgICAACACIAE3AwggAkEIakEBEKqAgIAAIQEgAEIANwMAIAAgATcDCCACQRBqJICAgIAAC10CAX8BfiOAgICAAEEgayICJICAgIAAIAIgASkDEDcDGCACIAEpAwg3AxAgAiABKQMANwMIIAJBCGpBAxCqgICAACEDIABCADcDACAAIAM3AwggAkEgaiSAgICAAAtgAgF/AX4jgICAgABBEGsiACSAgICAACAAQbCBwIAAQQYQ0ICAgAACQAJAIAAoAgANACAAIAApAwgQ0YCAgAAgACgCAEEBRw0BCwALIAApAwghASAAQRBqJICAgIAAIAELkgECAX8BfiOAgICAAEEQayIBJICAgIAAAkACQAJAAkAgAEEBcUUNACABQdeBwIAAQQgQ0ICAgAAgASgCAA0CIAEgASkDCBDRgICAAAwBCyABQdCBwIAAQQcQ0ICAgAAgASgCAA0BIAEgASkDCBDRgICAAAsgASkDCCECIAEpAwBQDQELAAsgAUEQaiSAgICAACACC0gBAX8jgICAgABBEGsiAySAgICAACADIAI3AwggAyABNwMAIANBAhCqgICAACECIABCADcDACAAIAI3AwggA0EQaiSAgICAAAseAAJAIACnQQFxRQ0ADwtCg4CAgJD6ARC5gICAAAAL7gUDAX8FfgN/I4CAgIAAQdAAayIFJICAgIAAIAIpAzAiBhCFgICAACEHIAVBEGoQ2ICAgAACQAJAAkACQCAFKQMQIgggBSkDGCIJhFANACACKQMgIQoCQCADIARCgICAgICAgICAf4WEQgBSDQAgCCAJg0J/UQ0BCyAFIAMgBCAIIAkQ1oGAgAAgBSkDCEIBWQ0BIAUpAwAhBAJAAkAgB0L/////D1YNACAFIAQ3AzggBSAKNwMwQgAhBiAFQgA3AxAgBUEgaiELQQEhDAwBCyAFQRBqIAEQioCAgABBBBC4gICAACIDQgRChICAgMAAEIuAgIAAENmAgIAAIAUoAhBBAUYNBCAFKQMYIQggBUEANgJAIAggBUHAAGpBBBDagICAACAFKAJAIgtB////B3ENAwJAAkACQCALQRh2DgIAAQYLIAVBwABqIANChICAgMAAQoSAgICAARCLgICAABDZgICAACAFKAJAQQFGDQYgBSkDSCEIIAVBADYCQCAIIAVBwABqQQQQ2oCAgAAgBSgCQA0FIAVBwABqIANChICAgIABQoSAgICABRCLgICAABDbgICAACAFKAJAQQFHDQEMBgsgBUHAAGogA0KEgICAwABChICAgMAEEIuAgIAAENuAgIAAIAUoAkBBAUYNBQsgBSkDSCEDIAVBKGohCyAFIAQ3AzggBSAKNwMwIAVCATcDICAFIAM3AxggBUIBNwMQQQIhDAsgCyAGNwMAIAVBEGoQ3ICAgAAhCyAFEIiAgIAANwNAIAVBwABqIAoQ3YCAgAAgBBDegICAACENAkACQCALDQAgDSkDACEEDAELIAdC/////w9YDQMgDSADEN2AgIAAIQsgBSgCIEUNAyALKQMAIAUpAygQhoCAgAAhBAsgACACKAJAIAwgAkEoahCzgICAADcDCCAAIAQ3AwAgBUHQAGokgICAgAAPCxDfgICAAAALQoOAgICg9wIQuYCAgAAACxDDgICAAAALAAuBAQIBfwF+I4CAgIAAQSBrIgEkgICAgAACQAJAQQAQ4ICAgAAiAkICELuAgIAARQ0AIAEgAkICEIeAgIAAEOGAgIAAIAEoAgBBAUcNAQALQoOAgICQ9wIQuYCAgAAACyABKQMQIQIgACABKQMYNwMIIAAgAjcDACABQSBqJICAgIAACzYBAX5CASECAkAgARCFgICAAEKAgICAcINCgICAgMAAUg0AIAAgATcDCEIAIQILIAAgAjcDAAsfACAAQgQgAa1CIIZCBIQgAq1CIIZCBIQQlICAgAAaCzYBAX5CASECAkAgARCFgICAAEKAgICAcINCgICAgIAEUg0AIAAgATcDCEIAIQILIAAgAjcDAAszAQF/QQAhAQJAIAApAwBQDQAgACgCEEEBRw0AIAApAxgQhYCAgABC/////w9WIQELIAELwgEBBH8jgICAgABBwABrIgIkgICAgAAgAkEgakEYaiIDQgA3AwAgAkEgakEQaiIEQgA3AwAgAkEgakEIaiIFQgA3AwAgAkIANwMgIAEgAkEgakEgENqAgIAAIAJBGGogAykDADcDACACQRBqIAQpAwA3AwAgAkEIaiAFKQMANwMAIAIgAikDIDcDACAAKQMAIQEgACABIAEQhYCAgABCgICAgHCDQgSEIAJBIBCzgYCAADcDACACQcAAaiSAgICAACAAC6cBAQF/I4CAgIAAQRBrIgIkgICAgAAgAiABQjiGIAFCgP4Dg0IohoQgAUKAgPwHg0IYhiABQoCAgPgPg0IIhoSEIAFCCIhCgICA+A+DIAFCGIhCgID8B4OEIAFCKIhCgP4DgyABQjiIhISENwMIIAApAwAhASAAIAEgARCFgICAAEKAgICAcINCBIQgAkEIakEIELOBgIAANwMAIAJBEGokgICAgAAgAAsJABDNgYCAAAALkgECAX8BfiOAgICAAEEQayIBJICAgIAAAkACQAJAAkAgAEEBcUUNACABQcWHwIAAQQUQ0ICAgAAgASgCAA0CIAEgASkDCBDRgICAAAwBCyABQbCHwIAAQRUQ0ICAgAAgASgCAA0BIAEgASkDCBDRgICAAAsgASkDCCECIAEpAwBQDQELAAsgAUEQaiSAgICAACACC30CAX8BfgJAAkACQAJAIAGnQf8BcSICQcUARg0AIAJBC0cNAiAAIAFCP4c3AxggACABQgiHNwMQDAELIAEQl4CAgAAhAyABEJiAgIAAIQEgACADNwMYIAAgATcDEAtCACEBDAELIABCg5CAgIABNwMIQgEhAQsgACABNwMAC0cBAX4CQAJAQQEQ4ICAgAAiAEICELuAgIAARQ0AIABCAhCHgICAACIAQv8Bg0LNAFENAQALQoOAgICQ9wIQuYCAgAAACyAAC1QCAX8BfiOAgICAAEEQayIAJICAgIAAIABBBGoQtICAgAACQCAAKAIEQQFHDQAgACgCCCAAKAIMELWAgIAACxDigICAACEBIABBEGokgICAgAAgAQsdAAJAEOWAgIAADQAPC0KDgICA4IQDELmAgIAAAAtFAgF/AX5BACEAAkAQ04CAgAAiAUICELuAgIAARQ0AQQEhAAJAAkAgAUICEIeAgIAAp0H/AXEOAgECAAsAC0EAIQALIAALuAIEAX8CfgF/BH4jgICAgABB8ABrIgQkgICAgAACQAJAAkACQCAAIAEQ54CAgABFDQAgACABEOiAgIAAIARBMGogACABEOmAgIAAIAQoAjBBAXFFDQJCACEFQgAhBgJAIAQgBEHAAGpBMBDagYCAACIHKQMAIgggBykDECIJViAHKQMIIgogBykDGCILVSAKIAtRG0UNACAKIAuFIAogCiALfSAIIAlUrX0iBoWDQgBTDQIgCCAJfSEFCyACIAVWIAMgBlUgAyAGURsNAyALIAOFQn+FIAsgCyADfCAJIAJ8IgMgCVStfCIChYNCAFMNASAHIAM3AxAgByACNwMYIAAgASAHEOqAgIAACyAEQfAAaiSAgICAAA8LEN+AgIAAAAsQw4CAgAAAC0KDgICAgIYDELmAgIAAAAtlAQJ/I4CAgIAAQRBrIgIkgICAgAACQCABIAAQsICAgABCARC7gICAACIDRQ0AIAJBBGoQvICAgAAgAigCBEEBRw0AIAEgACACKAIIIAIoAgwQr4CAgAALIAJBEGokgICAgAAgAwuZAQIBfwJ+I4CAgIAAQfAAayICJICAgIAAIAJBMGogACABEOyAgIAAIAIpAzghAyACKQMwIQQgAkEwaiAAIAEQ6YCAgAACQCACKAIwQQFxDQAQw4CAgAAACyACIAJBwABqQTAQ2oGAgAAiAiADNwMYIAIgBDcDECACEO2AgIAANwMoIAAgASACEOqAgIAAIAJB8ABqJICAgIAAC5oDBAF/AX4BfwV+I4CAgIAAQcAAayIDJICAgIAAAkACQAJAIAIgARCwgICAACIEQgEQu4CAgABFDQAgBEIBEIeAgIAAIQRBACEFAkADQCAFQSBGDQEgAyAFakICNwMAIAVBCGohBQwACwsCQCAEQv8Bg0LMAFINACAEQaiCwIAAQQQgA0EEEPWAgIAAIANBIGogAykDABDhgICAACADKAIgQQFGDQAgAykDOCEEIAMpAzAhBiADQSBqIAMpAwgQ74CAgAAgAygCIA0AIAMpAyghByADQSBqIAMpAxAQ4YCAgAAgAygCIEEBRg0AIAMpAzghCCADKQMwIQkgA0EgaiADKQMYEO+AgIAAIAMoAiBBAUcNAgsACyAAQgA3AwggAEIANwMADAELIAMpAyghCiAAIAY3AyAgACAJNwMQIABCADcDCCAAQgE3AwAgACAHNwM4IAAgCjcDMCAAIAQ3AyggACAINwMYIANBIGoQvICAgAAgAygCIEUNACACIAEgAygCJCADKAIoEK+AgIAACyADQcAAaiSAgICAAAuWAgIBfwR+I4CAgIAAQTBrIgMkgICAgAAgASAAELCAgIAAIQQgA0EgaiACKQMQIAIpAxgQ9oCAgAACQCADKAIgDQAgAykDKCEFIANBIGogAikDKBD3gICAACADKAIgDQAgAykDKCEGIANBIGogAikDACACKQMIEPaAgIAAIAMoAiANACADKQMoIQcgA0EgaiACKQMgEPeAgIAAIAMoAiBBAUYNACADIAMpAyg3AxggAyAHNwMQIAMgBjcDCCADIAU3AwAgBEGogsCAAEEEIANBBBD4gICAAEIBEISAgIAAGiADELyAgIAAAkAgAygCAEEBRw0AIAEgACADKAIEIAMoAggQr4CAgAALIANBMGokgICAgAAPCwAL5gEEAX8CfgF/An4jgICAgABB8ABrIgQkgICAgAACQAJAAkAgACABEOeAgIAARQ0AIAAgARDogICAACAEQTBqIAAgARDpgICAACAEKAIwQQFxRQ0BQgAhBUIAIQYCQCACIAQgBEHAAGpBMBDagYCAACIHKQMQIghUIAMgBykDGCIJUyADIAlRG0UNACAJIAOFIAkgCSADfSAIIAJUrX0iBoWDQgBTDQMgCCACfSEFCyAHIAU3AxAgByAGNwMYIAAgASAHEOqAgIAACyAEQfAAaiSAgICAAA8LEMOAgIAAAAsQ34CAgAAAC80CAgF/B34jgICAgABB8ABrIgMkgICAgABCACEEQgAhBQJAAkACQAJAIAEgAhDngICAAEUNACADQTBqIAEgAhDpgICAACADKAIwQQFxRQ0CIAMpA1ghBiADKQNQIQcgAykDSCEEIAMpA0AhCCADKQNgIQkgAykDaCEFEO2AgIAAIgogBVQNAyADQQA2AiwgA0EQaiAKIAV9QgAgCCAEIANBLGoQ04GAgAAgAygCLA0BIAlQDQFCACEEIAMgAykDECADKQMYIAlCABDWgYCAAEIAIQUgAykDACIIIAdaIAMpAwgiCSAGWSAJIAZRGw0AIAYgCYUgBiAGIAl9IAcgCFStfSIFhYNCAFMNASAHIAh9IQQLIAAgBDcDACAAIAU3AwggA0HwAGokgICAgAAPCxDfgICAAAALEMOAgIAAAAtCg4CAgJCGAxC5gICAAAALPQIBfgF/AkAQoICAgAAiAKdB/wFxIgFBBkYNAAJAIAFBwABHDQAgABCTgICAAA8LEN+AgIAAAAsgAEIIiAtqAgF/An4jgICAgABBEGsiACSAgICAAEIAIQECQAJAQQAgABCugICAACICQgIQu4CAgABFDQAgACACQgIQh4CAgAAQ74CAgAAgACgCAEEBRg0BIAApAwghAQsgAEEQaiSAgICAACABDwsAC10CAX8BfgJAAkAgAadB/wFxIgJBwABGDQACQCACQQZGDQBCASEDQoOQgICAASEBDAILIAFCCIghAUIAIQMMAQtCACEDIAEQk4CAgAAhAQsgACADNwMAIAAgATcDCAufAQIBfwF+I4CAgIAAQRBrIgIkgICAgAACQAJAAkBBASABEK6AgIAAIgNCARC7gICAAEUNACACIANCARCHgICAABDvgICAACACKAIAQQFHDQEACyAAQgA3AwAMAQsgAikDCCEDIABCATcDACAAIAM3AwggAhC8gICAACACKAIARQ0AIAEgAigCBCACKAIIEK2AgIAACyACQRBqJICAgIAAC2MBAn8jgICAgABBEGsiASSAgICAAAJAQQEgABCugICAAEIBELuAgIAAIgJFDQAgAUEEahC8gICAACABKAIEQQFHDQAgACABKAIIIAEoAgwQrYCAgAALIAFBEGokgICAgAAgAgtPAQJ+QgAhAQJAAkBBAiAAEK6AgIAAIgJCAhC7gICAAEUNACACQgIQh4CAgAAiAUL/AYNCzQBSDQEgACABNwMIQgEhAQsgACABNwMADwsAC4cBAgF/AX4jgICAgABBEGsiASSAgICAACABELSAgIAAAkAgASgCAEEBRw0AIAEoAgQgASgCCBC1gICAAAsCQAJAAkAgABDxgICAAA0AEO6AgIAAIQIMAQsgASAAEPCAgIAAIAEoAgBFDQEgASkDCCECCyABQRBqJICAgIAAIAIPCxDDgICAAAALUgECfyOAgICAAEEQayIAJICAgIAAIABBBGoQtICAgAACQCAAKAIEQQFHDQAgACgCCCAAKAIMELWAgIAACxDlgICAACEBIABBEGokgICAgAAgAQsxAAJAIAIgBEYNAAALIAAgAa1CIIZCBIQgA61CIIZCBIQgAq1CIIZCBIQQnYCAgAAaC1sAAkACQCABQoCAgICAgIDAAHxC//////////8AVg0AIAEgAYUgAiABQj+HhYRCAFINACABQgiGQguEIQEMAQsgAiABEJmAgIAAIQELIABCADcDACAAIAE3AwgLOwACQAJAIAFC//////////8AVg0AIAFCCIZCBoQhAQwBCyABEJKAgIAAIQELIABCADcDACAAIAE3AwgLLgACQCABIANGDQAACyAArUIghkIEhCACrUIghkIEhCABrUIghkIEhBCcgICAAAuKAgIBfwZ+I4CAgIAAQcAAayIDJICAgIAAIAMQtICAgAACQCADKAIAQQFHDQAgAygCBCADKAIIELWAgIAACwJAAkACQAJAIAEgAhDngICAAA0AQv///////////wAhBEJ/IQUMAQsgAyABIAIQ6YCAgAAgAygCAEEBcUUNAiADKQMQIQYgAykDGCEHIAMgASACEOyAgIAAQgAhBUIAIQQgBiADKQMAIghWIAcgAykDCCIJVSAHIAlRG0UNACAHIAmFIAcgByAJfSAGIAhUrX0iBIWDQgBTDQEgBiAIfSEFCyAAIAU3AwAgACAENwMIIANBwABqJICAgIAADwsQ34CAgAAACxDDgICAAAALkwQCAX8FfiOAgICAAEHwAGsiBiSAgICAABDkgICAACAGQeAAahDYgICAACAGKQNoIQcgBikDYCEIAkACQAJAAkACQAJAIAUQ8YCAgAANABDugICAACEJDAELIAZB4ABqIAUQ8ICAgAAgBigCYEUNASAGKQNoIQkLAkACQCAJUEUNAEIAIQpCACEJDAELIAZB4ABqEPKAgIAAIAYoAmBFDQIgBkEANgJcIAZBwABqIAEgAiAJQgAgBkHcAGoQ04GAgAAgBigCXA0DIAZBMGogBikDQCAGKQNIQpDOAEIAENaBgIAAIAYpAzghCSAGKQMwIQoLIAIgCYUgAiACIAl9IAEgClStfSILhYNCAFMNAiAIIAeEUA0CAkAgASAKfSICIAtCgICAgICAgICAf4WEQgBSDQAgCCAHg0J/UQ0DCyAGQSBqIAIgCyAIIAcQ1oGAgAAgBkEANgIcIAYgBikDICAGKQMoIAggByAGQRxqENOBgIAAIAYoAhwNAiAGKQMIIgIgCYVCf4UgAiACIAl8IAYpAwAiCSAKfCIHIAlUrXwiCIWDQgBTDQIgCSADVCACIARTIAIgBFEbDQMgACAJNwMQIAAgBzcDACAAIAI3AxggACAINwMIIAZB8ABqJICAgIAADwsQw4CAgAAAC0KDgICA0IMDELmAgIAAAAsQ34CAgAAAC0KDgICAsPcCELmAgIAAAAvnBQMDfwJ+AX8jgICAgABB8ABrIgQkgICAgAACQAJAAkACQAJAIAAQpoCAgABB/wFxIgVBAkYNACABQv8Bg0IEUg0AIARBMGogAhDhgICAACAEKAIwQQFGDQAgBCkDSCEAIAQpA0AhAiAEQTBqIAMQ74CAgAAgBCgCMEEBRg0AIAQpAzghAxDGgICAACAEQTBqELSAgIAAAkAgBCgCMEEBRw0AIAQoAjQgBCgCOBC1gICAAAsgAkIAUiAAQgBVIABQG0UNASADQgBRDQICQAJAIAUgAUIgiKciBhDngICAAA0AEO2AgIAAIQcgBCAANwM4IAQgAjcDMCAEQgA3A0ggBEIANwNAIAQgAzcDUCAEIAc3A1ggBSAGIARBMGoQ6oCAgABB0YLAgABBDhD8gICAABD9gICAACEHIAUQ1ICAgAAhCCACIAAQqYCAgAAhACAEIAMQsoCAgAA3A0ggBCAANwNAIAQgAUKEgICAcIM3AzggBCAINwMwIAdB6ILAgABBBCAEQTBqQQQQ+ICAgAAQjICAgAAaDAELIARBMGogBSAGEOmAgIAAIAQoAjBBAXFFDQQCQCACIAQpA0CFIAAgBCkDSIWEQgBSDQAgAyAEKQNgUQ0GCyAFIAYQ6ICAgAAgBEEwaiAFIAYQ6YCAgAAgBCgCMEEBcUUNBCAEIARBwABqQTAQ2oGAgAAiCSAANwMIIAkgAjcDACAJIAM3AyAgBSAGIAkQ6oCAgABBiIPAgABBEhD8gICAABD9gICAACEHIAUQ1ICAgAAhCCACIAAQqYCAgAAhACAJIAMQsoCAgAA3A0ggCSAANwNAIAkgAUKEgICAcIM3AzggCSAINwMwIAdB6ILAgABBBCAJQTBqQQQQ+ICAgAAQjICAgAAaCyAEQfAAaiSAgICAAEICDwsAC0KDgICAsIYDELmAgIAAAAtCg4CAgKCGAxC5gICAAAALEMOAgIAAAAtCg4CAgMCGAxC5gICAAAALRQIBfwF+I4CAgIAAQRBrIgIkgICAgAAgAiAAIAEQzoGAgAACQCACKAIAQQFHDQAACyACKQMIIQMgAkEQaiSAgICAACADC2MDAX8BfgF/I4CAgIAAQRBrIgEkgICAgAAgASAANwMAQgIhAkEBIQMCQANAIANFDQEgA0F/aiEDIAAhAgwACwsgASACNwMIIAFBCGpBARCqgICAACEAIAFBEGokgICAgAAgAAv8AQIDfwF+I4CAgIAAQRBrIgIkgICAgAACQAJAIAAQpoCAgABB/wFxIgNBAkYNACABQv8Bg0IEUg0AIAFCIIinIQQQxoCAgAAgAhC0gICAAAJAIAIoAgBBAUcNACACKAIEIAIoAggQtYCAgAALIAMgBBDngICAAEUNASAEIAMQsICAgABCARCNgICAABpBmoPAgABBEBD8gICAABD9gICAACEAIAMQ1ICAgAAhBSACIAFChICAgHCDNwMIIAIgBTcDACAAQayDwIAAQQIgAkECEPiAgIAAEIyAgIAAGiACQRBqJICAgIAAQgIPCwALQoOAgIDAhgMQuYCAgAAAC50CAgN/AX4jgICAgABB0ABrIgIkgICAgAACQAJAAkAgABCmgICAAEH/AXEiA0ECRg0AIAFC/wGDQgRSDQAgAUIgiKchBCACELSAgIAAAkAgAigCAEEBRw0AIAIoAgQgAigCCBC1gICAAAsCQAJAIAMgBBDngICAAA0AQgAhBUIAIQFCACEADAELIAIgAyAEEOmAgIAAIAIoAgBBAXFFDQIgAikDGCEAIAIpAxAhASACKQMwIQULIAIgASAAEPaAgIAAIAIoAgANACACKQMIIQEgAiAFEPeAgIAAIAIoAgBBAUcNAgsACxDDgICAAAALIAIgAikDCDcDSCACIAE3A0AgAkHAAGpBAhCqgICAACEBIAJB0ABqJICAgIAAIAELjAEBAn8jgICAgABBEGsiAiSAgICAAAJAIAAQpoCAgABB/wFxIgNBAkYNACABQv8Bg0IEUg0AIAIQtICAgAACQCACKAIAQQFHDQAgAigCBCACKAIIELWAgIAACyACIAMgAUIgiKcQ7ICAgAAgAikDACACKQMIEKmAgIAAIQEgAkEQaiSAgICAACABDwsAC2cBAn8jgICAgABBEGsiAiSAgICAAAJAIAAQpoCAgABB/wFxIgNBAkYNACABQv8Bg0IEUg0AIAIgAyABQiCIpxD5gICAACACKQMAIAIpAwgQqYCAgAAhASACQRBqJICAgIAAIAEPCwAL8wECAX8BfiOAgICAAEEQayIBJICAgIAAIAEgABDvgICAAAJAAkACQCABKAIAQQFGDQAgASkDCCEAEMaAgIAAIAEQtICAgAACQCABKAIAQQFHDQAgASgCBCABKAIIELWAgIAACyAAQpHOAFoNARDugICAACAAUQ0CQQAgASAAQgIQsYCAgABBpIDAgABBExD8gICAABD9gICAACECIAEgABCygICAADcDACACQcCAwIAAQQEgAUEBEPiAgIAAEIyAgIAAGiABQRBqJICAgIAAQgIPCwALQoOAgIDAgwMQuYCAgAAAC0KDgICA8IMDELmAgIAAAAvdAgICfwF+I4CAgIAAQRBrIgIkgICAgAACQAJAAkACQCAAQv8Bg0IEUg0AIAIgARDvgICAACACKAIAQQFGDQAgAikDCCEBEMaAgIAAIAIQtICAgAACQCACKAIAQQFHDQAgAigCBCACKAIIELWAgIAACyABQpHOAFoNASAAQiCIpyIDEPGAgIAARQ0DIAIgAxDwgICAACACKAIARQ0CIAIpAwggAVINA0KDgICA8IMDELmAgIAACwALQoOAgIDAgwMQuYCAgAAACxDDgICAAAALQQEgAyABQgEQsYCAgAAgAhC8gICAAAJAIAIoAgBBAUcNACADIAIoAgQgAigCCBCtgICAAAtByIDAgABBCxD8gICAABD9gICAACEEIAIgARCygICAADcDCCACIABChICAgHCDNwMAIARB1IDAgABBAiACQQIQ+ICAgAAQjICAgAAaIAJBEGokgICAgABCAgvWAQICfwF+I4CAgIAAQRBrIgEkgICAgAACQAJAIABC/wGDQgRSDQAgAEIgiKchAhDGgICAACABELSAgIAAAkAgASgCAEEBRw0AIAEoAgQgASgCCBC1gICAAAsgAhDxgICAAEUNAUEBIAIQroCAgABCARCNgICAABpB5IDAgABBDRD8gICAABD9gICAACEDIAEgAEKEgICAcIM3AwAgA0H0gMCA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AiggASgCLBC9gICAAAsgA0IBfCEDDAALC0HvhcCAAEETEPyAgIAAEP2AgIAAIQMgASAANwMIIANBmIbAgABBASABQQhqQQEQ+ICAgAAQjICAgAAaIAFBMGokgICAgABCAg8LAAsQ34CAgAAAC2kBAX8jgICAgABBEGsiAySAgICAAAJAIABC/wGDQgRSDQAgAUL/AYNCBFINACACQv8Bg0LIAFINACADIAI3AwggAEIgiKcgAUIgiKcgA0EIahCzgICAACEAIANBEGokgICAgAAgAA8LAAubAQICfwF+I4CAgIAAQSBrIgEkgICAgAAgASAAEKuBgIAAAkAgASgCAEEBRg0AIAEoAhghAiABKQMIIQMgARC0gICAAAJAIAEoAgBBAUcNACABKAIEIAEoAggQtYCAgAALIAEgAhC+gICAAEIAIQACQCABKAIAQQFHDQAgASkDCCADEIaBgIAArSEACyABQSBqJICAgIAAIAAPCwAL4gECAn8CfiOAgICAAEEwayICJICAgIAAQQAhAwJAA0AgA0EYRg0BIAJBCGogA2pCAjcDACADQQhqIQMMAAsLQgEhBAJAIAFC/wGDQswAUg0AIAFBmITAgABBAyACQQhqQQMQ9YCAgAAgAkEgaiACKQMIEO+AgIAAIAIoAiANACACKQMoIQEgAkEgaiACKQMQEMCAgIAAIAIoAiANACACKQMYIgVC/wGDQgRSDQAgAikDKCEEIAAgATcDECAAIAQ3AwggACAFQiCIPgIYQgAhBAsgACAENwMAIAJBMGokgICAgAALdQEBfyOAgICAAEEQayICJICAgIAAAkAgAEL/AYNCBFINACACIAEQwICAgAAgAigCAEEBRg0AIAIQtICAgAACQCACKAIAQQFHDQAgAigCBCACKAIIELWAgIAAC0IAELKAgIAAIQAgAkEQaiSAgICAACAADwsAC7oPBAJ/A34BfwF+I4CAgIAAQbABayIGJICAgIAAAkACQAJAIABC/wGDQs0AUg0AIAZBIGogARCrgYCAACAGKAIgQQFGDQAgBigCOCEHIAYpAzAhCCAGKQMoIQEgBkEgaiACEMCAgIAAIAYoAiBBAUYNACADQv8Bg0LIAFINACAGKQMoIQkgBiADNwMYIARC/wGDQsgAUg0AIAZBIGogBRDhgICAACAGKAIgQQFGDQAgBikDOCEC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AwF/AX4CfyOAgICAAEHAAGsiASSAgICAAAJAAkAgAEEgEK+BgIAAIgIQhYCAgABCgICAgHCDQoCAgICABFINACABQSBqQRhqIgBCADcDACABQSBqQRBqIgNCADcDACABQSBqQQhqIgRCADcDACABQgA3AyAgAhCFgICAAEKAgICAcINCgICAgIAEUg0BIAIgAUEgakEgENqAgIAAIAFBGGogACkDADcDACABQRBqIAMpAwA3AwAgAUEIaiAEKQMANwMAIAEgASkDIDcDACABQSAQkIGAgAAhAiABQcAAaiSAgICAACACDwtCg4CAgICCARC5gICAAAALELKBgIAAAAt1AgJ/AX4CQAJAIAAoAgQiAiABaiIBIAJJDQAgASAAKAIAIgMpAwAQhYCAgABCIIinSw0BIAMpAwAgAq1CIIZCBIQgAa1CIIZCBIQQi4CAgAAhBCAAIAE2AgQgBA8LEN+AgIAAAAtCg4CAgID9ABC5gICAAAALJwEBfwJAIAAQhYCAgABCIIinIgIgAUkNACACIAFrDwsQ34CAgAAAC0YBAX8CQEGcicCAAEGQicCAACAAp0EBcSICG0EIQQwgAhsQkIGAgAAgARCGgICAABCfgICAACIAQv8Bg0LNAFENAAALIAALCQAQ34CAgAAACx4AIAAgASACrUIghkIEhCADrUIghkIEhBCbgICAAAuJAQECfyOAgICAAEEgayIDJICAgIAAIAMgABCrgYCAAAJAIAMoAgBBAUYNACABQv8Bg0LIAFINACACQv8Bg0LNAFINACADELSAgIAAAkAgAygCAEEBRw0AIAMoAgQgAygCCBC1gICAAAsQj4CAgAAgAhCGgYCAACEEIANBIGokgICAgAAgBK0PCwALogECAX8BfiOAgICAAEEgayIAJICAgIAAIABBEGoQtICAgAACQCAAKAIQQQFHDQAgACgCFCAAKAIYELWAgIAACyAAQRBqQgEQ94CAgAACQAJAIAAoAhANACAAKQMYIQEgAEEQakIBEPeAgIAAIAAoAhBBAUcNAQsACyAAIAApAxg3AwggACABNwMAIABBAhCqgICAACEBIABBIGokgICAgAAgAQsIABDCgICAAAtRAQF/I4CAgIAAQRBrIgEkgICAgAACQCAAQv8Bg0IEUQ0AAAsgASAAQiCIpxC+gICAACABKQMAIAEpAwgQuIGAgAAhACABQRBqJICAgIAAIAALDQAgAUICIACnQQFxGwu6AgQBfwF+AX8BfiOAgICAAEEQayICJICAgIAAAkAgAEL/AYNCBFINAAJAAkAgAUICUg0AQgAhAQwBCyACIAEQwICAgAAgAigCAEEBRg0BIAIpAwghA0IBIQELEMaAgIAAIAIQtICAgAACQCACKAIAQQFHDQAgAigCBCACKAIIELWAgIAAC0EBIABCIIinIgQQv4CAgAAhBQJAAkAgAVANACAFIANCARCEgICAABogAhC8gICAACACKAIAQQFHDQEgBCACKAIEIAIoAggQwYCAgAAMAQsgBUIBEI2AgIAAGgtCjvKqvPDWqusAEP2AgIAAIQUgAiABIAMQuIGAgAA3AwggAiAAQoSAgIBwgzcDACAFQaiFwIAAQQIgAkECEPiAgIAAEIyAgIAAGiACQRBqJICAgIAAQgIPCwALhwECAX8BfiOAgICAAEEQayIBJICAgIAAIAEgABCfgYCAAAJAIAEpAwAiAEICUQ0AIAEpAwghAhDGgICAACABELSAgIAAAkAgASgCAEEBRw0AIAEoAgQgASgCCBC1gICAAAsQwoCAgAAQj4CAgAAgACACEKSBgIAAIAFBEGokgICAgABCAg8LAAveBAEFfyOAgICAAEHQAGsiAiSAgICAACACQShqIAAQvIGAgAACQCACKAIoQQJGDQAgAkEIakEIaiACQShqQQhqIgMoAgA2AgAgAiACKQIoNwMIIAJBKGogARC8gYCAACACKAIoQQJGDQAgAkEYakEIaiADKAIANgIAIAIgAikCKDcDGCACQShqELSAgIAAAkAgAigCKEEBRw0AIAIoAiwgAigCMBC1gICAAAsQxoCAgAACQAJAAkAQxICAgAANABC9gYCAACIDQYD7gAMgA0GA+4ADSRshBCACIAJBGGo2AiwgAiACQQhqNgIoQQAhAwNAIANBCEYNAwJAIAJBKGogA2ooAgAiBSgCAEEBcUUNACAFKAIIIgYgBEsNAyAFKAIEIAZLDQMLIANBBGohAwwACwtCg4CAgND/ABC5gICAAAALQoOAgIDA/wAQuYCAgAAACwJAAkAgAigCCEEBRw0AIAIoAgwgAigCEBChgYCAAAwBC0EBEMWAgIAAQgIQjYCAgAAaCwJAAkAgAigCGEEBRw0AIAIoAhwgAigCIBCigYCAAAwBC0ECEMWAgIAAQgIQjYCAgAAaCyACQShqQQhqIAJBCGpBCGooAgA2AgAgAkE8aiACQRhqQQhqKAIANgIAIAIgAikDCDcDKCACIAIpAxg3AjRB4IrAgABBDxD8gICAABD9gICAACEAIAJBKGoQvoGAgAAhASACIAJBNGoQvoGAgAA3A0ggAiABNwNAIABBhIvAgABBAiACQcAAakECEPiAgIAAEIyAgIAAGiACQdAAaiSAgICAAEICDwsAC2gBAX8jgICAgABBEGsiAiSAgICAAAJAAkAgAUICUQ0AIAJBBGogARDPgYCAAAJAIAIoAgRFDQAgAEECNgIADAILIAAgAikCCDcCBCAAQQE2AgAMAQsgAEEANgIACyACQRBqJICAgIAACzMBAn4QoYCAgAAhAAJAEKKAgIAAQiCIIgEgAEIgiCIAVA0AIAGnIACnaw8LEN+AgIAAAAtDAgF/AX4jgICAgABBEGsiASSAgICAACABIAAQwIGAgAACQCABKAIAQQFHDQAACyABKQMIIQIgAUEQaiSAgICAACACC8IBAgJ/AX4jgICAgABBwABrIgAkgICAgAAgAEEIahC0gICAAAJAIAAoAghBAUcNACAAKAIMIAAoAhAQtYCAgAALIABBCGoQtICAgAAgAEEUaiIBELyAgIAAIABBMGogAEEIahDAgYCAAAJAAkAgACgCMA0AIAApAzghAiAAQTBqIAEQwIGAgAAgACgCMEEBRw0BCwALIAAgACkDODcDKCAAIAI3AyAgAEEgakECEKqAgIAAIQIgAEHAAGokgICAgAAgAgswAAJAIAEoAgBBAUcNACAAIAEoAgQgASgCCBDQgYCAAA8LIABCADcDACAAQgI3AwgLqgEBAX8jgICAgABBIGsiACSAgICAACAAQQxqELSAgIAAAkAgACgCDEEBRw0AIAAoAhAgACgCFBC1gICAAAsQxoCAgAACQBDEgICAAEUNAEKDgICA4P8AELmAgIAAAAtBABDFgICAAEIBQgIQhICAgAAaQZSLwIAAQRIQ/ICAgAAQ/YCAgABBBEEAIABBGGpBABD4gICAABCMgICAABogAEEgaiSAgICAAEICCwkAEMSAgIAArQsxAAJAIABC/wGDQgRSDQAgAUL/AYNCBFINACAAQiCIpyABQiCIpxC1gICAAEICDwsACz4CAX8BfiOAgICAAEEQayIAJICAgIAAIAAQyYCAgAAgACkDACAAKQMIELiBgIAAIQEgAEEQaiSAgICAACABCz4CAX8BfiOAgICAAEEQayIAJICAgIAAIAAQzICAgAAgACkDACAAKQMIELiBgIAAIQEgAEEQaiSAgICAACABC30CAX8BfiOAgICAAEEQayIBJICAgIAAAkAgAEL/AYNCzQBSDQAgAUEEahC0gICAAAJAIAEoAgRBAUcNACABKAIIIAEoAgwQtYCAgAALEMiAgIAAIQIQy4CAgAAgABCjgYCAACACIAAQx4GAgAAgAUEQaiSAgICAAEICDwsAC2ECAX8BfiOAgICAAEEQayICJICAgIAAQa2JwIAAQRUQ/ICAgAAQ/YCAgAAhAyACIAA3AwggAiABNwMAIANB1InAgABBAiACQQIQ+ICAgAAQjICAgAAaIAJBEGokgICAgAAL3AICAX8CfiOAgICAAEEgayICJICAgIAAAkACQAJAIABC/wGDQs0AUg0AIAFC/wGDQgRSDQAgAkEIahC0gICAAAJAIAIoAghBAUcNACACKAIMIAIoAhAQtYCAgAALEMiAgIAAIQMCQAJAIAFC/////w9WDQAgAkEIahDMgICAACACKQMQIQEgAikDCEGICBDKgICAACABIAAQhoGAgABFDQMQyYGAgAAMAQsQvYGAgAAgAUIgiKdJDQNBASAAQgAQyoGAgABBARDNgICAAEIAIAFChICAgHCDIgEgARCDgICAABpB5InAgABBFhD8gICAABD9gICAACEEIAIgATcDGCACIAM3AxAgAiAANwMIIARBgIrAgABBAyACQQhqQQMQ+ICAgAAQjICAgAAaCyACQSBqJICAgIAAQgIPCwALQoOAgIDggAEQuYCAgAAAC0KDgICA8IABELmAgIAAAAsTAEEBEM2AgIAAQgAQjYCAgAAaCxUAIAAQzYCAgAAgASACEISAgIAAGgunAQIBfwJ+I4CAgIAAQRBrIgAkgICAgAAgABC0gICAAAJAIAAoAgBBAUcNACAAKAIEIAAoAggQtYCAgAALIAAQzICAgAAgACkDCCEBIAApAwBBiAgQyoCAgAAgARCJgICAABogABDOgICAAAJAIAAoAgANABDDgICAAAALIAApAwghAhDJgYCAACABEKOBgIAAIAIgARDHgYCAACAAQRBq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BCANfSEBIAYgDCALfEJ/fCIMIAtUrXwhBgwKCyAFQYABaiAMIAqAIgxCACAIIAlrIggQ1IGAgAAgBUHwAGogAyAEIAxCABDbgYCAACAFQeAAaiAFKQNwIAUpA3ggCBDUgYCAACAFKQOIASAGfCAFKQOAASIGIAt8IgsgBlStfCEGIAcgAiAFKQNofSABIAUpA2AiDFStfSICeSABIAx9IgF5QsAAfCACQgBSG6ciCE0NASAIQT9NDQALIANQRQ0BDAILIAEgA1QiCCACIARUIAIgBFEbRQ0CIAshDAwHCyABIAOAIQILIAEgA4IhASAGIAsgAnwiDCALVK18IQZCACECDAULIAIgBH0gCK19IQIgASADfSEBIAYgC0IBfCIMUK18IQYMBAsgAiAEQgAgASADWiACIARaIAIgBFEbIggbfSABIANCACAIGyIEVK19IQIgASAEfSEBIAitIQwMAwsgASABIAOAIgwgA359IQFCACEGQgAhAgwCCyACIAIgA0L/////D4MiBIAiBiADfn1CIIYgAUIgiCIMhCAEgCICQiCGIAwgAiADfn1CIIYgAUL/////D4OEIgEgBIAiA4QhDCABIAMgBH59IQEgAkIgiCAGhCEGQgAhAgwBCyAFQTBqIAMgBEHAACAIayIIENeBgIAAIAVBIGogASACIAgQ14GAgABCACEGIAVBEGogA0IAIAUpAyAgBSkDMIAiDEIAENuBgIAAIAUgBEIAIAxCABDbgYCAACAFKQMQIQoCQAJAIAUpAwggBSkDGCINIAUpAwB8IgsgDVStfEIAUg0AIAEgClQiCCACIAtUIAIgC1EbRQ0BCyAEIAJ8IAMgAXwiASADVK18IAt9IAEgClStfSECIAxCf3whDCABIAp9IQEMAQsgAiALfSAIrX0hAiABIAp9IQFCACEGCyAAIAE3AxAgACAMNwMAIAAgAjcDGCAAIAY3AwggBUGwAWokgICAgAALoQEBAn8jgICAgABBIGsiBSSAgICAACAFQgAgAX0gASACQgBTIgYbQgAgAiABQgBSrXx9IAIgBhtCACADfSADIARCAFMiBhtCACAEIANCAFKtfH0gBCAGGxDVgYCAACAFKQMIIQMgAEIAIAUpAwAiAX0gASAEIAKFQgBTIgYbNwMAIABCACADIAFCAFKtfH0gAyAGGzcDCCAFQSBqJICA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AAAAEQIQAAYAAACEAxAABwAAAG5hdGl2ZV9mZWV6cm9fZmVlAAAAMAIQAAoAAAA6AhAABwAAAGZlZQBUAhAAAwAAAEsDEAAEAAAADAIQAAUAAABuYXRpdmVfdG9rZW5zZXRfZGVsZWdhdGVzZW5kX2NvbXBvc2VFbmRwb2ludFBlZXJlaWRwZWVyAKACEAADAAAAowIQAAQAAABtc2dfdHlwZW9wdGlvbnMAoAIQAAMAAAC4AhAACAAAAMACEAAHAAAARW5mb3JjZWRPcHRpb25zZW5mb3JjZWRfb3B0aW9uX3NldGVuZm9yY2VkX29wdGlvbl9wYXJhbXMCAxAAFgAAAGFtb3VudF9yZWNlaXZlZF9sZGFtb3VudF9zZW50X2xkZHN0X2VpZGZyb21ndWlkACADEAASAAAAMgMQAA4AAABAAxAABwAAAEcDEAAEAAAASwMQAAQAAABvZnRfcmVjZWl2ZWRzcmNfZWlkdG8AAAAgAxAAEgAAAEsDEAAEAAAAhAMQAAcAAACLAxAAAgAAAERlY2ltYWxDb252ZXJzaW9uUmF0ZVRva2VuYW1vdW50X2xkY29tcG9zZV9tc2dleHRyYV9vcHRpb25zbWluX2Ftb3VudF9sZG9mdF9jbWQAygMQAAkAAADTAxAACwAAAEADEAAHAAAA3gMQAA0AAADrAxAADQAAAPgDEAAHAAAAiwMQAAIAAABtYXhfYW1vdW50X2xkAAAAOAQQAA0AAADrAxAADQAAACADEAASAAAAMgMQAA4AAABkZXNjcmlwdGlvbmZlZV9hbW91bnRfbGRoBBAACwAAAHMEEAANAAAAAAAAEgAAAAAAAAAAAAAAEgAAAAF0aHJlc2hvbGRvd25lcnNoaXBfdHJhbnNmZXJyZWRuZXdfb3duZXJvbGRfb3duZXLCBBAACQAAAMsEEAAJAAAAb3duZXJzaGlwX3RyYW5zZmVycmluZ3R0bAAAAMIEEAAJAAAAywQQAAkAAAD6BBAAAwAAAG93bmVyc2hpcF9yZW5vdW5jZWQAywQQAAkAAABPd25lclBlbmRpbmdPd25lcmV4dGVuZF90bwAARQUQAAkAAACkBBAACQAAAHR0bF9jb25maWdzX3NldGluc3RhbmNlcGVyc2lzdGVudAAAAG8FEAAIAAAAdwUQAAoAAAB0dGxfY29uZmlnc19m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cyB1c2VkIGZvciBjcm9zcy1jaGFpbiBub3JtYWxpemF0aW9uLgAAAAAAAA9zaGFyZWRfZGVjaW1hbHMAAAAAAAAAAAEAAAAEAAAAAAAAAElSZXRyaWV2ZXMgdGhlIGRlY2ltYWwgY29udmVyc2lvbiByYXRlIHVzZWQgZm9yIGNyb3NzLWNoYWluIG5vcm1hbGl6YXRpb24uAAAAAAAAF2RlY2ltYWxfY29udmVyc2lvbl9yYXRlAAAAAAAAAAABAAAACwAAAAAAAADqV2hldGhlciBhIHNlcGFyYXRlIHRva2VuIGFwcHJvdmFsIGlzIHJlcXVpcmVkIGJlZm9yZSBzZW5kaW5nLgoKSGVscHMgd2FsbGV0IGltcGxlbWVudGVycyBkZXRlcm1pbmUgaW50ZWdyYXRpb24gcmVxdWlyZW1lbnRzLgoKIyBSZXR1cm5zCi0gYHRydWVgIGlmIGEgc2VwYXJhdGUgdG9rZW4gYXBwcm92YWwgc3RlcCBpcyByZXF1aXJlZAotIGBmYWxzZWAgaWYgbm8gc2VwYXJhdGUgYXBwcm92YWwgaXMgbmVlZGVkAAAAAAARYXBwcm92YWxfcmVxdWlyZWQAAAAAAAAAAAAAAQAAAAEAAAAAAAAAO1F1b3RlcyBhIHNlbmQgb3BlcmF0aW9uIGluY2x1ZGluZyBMYXllclplcm8gbWVzc2FnaW5nIGZlZXMuAAAAAApxdW90ZV9zZW5kAAAAAAADAAAAAAAAAARmcm9tAAAAEwAAAAAAAAAKc2VuZF9wYXJhbQAAAAAH0AAAAAlTZW5kUGFyYW0AAAAAAAAAAAAACnBheV9pbl96cm8AAAAAAAEAAAABAAAH0AAAAAxNZXNzYWdpbmdGZWUAAAAAAAAAdFNlbmRzIHRva2VucyBjcm9zcy1jaGFpbiB0byBhbm90aGVyIGVuZHBvaW50LgoKRnJvbSBtdXN0IGJlIGF1dGhlbnRpY2F0ZWQuCgojIFJldHVybnMKKE1lc3NhZ2luZ1JlY2VpcHQsIE9GVFJlY2VpcHQpAAAABHNlbmQAAAAEAAAAAAAAAARmcm9tAAAAEwAAAAAAAAAKc2VuZF9wYXJhbQAAAAAH0AAAAAlTZW5kUGFyYW0AAAAAAAAAAAAAA2ZlZQAAAAfQAAAADE1lc3NhZ2luZ0ZlZQAAAAAAAAAOcmVmdW5kX2FkZHJlc3MAAAAAABMAAAABAAAD7QAAAAIAAAfQAAAAEE1lc3NhZ2luZ1JlY2VpcHQAAAfQAAAACk9GVFJlY2VpcHQAAAAAAAAAAAAAAAAADV9fY29uc3RydWN0b3IAAAAAAAAGAAAAAAAAAAV0b2tlbgAAAAAAABMAAAAAAAAABW93bmVyAAAAAAAAEwAAAAAAAAAIZW5kcG9pbnQAAAATAAAAAAAAAAhkZWxlZ2F0ZQAAA+gAAAATAAAAAAAAAA9zaGFyZWRfZGVjaW1hbHMAAAAABAAAAAAAAAAIb2Z0X3R5cGUAAAfQAAAAB09mdFR5cGUAAAAAAAAAAAAAAABDUmV0dXJucyB0aGUgdHlwZSBvZiBvcGVyYXRpb24gZm9yIHRoaXMgT0ZUIChMb2NrVW5sb2NrIG9yIE1pbnRCdXJuKQAAAAAIb2Z0X3R5cGUAAAAAAAAAAQAAB9AAAAAHT2Z0VHlwZQAAAAAAAAAAAAAAAAphdXRob3JpemVyAAAAAAAAAAAAAQAAABMAAAAAAAAA2VJldHJpZXZlcyB0aGUgZW5mb3JjZWQgb3B0aW9ucyBmb3IgYSBnaXZlbiBlbmRwb2ludCBhbmQgbWVzc2FnZSB0eXBlLgoKIyBBcmd1bWVudHMKKiBgZWlkYCAtIFRoZSBlbmRwb2ludCBJRAoqIGBtc2dfdHlwZWAgLSBUaGUgT0FwcCBtZXNzYWdlIHR5cGUKCiMgUmV0dXJucwpUaGUgZW5mb3JjZWQgb3B0aW9ucyBmb3IgdGhlIGdpdmVuIGVuZHBvaW50IGFuZCBtZXNzYWdlIHR5cGUAAAAAAAAQZW5mb3JjZWRfb3B0aW9ucwAAAAIAAAAAAAAAA2VpZAAAAAAEAAAAAAAAAAhtc2dfdHlwZQAAAAQAAAABAAAADgAAAAAAAAKbU2V0cyB0aGUgZW5mb3JjZWQgb3B0aW9ucyBmb3Igc3BlY2lmaWMgZW5kcG9pbnQgYW5kIG1lc3NhZ2UgdHlwZSBjb21iaW5hdGlvbnMuCgpPbmx5IHRoZSBgYXV0aG9yaXplcmAgb2YgdGhlIE9BcHAgY2FuIGNhbGwgdGhpcyBmdW5jdGlvbi4KUHJvdmlkZXMgYSB3YXkgZm9yIHRoZSBPQXBwIHRvIGVuZm9yY2UgdGhpbmdzIGxpa2UgcGF5aW5nIGZvciBQcmVDcmltZSwgQU5EL09SIG1pbmltdW0gZHN0IGx6UmVjZWl2ZSBnYXMgYW1vdW50cyBldGMuClRoZXNlIGVuZm9yY2VkIG9wdGlvbnMgY2FuIHZhcnkgYXMgdGhlIHBvdGVudGlhbCBvcHRpb25zL2V4ZWN1dGlvbiBvbiB0aGUgcmVtb3RlIG1heSBkaWZmZXIgYXMgcGVyIHRoZSBtc2dfdHlwZS4KZS5nLiBBbW91bnQgb2YgbHpSZWNlaXZlKCkgZ2FzIG5lY2Vzc2FyeSB0byBkZWxpdmVyIGEgbHpDb21wb3NlKCkgbWVzc2FnZSBhZGRzIG92ZXJoZWFkIHlvdSBkb24ndCB3YW50IHRvIHBheQppZiB5b3UgYXJlIG9ubHkgbWFraW5nIGEgc3RhbmRhcmQgTGF5ZXJaZXJvIG1lc3NhZ2UgaWUuIGx6UmVjZWl2ZSgpIFdJVEhPVVQgc2VuZENvbXBvc2UoKS4KCiMgQXJndW1lbnRzCiogYG9wdGlvbnNgIC0gQSB2ZWN0b3Igb2YgRW5mb3JjZWRPcHRpb25QYXJhbSBzdHJ1Y3R1cmVzIHNwZWNpZnlpbmcgZW5mb3JjZWQgb3B0aW9ucwAAAAAUc2V0X2VuZm9yY2VkX29wdGlvbnMAAAABAAAAAAAAAAdvcHRpb25zAAAAA+oAAAfQAAAAE0VuZm9yY2VkT3B0aW9uUGFyYW0AAAAAAAAAAAAAAAJ6Q29tYmluZXMgb3B0aW9ucyBmb3IgYSBnaXZlbiBlbmRwb2ludCBhbmQgbWVzc2FnZSB0eXBlLgoKSWYgdGhlcmUgaXMgYW4gZW5mb3JjZWQgbHpSZWNlaXZlIG9wdGlvbjoKLSB7Z2FzX2xpbWl0OiAyMDBrLCB2YWx1ZTogMSBYTE19IEFORCBhIGNhbGxlciBzdXBwbGllcyBhIGx6UmVjZWl2ZSBvcHRpb246IHtnYXNfbGltaXQ6IDEwMGssIHZhbHVlOiAwLjUgWExNfQotIFRoZSByZXN1bHRpbmcgb3B0aW9ucyB3aWxsIGJlIHtnYXNfbGltaXQ6IDMwMGssIHZhbHVlOiAxLjUgWExNfSB3aGVuIHRoZSBtZXNzYWdlIGlzIGV4ZWN1dGVkIG9uIHRoZSByZW1vdGUgbHpfcmVjZWl2ZSgpIGZ1bmN0aW9uLgpUaGUgcHJlc2VuY2Ugb2YgZHVwbGljYXRlZCBvcHRpb25zIGlzIGhhbmRsZWQgb2ZmLWNoYWluIGluIHRoZSB2ZXJpZmllci9leGVjdXRvci4KCiMgQXJndW1lbnRzCiogYGVpZGAgLSBUaGUgZW5kcG9pbnQgSUQKKiBgbXNnX3R5cGVgIC0gVGhlIE9BcHAgbWVzc2FnZSB0eXBlCiogYGV4dHJhX29wdGlvbnNgIC0gQWRkaXRpb25hbCBvcHRpb25zIHBhc3NlZCBieSB0aGUgY2FsbGVyCgojIFJldHVybnMKVGhlIGNvbWJpbmF0aW9uIG9mIGNhbGxlciBzcGVjaWZpZWQgb3B0aW9ucyBBTkQgZW5mb3JjZWQgb3B0aW9ucwAAAAAAD2NvbWJpbmVfb3B0aW9ucwAAAAADAAAAAAAAAANlaWQAAAAABAAAAAAAAAAIbXNnX3R5cGUAAAAEAAAAAAAAAA1leHRyYV9vcHRpb25zAAAAAAAADgAAAAEAAAAOAAAAAAAAALdDaGVja3MgaWYgYSBtZXNzYWdpbmcgcGF0aCBjYW4gYmUgaW5pdGlhbGl6ZWQgZm9yIHRoZSBnaXZlbiBvcmlnaW4uCgojIEFyZ3VtZW50cwoqIGBvcmlnaW5gIC0gVGhlIG9yaWdpbiBvZiB0aGUgbWVzc2FnZQoKIyBSZXR1cm5zClRydWUgaWYgdGhlIHBhdGggY2FuIGJlIGluaXRpYWxpemVkLCBmYWxzZSBvdGhlcndpc2UAAAAAFWFsbG93X2luaXRpYWxpemVfcGF0aAAAAAAAAAEAAAAAAAAABm9yaWdpbgAAAAAH0AAAAAZPcmlnaW4AAAAAAAEAAAABAAAAAAAAAfhSZXRyaWV2ZXMgdGhlIG5leHQgbm9uY2UgZm9yIGEgZ2l2ZW4gc291cmNlIGVuZHBvaW50IGFuZCBzZW5kZXIgYWRkcmVzcy4KClRoZSBwYXRoIG5vbmNlIHN0YXJ0cyBmcm9tIDEuIElmIDAgaXMgcmV0dXJuZWQgaXQgbWVhbnMgdGhhdCB0aGVyZSBpcyBOTyBub25jZSBvcmRlcmVkIGVuZm9yY2VtZW50LgpUaGlzIGlzIHJlcXVpcmVkIGJ5IHRoZSBvZmYtY2hhaW4gZXhlY3V0b3IgdG8gZGV0ZXJtaW5lIGlmIHRoZSBPQXBwIGV4cGVjdHMgbWVzc2FnZSBleGVjdXRpb24gdG8gYmUgb3JkZXJlZC4KVGhpcyBpcyBhbHNvIGVuZm9yY2VkIGJ5IHRoZSBPQXBwLgpCeSBkZWZhdWx0IHRoaXMgaXMgTk9UIGVuYWJsZWQsIGkuZS4gbmV4dF9ub25jZSBpcyBoYXJkY29kZWQgdG8gcmV0dXJuIDAuCgojIEFyZ3VtZW50cwoqIGBzcmNfZWlkYCAtIFRoZSBzb3VyY2UgZW5kcG9pbnQgSUQKKiBgc2VuZGVyYCAtIFRoZSBzZW5kZXIgT0FwcCBhZGRyZXNzCgojIFJldHVybnMKVGhlIG5leHQgbm9uY2UAAAAKbmV4dF9ub25jZQAAAAAAAgAAAAAAAAAHc3JjX2VpZAAAAAAEAAAAAAAAAAZzZW5kZXIAAAAAA+4AAAAgAAAAAQAAAAYAAAAAAAADI0VudHJ5IHBvaW50IGZvciByZWNlaXZpbmcgbWVzc2FnZXMgb3IgcGFja2V0cyBmcm9tIHRoZSBMYXllclplcm8gZW5kcG9pbnQuCgpUaGUgZGVmYXVsdCBpbXBsZW1lbnRhdGlvbiBjYWxscyBgY2xlYXJfcGF5bG9hZF9hbmRfdHJhbnNmZXJgIHRvIHZhbGlkYXRlIHRoZSBtZXNzYWdlCmFuZCBjbGVhciBpdCBmcm9tIHRoZSBlbmRwb2ludCwgdGhlbiBkZWxlZ2F0ZXMgdG8gYF9fbHpfcmVjZWl2ZWAgZm9yIGFwcGxpY2F0aW9uIGxvZ2ljLgoKIyBBcmd1bWVudHMKKiBgZXhlY3V0b3JgIC0gVGhlIGFkZHJlc3Mgb2YgdGhlIGV4ZWN1dG9yIGZvciB0aGUgcmVjZWl2ZWQgbWVzc2FnZQoqIGBvcmlnaW5gIC0gVGhlIG9yaWdpbiBpbmZvcm1hdGlvbiBjb250YWluaW5nIHRoZSBzb3VyY2UgZW5kcG9pbnQgYW5kIHNlbmRlciBhZGRyZXNzOgotIGBzcmNfZWlkYDogVGhlIHNvdXJjZSBjaGFpbiBlbmRwb2ludCBJRAotIGBzZW5kZXJgOiBUaGUgc2VuZGVyIGFkZHJlc3Mgb24gdGhlIHNvdXJjZSBjaGFpbgotIGBub25jZWA6IFRoZSBub25jZSBvZiB0aGUgbWVzc2FnZQoqIGBndWlkYCAtIFRoZSB1bmlxdWUgaWRlbnRpZmllciBmb3IgdGhlIHJlY2VpdmVkIExheWVyWmVybyBtZXNzYWdlCiogYG1lc3NhZ2VgIC0gVGhlIHBheWxvYWQgb2YgdGhlIHJlY2VpdmVkIG1lc3NhZ2UKKiBgZXh0cmFfZGF0YWAgLSBBZGRpdGlvbmFsIGFyYml0cmFyeSBkYXRhIHByb3ZpZGVkIGJ5IHRoZSBjb3JyZXNwb25kaW5nIGV4ZWN1dG9yCiogYHZhbHVlYCAtIFRoZSBuYXRpdmUgdG9rZW4gdmFsdWUgc2VudCB3aXRoIHRoZSBtZXNzYWdlAAAAAApsel9yZWNlaXZlAAAAAAAGAAAAAAAAAAhleGVjdXRvcgAAABMAAAAAAAAABm9yaWdpbgAAAAAH0AAAAAZPcmlnaW4AAAAAAAAAAAAEZ3VpZAAAA+4AAAAgAAAAAAAAAAdtZXNzYWdlAAAAAA4AAAAAAAAACmV4dHJhX2RhdGEAAAAAAA4AAAAAAAAABXZhbHVlAAAAAAAACwAAAAAAAAAAAAAB7EluZGljYXRlcyB3aGV0aGVyIGFuIGFkZHJlc3MgaXMgYW4gYXBwcm92ZWQgY29tcG9zZU1zZyBzZW5kZXIgdG8gdGhlIEVuZHBvaW50LgoKQXBwbGljYXRpb25zIGNhbiBvcHRpb25hbGx5IGNob29zZSB0byBpbXBsZW1lbnQgc2VwYXJhdGUgY29tcG9zZU1zZyBzZW5kZXJzIHRoYXQgYXJlIE5PVCB0aGUgYnJpZGdpbmcgbGF5ZXIuClRoZSBkZWZhdWx0IHNlbmRlciBJUyB0aGUgT0FwcFJlY2VpdmVyIGltcGxlbWVudGVyLgoKIyBBcmd1bWVudHMKKiBgb3JpZ2luYCAtIFRoZSBvcmlnaW4gaW5mb3JtYXRpb24gY29udGFpbmluZyB0aGUgc291cmNlIGVuZHBvaW50IGFuZCBzZW5kZXIgYWRkcmVzcwoqIGBtZXNzYWdlYCAtIFRoZSBselJlY2VpdmUgcGF5bG9hZAoqIGBzZW5kZXJgIC0gVGhlIHNlbmRlciBhZGRyZXNzIHRvIGNoZWNrCgojIFJldHVybnMKVHJ1ZSBpZiB0aGUgc2VuZGVyIGlzIGEgdmFsaWQgY29tcG9zZU1zZyBzZW5kZXIsIGZhbHNlIG90aGVyd2lzZQAAABVpc19jb21wb3NlX21zZ19zZW5kZXIAAAAAAAADAAAAAAAAAAZvcmlnaW4AAAAAB9AAAAAGT3JpZ2luAAAAAAAAAAAAB21lc3NhZ2UAAAAADgAAAAAAAAAGc2VuZGVyAAAAAAATAAAAAQAAAAEAAAAAAAAArlJldHJpZXZlcyB0aGUgT0FwcCB2ZXJzaW9uIGluZm9ybWF0aW9uLgoKIyBSZXR1cm5zCkEgdHVwbGUgY29udGFpbmluZzoKLSBgc2VuZGVyX3ZlcnNpb25gOiBUaGUgdmVyc2lvbiBvZiB0aGUgT0FwcFNlbmRlcgotIGByZWNlaXZlcl92ZXJzaW9uYDogVGhlIHZlcnNpb24gb2YgdGhlIE9BcHBSZWNlaXZlcgAAAAAADG9hcHBfdmVyc2lvbgAAAAAAAAABAAAD7QAAAAIAAAAGAAAABgAAAAAAAABsUmV0cmlldmVzIHRoZSBMYXllclplcm8gZW5kcG9pbnQgYWRkcmVzcyBhc3NvY2lhdGVkIHdpdGggdGhlIE9BcHAuCgojIFJldHVybnMKVGhlIExheWVyWmVybyBlbmRwb2ludCBhZGRyZXNzAAAACGVuZHBvaW50AAAAAAAAAAEAAAATAAAAAAAAAMFSZXRyaWV2ZXMgdGhlIHBlZXIgKE9BcHApIGFzc29jaWF0ZWQgd2l0aCBhIGNvcnJlc3BvbmRpbmcgZW5kcG9pbnQuCgojIEFyZ3VtZW50cwoqIGBlaWRgIC0gVGhlIGVuZHBvaW50IElECgojIFJldHVybnMKVGhlIHBlZXIgYWRkcmVzcyAoT0FwcCBpbnN0YW5jZSkgYXNzb2NpYXRlZCB3aXRoIHRoZSBjb3JyZXNwb25kaW5nIGVuZHBvaW50AAAAAAAABHBlZXIAAAABAAAAAAAAAANlaWQAAAAABAAAAAEAAAPoAAAD7gAAACAAAAAAAAAA5VNldHMgb3IgcmVtb3ZlcyB0aGUgcGVlciBhZGRyZXNzIChPQXBwIGluc3RhbmNlKSBmb3IgYSBjb3JyZXNwb25kaW5nIGVuZHBvaW50LgoKIyBBcmd1bWVudHMKKiBgZWlkYCAtIFRoZSBlbmRwb2ludCBJRAoqIGBwZWVyYCAtIFRoZSBhZGRyZXNzIG9mIHRoZSBwZWVyIHRvIGJlIGFzc29jaWF0ZWQgd2l0aCB0aGUgY29ycmVzcG9uZGluZyBlbmRwb2ludCwgb3IgTm9uZSB0byByZW1vdmUgdGhlIHBlZXIAAAAAAAAIc2V0X3BlZXIAAAACAAAAAAAAAANlaWQAAAAABAAAAAAAAAAEcGVlcgAAA+gAAAPuAAAAIAAAAAAAAAAAAAAAjlNldHMgdGhlIGRlbGVnYXRlIGFkZHJlc3MgZm9yIHRoZSBPQXBwIENvcmUuCgojIEFyZ3VtZW50cwoqIGBkZWxlZ2F0ZWAgLSBUaGUgYWRkcmVzcyBvZiB0aGUgZGVsZWdhdGUgdG8gYmUgc2V0LCBvciBOb25lIHRvIHJlbW92ZSB0aGUgZGVsZWdhdGUAAAAAAAxzZXRfZGVsZWdhdGUAAAABAAAAAAAAAAhkZWxlZ2F0ZQAAA+gAAAATAAAAAAAAAAAAAAGPU2V0cyBUVEwgY29uZmlncyBmb3IgaW5zdGFuY2UgYW5kIHBlcnNpc3RlbnQgc3RvcmFnZS4KCi0gYE5vbmVgIHZhbHVlcyByZW1vdmUgdGhlIGNvcnJlc3BvbmRpbmcgY29uZmlnIChkaXNhYmxlcyBhdXRvLWV4dGVuc2lvbiBmb3IgdGhhdCB0eXBlKQotIFZhbGlkYXRlcyB0aGF0IGB0aHJlc2hvbGQgPD0gZXh0ZW5kX3RvIDw9IE1BWF9UVExgCgojIEFyZ3VtZW50cwotIGBpbnN0YW5jZWAgLSBUVEwgY29uZmlnIGZvciBpbnN0YW5jZSBzdG9yYWdlCi0gYHBlcnNpc3RlbnRgIC0gVFRMIGNvbmZpZyBmb3IgcGVyc2lzdGVudCBzdG9yYWdlCgojIFBhbmljcwotIGBUdGxDb25maWdGcm96ZW5gIGlmIGNvbmZpZ3MgYXJlIGZyb3plbgotIGBJbnZhbGlkVHRsQ29uZmlnYCBpZiB2YWxpZGF0aW9uIGZhaWxzAAAAAA9zZXRfdHRsX2NvbmZpZ3MAAAAAAgAAAAAAAAAIaW5zdGFuY2UAAAPoAAAH0AAAAAlUdGxDb25maWcAAAAAAAAAAAAACnBlcnNpc3RlbnQAAAAAA+gAAAfQAAAACVR0bENvbmZpZwAAAAAAAAAAAAAAAAAASFJldHVybnMgdGhlIGN1cnJlbnQgVFRMIGNvbmZpZ3MgYXMgKGluc3RhbmNlX2NvbmZpZywgcGVyc2lzdGVudF9jb25maWcpLgAAAAt0dGxfY29uZmlncwAAAAAAAAAAAQAAA+0AAAACAAAD6AAAB9AAAAAJVHRsQ29uZmlnAAAAAAAD6AAAB9AAAAAJVHRsQ29uZmlnAAAAAAAAAAAAAOFQZXJtYW5lbnRseSBmcmVlemVzIFRUTCBjb25maWdzLCBwcmV2ZW50aW5nIGFueSBmdXR1cmUgbW9kaWZpY2F0aW9ucy4KClRoaXMgaXMgaXJyZXZlcnNpYmxlIGFuZCBwcm92aWRlcyBpbW11dGFiaWxpdHkgZ3VhcmFudGVlcyB0byB1c2Vycy4KRW1pdHMgYFR0bENvbmZpZ3NGcm96ZW5gIGV2ZW50LgoKIyBQYW5pY3MKLSBgVHRsQ29uZmlnQWxyZWFkeUZyb3plbmAgaWYgYWxyZWFkeSBmcm96ZW4AAAAAAAASZnJlZXplX3R0bF9jb25maWdzAAAAAAAAAAAAAAAAAAAAAAAnUmV0dXJucyB3aGV0aGVyIFRUTCBjb25maWdzIGFyZSBmcm96ZW4uAAAAABVpc190dGxfY29uZmlnc19mcm96ZW4AAAAAAAAAAAAAAQAAAAEAAAAAAAAApUV4dGVuZHMgdGhlIGluc3RhbmNlIFRUTC4KCiMgQXJndW1lbnRzCgoqIGB0aHJlc2hvbGRgIC0gVGhlIHRocmVzaG9sZCB0byBleHRlbmQgdGhlIFRUTCAoaWYgY3VycmVudCBUVEwgaXMgYmVsb3cgdGhpcywgZXh0ZW5kKS4KKiBgZXh0ZW5kX3RvYCAtIFRoZSBUVEwgdG8gZXh0ZW5kIHRvLgAAAAAAABNleHRlbmRfaW5zdGFuY2VfdHRsAAAAAAIAAAAAAAAACXRocmVzaG9sZAAAAAAAAAQAAAAAAAAACWV4dGVuZF90bwAAAAAAAAQAAAAAAAAAAAAAAD5SZXR1cm5zIHRoZSBjdXJyZW50IG93bmVyIGFkZHJlc3MsIG9yIE5vbmUgaWYgbm8gb3duZXIgaXMgc2V0LgAAAAAABW93bmVyAAAAAAAAAAAAAAEAAAPoAAAAEwAAAAAAAABZUmV0dXJucyB0aGUgcGVuZGluZyBvd25lciBhZGRyZXNzIGZvciAyLXN0ZXAgdHJhbnNmZXIsIG9yIE5vbmUgaWYgbm8gdHJhbnNmZXIgaXMgcGVuZGluZy4AAAAAAAANcGVuZGluZ19vd25lcgAAAAAAAAAAAAABAAAD6AAAABMAAAAAAAABK1RyYW5zZmVycyBvd25lcnNoaXAgaW1tZWRpYXRlbHkgdG8gYSBuZXcgYWRkcmVzcy4KClVzZSB3aXRoIGNhdXRpb24gLSBpZiB5b3UgdHJhbnNmZXIgdG8gYSB3cm9uZyBhZGRyZXNzLCBvd25lcnNoaXAgaXMgbG9zdCBmb3JldmVyLgpDb25zaWRlciB1c2luZyBgcHJvcG9zZV9vd25lcnNoaXBfdHJhbnNmZXJgIGluc3RlYWQuCgojIFBhbmljcwotIGBPd25lck5vdFNldGAgaWYgbm8gb3duZXIgaXMgY3VycmVudGx5IHNldAotIGBUcmFuc2ZlckluUHJvZ3Jlc3NgIGlmIGEgMi1zdGVwIHRyYW5zZmVyIGlzIGluIHByb2dyZXNzAAAAABJ0cmFuc2Zlcl9vd25lcnNoaXAAAAAAAAEAAAAAAAAACW5ld19vd25lcgAAAAAAABMAAAAAAAAAAAAAAlxQcm9wb3NlcyBhbiBvd25lcnNoaXAgdHJhbnNmZXIgdG8gYSBuZXcgYWRkcmVzcy4KClRoZSBuZXcgb3duZXIgbXVzdCBjYWxsIGBhY2NlcHRfb3duZXJzaGlwKClgIHdpdGhpbiBgdHRsYCBsZWRnZXJzCnRvIGNvbXBsZXRlIHRoZSB0cmFuc2Zlci4gVGhlIHBlbmRpbmcgdHJhbnNmZXIgd2lsbCBhdXRvbWF0aWNhbGx5IGV4cGlyZSBhZnRlci4KCiMgQXJndW1lbnRzCi0gYG5ld19vd25lcmAgLSBUaGUgcHJvcG9zZWQgbmV3IG93bmVyCi0gYHR0bGAgLSBOdW1iZXIgb2YgbGVkZ2VycyB0aGUgbmV3IG93bmVyIGhhcyB0byBhY2NlcHQuClVzZSBgMGAgdG8gY2FuY2VsIGEgcGVuZGluZyB0cmFuc2ZlciAobmV3X293bmVyIG11c3QgbWF0Y2ggcGVuZGluZykuCgojIFBhbmljcwotIGBPd25lck5vdFNldGAgaWYgbm8gb3duZXIgaXMgY3VycmVudGx5IHNldAotIGBOb1BlbmRpbmdUcmFuc2ZlcmAgd2hlbiBjYW5jZWxsaW5nIGFuZCBubyBwZW5kaW5nIHRyYW5zZmVyIGV4aXN0cwotIGBJbnZhbGlkVHRsYCBpZiB0dGwgZXhjZWVkcyBtYXggVFRMCi0gYEludmFsaWRQZW5kaW5nT3duZXJgIHdoZW4gY2FuY2VsbGluZyB3aXRoIHdyb25nIG5ld19vd25lciBhZGRyZXNzAAAAGnByb3Bvc2Vfb3duZXJzaGlwX3RyYW5zZmVyAAAAAAACAAAAAAAAAAluZXdfb3duZXIAAAAAAAATAAAAAAAAAAN0dGwAAAAABAAAAAAAAAAAAAAAuUFjY2VwdHMgYSBwZW5kaW5nIDItc3RlcCBvd25lcnNoaXAgdHJhbnNmZXIuCgpNdXN0IGJlIGNhbGxlZCBieSB0aGUgcGVuZGluZyBvd25lciBiZWZvcmUgdGhlIFRUTCBleHBpcmVzLgoKIyBQYW5pY3MKLSBgTm9QZW5kaW5nVHJhbnNmZXJgIGlmIHRoZXJlIGlzIG5vIHBlbmRpbmcgdHJhbnNmZXIgKG9yIGl0IGV4cGlyZWQpAAAAAAAAEGFjY2VwdF9vd25lcnNoaXAAAAAAAAAAAAAAAAAAAACkUGVybWFuZW50bHkgcmVub3VuY2VzIG93bmVyc2hpcC4KCiMgUGFuaWNzCi0gYE93bmVyTm90U2V0YCBpZiBubyBvd25lciBpcyBjdXJyZW50bHkgc2V0Ci0gYFRyYW5zZmVySW5Qcm9ncmVzc2AgaWYgYSAyLXN0ZXAgdHJhbnNmZXIgaXMgaW4gcHJvZ3Jlc3MgKGNhbmNlbCBpdCBmaXJzdCkAAAAScmVub3VuY2Vfb3duZXJzaGlwAAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAAAA1FbmRwb2ludEVycm9yAAAAAAAAGQAAAAAAAAARQWxyZWFkeVJlZ2lzdGVyZWQAAAAAAAABAAAAAAAAAA1Db21wb3NlRXhpc3RzAAAAAAAAAgAAAAAAAAAPQ29tcG9zZU5vdEZvdW5kAAAAAAMAAAAAAAAAHERlZmF1bHRSZWNlaXZlTGliVW5hdmFpbGFibGUAAAAEAAAAAAAAABlEZWZhdWx0U2VuZExpYlVuYXZhaWxhYmxlAAAAAAAABQAAAAAAAAAVSW5zdWZmaWNpZW50TmF0aXZlRmVlAAAAAAAABgAAAAAAAAAS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bmcgYSBjcm9zcy1jaGFpbiBtZXNzYWdlLgAAAAAAAAAAAAAPTWVzc2FnaW5nUGFyYW1zAAAAAAUAAAArRGVzdGluYXRpb24gZW5kcG9pbnQgSUQgKGNoYWluIGlkZW50aWZpZXIpLgAAAAAHZHN0X2VpZAAAAAAEAAAAHFRoZSBtZXNzYWdlIHBheWxvYWQgdG8gc2VuZC4AAAAHbWVzc2FnZQAAAAAOAAAAIUVuY29kZWQgZXhlY3V0b3IgYW5kIERWTiBvcHRpb25zLgAAAAAAAAdvcHRpb25zAAAAAA4AAAA5V2hldGhlciB0byBwYXkgZmVlcyBpbiBaUk8gdG9rZW4gaW5zdGVhZCBvZiBuYXRpdmUgdG9rZW4uAAAAAAAACnBheV9pbl96cm8AAAAAAAEAAAA1UmVjZWl2ZXIgYWRkcmVzcyBvbiB0aGUgZGVzdGluYXRpb24gY2hhaW4gKDMyIGJ5dGVzKS4AAAAAAAAIcmVjZWl2ZXIAAAPuAAAAIAAAAAEAAABNU291cmNlIG1lc3NhZ2UgaW5mb3JtYXRpb24gaWRlbnRpZnlpbmcgd2hlcmUgYSBjcm9zcy1jaGFpbiBtZXNzYWdlIGNhbWUgZnJvbS4AAAAAAAAAAAAABk9yaWdpbgAAAAAAAwAAABdOb25jZSBmb3IgdGhpcyBwYXRod2F5LgAAAAAFbm9uY2UAAAAAAAAGAAAALlNlbmRlciBhZGRyZXNzIG9uIHRoZSBzb3VyY2UgY2hhaW4gKDMyIGJ5dGVzKS4AAAAAAAZzZW5kZXIAAAAAA+4AAAAgAAAAJlNvdXJjZSBlbmRwb2ludCBJRCAoY2hhaW4gaWRlbnRpZmllcikuAAAAAAAHc3JjX2VpZAAAAAAEAAAAAQAAAChGZWUgc3RydWN0dXJlIGZvciBjcm9zcy1jaGFpbiBtZXNzYWdpbmcuAAAAAAAAAAxNZXNzYWdpbmdGZWUAAAACAAAAH0ZlZSBwYWlkIGluIG5hdGl2ZSB0b2tlbiAoWExNKS4AAAAACm5hdGl2ZV9mZWUAAAAAAAsAAAAoRmVlIHBhaWQgaW4gWlJPIHRva2VuIChMYXllclplcm8gdG9rZW4pLgAAAAd6cm9fZmVlAAAAAAsAAAABAAAAQlJlY2VpcHQgcmV0dXJuZWQgYWZ0ZXIgc3VjY2Vzc2Z1bGx5IHNlbmRpbmcgYSBjcm9zcy1jaGFpbiBtZXNzYWdlLgAAAAAAAAAAABBNZXNzYWdpbmdSZWNlaXB0AAAAAwAAAClUaGUgZmVlcyBjaGFyZ2VkIGZvciBzZW5kaW5nIHRoZSBtZXNzYWdlLgAAAAAAAANmZWUAAAAH0AAAAAxNZXNzYWdpbmdGZWUAAAArR2xvYmFsbHkgdW5pcXVlIGlkZW50aWZpZXIgZm9yIHRoZSBtZXNzYWdlLgAAAAAEZ3VpZAAAA+4AAAAgAAAAJFRoZSBvdXRib3VuZCBub25jZSBmb3IgdGhpcyBwYXRod2F5LgAAAAVub25jZQAAAAAAAAYAAAACAAAAOFR5cGUgb2YgbWVzc2FnZSBsaWJyYXJ5IGluZGljYXRpbmcgc3VwcG9ydGVkIG9wZXJhdGlvbnMuAAAAAAAAAA5NZXNzYWdlTGliVHlwZQAAAAAAAwAAAAAAAAAfU3VwcG9ydHMgb25seSBzZW5kaW5nIG1lc3NhZ2VzLgAAAAAEU2VuZAAAAAAAAAAhU3VwcG9ydHMgb25seSByZWNlaXZpbmcgbWVzc2FnZXMuAAAAAAAAB1JlY2VpdmUAAAAAAAAAAC1TdXBwb3J0cyBib3RoIHNlbmRpbmcgYW5kIHJlY2VpdmluZyBtZXNzYWdlcy4AAAAAAAAOU2VuZEFuZFJlY2VpdmUAAAAAAAEAAAC3VmVyc2lvbiBpbmZvcm1hdGlvbiBmb3IgYSBtZXNzYWdlIGxpYnJhcnkuCgpOb3RlOiBgbWlub3JgIGFuZCBgZW5kcG9pbnRfdmVyc2lvbmAgdXNlIGB1MzJgIGluc3RlYWQgb2YgYHU4YCBiZWNhdXNlIFN0ZWxsYXIgZG9lcyBub3QKc3VwcG9ydCBgdThgIHR5cGVzIGluIGNvbnRyYWN0IGludGVyZmFjZSBmdW5jdGlvbnMuAAAAAAAAAAARTWVzc2FnZUxpYlZlcnNpb24AAAAAAAADAAAAM0VuZHBvaW50IHZlcnNpb24gKHNob3VsZCBub3QgZXhjZWVkIHU4OjpNQVggPSAyNTUpLgAAAAAQZW5kcG9pbnRfdmVyc2lvbgAAAAQAAAAVTWFqb3IgdmVyc2lvbiBudW1iZXIuAAAAAAAABW1ham9yAAAAAAAABgAAADdNaW5vciB2ZXJzaW9uIG51bWJlciAoc2hvdWxkIG5vdCBleGNlZWQgdTg6Ok1BWCA9IDI1NSkuAAAAAAVtaW5vcgAAAAAAAAQAAAABAAAANlRpbWVvdXQgY29uZmlndXJhdGlvbiBmb3IgcmVjZWl2ZSBsaWJyYXJ5IHRyYW5zaXRpb25zLgAAAAAAAAAAAAdUaW1lb3V0AAAAAAIAAAAoVW5peCB0aW1lc3RhbXAgd2hlbiB0aGUgdGltZW91dCBleHBpcmVzLgAAAAZleHBpcnkAAAAAAAYAAAApVGhlIG5ldyBsaWJyYXJ5IGFkZHJlc3MgdG8gdHJhbnNpdGlvbiB0by4AAAAAAAADbGliAAAAABMAAAABAAAANVBhcmFtZXRlcnMgZm9yIHNldHRpbmcgbWVzc2FnZSBsaWJyYXJ5IGNvbmZpZ3VyYXRpb24uAAAAAAAAAAAAAA5TZXRDb25maWdQYXJhbQAAAAAAAwAAAB9YRFItZW5jb2RlZCBjb25maWd1cmF0aW9uIGRhdGEuAAAAAAZjb25maWcAAAAAAA4AAAAwVGhlIHR5cGUgb2YgY29uZmlndXJhdGlvbiAoZS5nLiwgZXhlY3V0b3IsIFVMTikuAAAAC2NvbmZpZ190eXBlAAAAAAQAAAAnVGhlIGVuZHBvaW50IElEIHRoaXMgY29uZmlnIGFwcGxpZXMgdG8uAAAAAANlaWQAAAAABAAAAAEAAAAxUmVzb2x2ZWQgbGlicmFyeSBpbmZvcm1hdGlvbiB3aXRoIGRlZmF1bHQgc3RhdHVzLgAAAAAAAAAAAAAPUmVzb2x2ZWRMaWJyYXJ5AAAAAAIAAABEV2hldGhlciB0aGlzIGlzIHRoZSBkZWZhdWx0IGxpYnJhcnkgKHRydWUpIG9yIE9BcHAtc3BlY2lmaWMgKGZhbHNlKS4AAAAKaXNfZGVmYXVsdAAAAAAAAQAAAB1UaGUgcmVzb2x2ZWQgbGlicmFyeSBhZGRyZXNzLgAAAAAAAANsaWIAAAAAEwAAAAEAAABIT3V0Ym91bmQgcGFja2V0IGNvbnRhaW5pbmcgYWxsIGluZm9ybWF0aW9uIGZvciBjcm9zcy1jaGFpbiB0cmFuc21pc3Npb24uAAAAAAAAAA5PdXRib3VuZFBhY2tldAAAAAAABwAAABhEZXN0aW5hdGlvbiBlbmRwb2ludCBJRC4AAAAHZHN0X2VpZAAAAAAEAAAALEdsb2JhbGx5IHVuaXF1ZSBpZGVudGlmaWVyIGZvciB0aGlzIG1lc3NhZ2UuAAAABGd1aWQAAAPuAAAAIAAAABRUaGUgbWVzc2FnZSBwYXlsb2FkLgAAAAdtZXNzYWdlAAAAAA4AAAAgT3V0Ym91bmQgbm9uY2UgZm9yIHRoaXMgcGF0aHdheS4AAAAFbm9uY2UAAAAAAAAGAAAAMVJlY2VpdmVyIGFkZHJlc3Mgb24gZGVzdGluYXRpb24gY2hhaW4gKDMyIGJ5dGVzKS4AAAAAAAAIcmVjZWl2ZXIAAAPuAAAAIAAAAB9TZW5kZXIgYWRkcmVzcyBvbiBzb3VyY2UgY2hhaW4uAAAAAAZzZW5kZXIAAAAAABMAAAATU291cmNlIGVuZHBvaW50IElELgAAAAAHc3JjX2VpZAAAAAAEAAAAAQAAACtBIGZlZSByZWNpcGllbnQgd2l0aCB0aGUgYW1vdW50IHRvIGJlIHBhaWQuAAAAAAAAAAAMRmVlUmVjaXBpZW50AAAAAgAAABVBbW91bnQgb2YgZmVlIHRvIHBheS4AAAAAAAAGYW1vdW50AAAAAAALAAAAH1RoZSBhZGRyZXNzIHRvIHNlbmQgdGhlIGZlZSB0by4AAAAAAnRvAAAAAAATAAAAAQAAADxSZXN1bHQgb2Ygc2VuZCBvcGVyYXRpb24gY29udGFpbmluZyBmZWVzIGFuZCBlbmNvZGVkIHBhY2tldC4AAAAAAAAADUZlZXNBbmRQYWNrZXQAAAAAAAADAAAAKlRoZSBlbmNvZGVkIHBhY2tldCByZWFkeSBmb3IgdHJhbnNtaXNzaW9uLgAAAAAADmVuY29kZWRfcGFja2V0AAAAAAAOAAAAP0xpc3Qgb2YgbmF0aXZlIHRva2VuIGZlZSByZWNpcGllbnRzIChleGVjdXRvciwgRFZOcywgdHJlYXN1cnkpLgAAAAAVbmF0aXZlX2ZlZV9yZWNpcGllbnRzAAAAAAAD6gAAB9AAAAAMRmVlUmVjaXBpZW50AAAALExpc3Qgb2YgWlJPIHRva2VuIGZlZSByZWNpcGllbnRzICh0cmVhc3VyeSkuAAAAEnpyb19mZWVfcmVjaXBpZW50cwAAAAAD6gAAB9AAAAAMRmVlUmVjaXBpZW50AAAABAAAABRPQXBwRXJyb3I6IDIwMDAtMjA5OQAAAAAAAAAJT0FwcEVycm9yAAAAAAAABAAAAAAAAAAOSW52YWxpZE9wdGlvbnMAAAAAB9AAAAAAAAAABk5vUGVlcgAAAAAH0QAAAAAAAAAIT25seVBlZXIAAAfSAAAAAAAAABNacm9Ub2tlblVuYXZhaWxhYmxlAAAAB9MAAAACAAAAAAAAAAAAAAAPT0FwcENvcmVTdG9yYWdlAAAAAAIAAAAAAAAAAAAAAAhFbmRwb2ludAAAAAEAAAAAAAAABFBlZXIAAAABAAAABAAAAAUAAAAAAAAAAAAAAAdQZWVyU2V0AAAAAAEAAAAIcGVlcl9zZXQAAAACAAAAAAAAAANlaWQAAAAABAAAAAAAAAAAAAAABHBlZXIAAAPoAAAD7gAAACAAAAAAAAAAAgAAAAEAAAAAAAAAAAAAABNFbmZvcmNlZE9wdGlvblBhcmFtAAAAAAMAAAAAAAAAA2VpZAAAAAAEAAAAAAAAAAhtc2dfdHlwZQAAAAQAAAAAAAAAB29wdGlvbnMAAAAADgAAAAIAAAAAAAAAAAAAABdPQXBwT3B0aW9uc1R5cGUzU3RvcmFnZQAAAAABAAAAAQAAAAAAAAAPRW5mb3JjZWRPcHRpb25zAAAAAAIAAAAEAAAABAAAAAUAAAAAAAAAAAAAABFFbmZvcmNlZE9wdGlvblNldAAAAAAAAAEAAAATZW5mb3JjZWRfb3B0aW9uX3NldAAAAAABAAAAAAAAABZlbmZvcmNlZF9vcHRpb25fcGFyYW1zAAAAAAPqAAAH0AAAABNFbmZvcmNlZE9wdGlvblBhcmFtAAAAAAAAAAACAAAABAAAABNPRlRFcnJvcjogMzAwMC0zMDk5AAAAAAAAAAAIT0ZURXJyb3IAAAAEAAAAAAAAABRJbnZhbGlkTG9jYWxEZWNpbWFscwAAC7gAAAAAAAAADk5vdEluaXRpYWxpemVkAAAAAAu5AAAAAAAAAAhPdmVyZmxvdwAAC7oAAAAAAAAAEFNsaXBwYWdlRXhjZWVkZWQAAAu7AAAABQAAAAAAAAAAAAAAB09GVFNlbnQAAAAAAQAAAAhvZnRfc2VudAAAAAUAAAAAAAAABGd1aWQAAAPuAAAAIAAAAAAAAAAAAAAAB2RzdF9laWQAAAAABAAAAAAAAAAAAAAABGZyb20AAAATAAAAAAAAAAAAAAAOYW1vdW50X3NlbnRfbGQAAAAAAAsAAAAAAAAAAAAAABJhbW91bnRfcmVjZWl2ZWRfbGQAAAAAAAsAAAAAAAAAAgAAAAUAAAAAAAAAAAAAAAtPRlRSZWNlaXZlZAAAAAABAAAADG9mdF9yZWNlaXZlZAAAAAQAAAAAAAAABGd1aWQAAAPuAAAAIAAAAAAAAAAAAAAAB3NyY19laWQAAAAABAAAAAAAAAAAAAAAAnRvAAAAAAATAAAAAAAAAAAAAAASYW1vdW50X3JlY2VpdmVkX2xkAAAAAAALAAAAAAAAAAIAAAACAAAAAAAAAAAAAAAKT0ZUU3RvcmFnZQAAAAAAAgAAAAAAAAAAAAAAFURlY2ltYWxDb252ZXJzaW9uUmF0ZQAAAAAAAAAAAAAAAAAABVRva2VuAAAAAAAAAQAAAC1QYXJhbWV0ZXJzIGZvciBzZW5kaW5nIE9GVCB0b2tlbnMgY3Jvc3MtY2hhaW4AAAAAAAAAAAAACVNlbmRQYXJhbQAAAAAAAAcAAAAkVGhlIGFtb3VudCB0byBzZW5kIGluIGxvY2FsIGRlY2ltYWxzAAAACWFtb3VudF9sZAAAAAAAAAsAAAA4Q29tcG9zZSBtZXNzYWdlIHRvIGV4ZWN1dGUgb24gdGhlIGRlc3RpbmF0aW9uIChPcHRpb25hbCkAAAALY29tcG9zZV9tc2cAAAAADgAAABtUaGUgZGVzdGluYXRpb24gZW5kcG9pbnQgSUQAAAAAB2RzdF9laWQAAAAABAAAADdBZGRpdGlvbmFsIG9wdGlvbnMgZm9yIHRoZSBMYXllclplcm8gbWVzc2FnZSAoT3B0aW9uYWwpAAAAAA1leHRyYV9vcHRpb25zAAAAAAAADgAAAEVUaGUgbWluaW11bSBhbW91bnQgdG8gcmVjZWl2ZSBpbiBsb2NhbCBkZWNpbWFscyAoc2xpcHBhZ2UgcHJvdGVjdGlvbikAAAAAAAANbWluX2Ftb3VudF9sZAAAAAAAAAsAAAAqT0ZUIGNvbW1hbmQgZm9yIGN1c3RvbSBiZWhhdmlvciAoT3B0aW9uYWwpAAAAAAAHb2Z0X2NtZAAAAAAOAAAAOVRoZSByZWNpcGllbnQgYWRkcmVzcyBvbiB0aGUgZGVzdGluYXRpb24gY2hhaW4gKDMyIGJ5dGVzKQAAAAAAAAJ0bwAAAAAD7gAAACAAAAABAAAAIlRyYW5zZmVyIGxpbWl0cyBmb3IgT0ZUIG9wZXJhdGlvbnMAAAAAAAAAAAAIT0ZUTGltaXQAAAACAAAALFRoZSBtYXhpbXVtIGFtb3VudCB0byBzZW5kIGluIGxvY2FsIGRlY2ltYWxzAAAADW1heF9hbW91bnRfbGQAAAAAAAALAAAALFRoZSBtaW5pbXVtIGFtb3VudCB0byBzZW5kIGluIGxvY2FsIGRlY2ltYWxzAAAADW1pbl9hbW91bnRfbGQAAAAAAAALAAAAAQAAAD9SZWNlaXB0IGNvbnRhaW5pbmcgYW1vdW50cyBzZW50IGFuZCByZWNlaXZlZCBpbiBhbiBPRlQgdHJhbnNmZXIAAAAAAAAAAApPRlRSZWNlaXB0AAAAAAACAAAAM1RoZSBhbW91bnQgcmVjZWl2ZWQgaW4gbG9jYWwgZGVjaW1hbHMgb24gdGhlIHJlbW90ZQAAAAASYW1vdW50X3JlY2VpdmVkX2xkAAAAAAALAAAAIVRoZSBhbW91bnQgc2VudCBpbiBsb2NhbCBkZWNpbWFscwAAAAAAAA5hbW91bnRfc2VudF9sZAAAAAAACwAAAAEAAAAuRGV0YWlscyBhYm91dCBmZWVzIGNoYXJnZWQgaW4gYW4gT0ZUIG9wZXJhdGlvbgAAAAAAAAAAAAxPRlRGZWVEZXRhaWwAAAACAAAAGlRoZSBkZXNjcmlwdGlvbiBvZiB0aGUgZmVlAAAAAAALZGVzY3JpcHRpb24AAAAADgAAAH9UaGUgYW1vdW50IG9mIHRoZSBmZWUgaW4gbG9jYWwgZGVjaW1hbHMuIFBvc2l0aXZlIHZhbHVlcyByZXByZXNlbnQgZmVlcyBjaGFyZ2VkLAp3aGlsZSBuZWdhdGl2ZSB2YWx1ZXMgcmVwcmVzZW50IHJld2FyZHMgZ2l2ZW4uAAAAAA1mZWVfYW1vdW50X2xkAAAAAAAACwAAAAQAAAAcQnVmZmVyUmVhZGVyRXJyb3I6IDEwMDAtMTAwOQAAAAAAAAARQnVmZmVyUmVhZGVyRXJyb3IAAAAAAAACAAAAAAAAAA1JbnZhbGlkTGVuZ3RoAAAAAAAD6AAAAAAAAAAVSW52YWxpZEFkZHJlc3NQYXlsb2FkAAAAAAAD6QAAAAQAAAAcQnVmZmVyV3JpdGVyRXJyb3I6IDEwMTAtMTAxOQAAAAAAAAARQnVmZmVyV3JpdGVyRXJyb3IAAAAAAAABAAAAAAAAABVJbnZhbGlkQWRkcmVzc1BheWxvYWQAAAAAAAPyAAAABAAAAB9UdGxDb25maWd1cmFibGVFcnJvcjogMTAyMC0xMDI5AAAAAAAAAAAUVHRsQ29uZmlndXJhYmxlRXJyb3IAAAADAAAAAAAAABBJbnZhbGlkVHRsQ29uZmlnAAAD/AAAAAAAAAAPVHRsQ29uZmlnRnJvemVuAAAAA/0AAAAAAAAAFlR0bENvbmZpZ0FscmVhZHlGcm96ZW4AAAAAA/4AAAAEAAAAF093bmFibGVFcnJvcjogMTAzMC0xMDM5AAAAAAAAAAAMT3duYWJsZUVycm9yAAAABgAAAAAAAAATSW52YWxpZFBlbmRpbmdPd25lcgAAAAQGAAAAAAAAAApJbnZhbGlkVHRsAAAAAAQHAAAAAAAAABFOb1BlbmRpbmdUcmFuc2ZlcgAAAAAABAgAAAAAAAAAD093bmVyQWxyZWFkeVNldAAAAAQJAAAAAAAAAAtPd25lck5vdFNldAAAAAQKAAAAAAAAABJUcmFuc2ZlckluUHJvZ3Jlc3MAAAAABAsAAAAEAAAAGEJ5dGVzRXh0RXJyb3I6IDEwNDAtMTA0OQAAAAAAAAANQnl0ZXNFeHRFcnJvcgAAAAAAAAEAAAAAAAAADkxlbmd0aE1pc21hdGNoAAAAAAQQAAAABAAAABtVcGdyYWRlYWJsZUVycm9yOiAxMDUwLTEwNTkAAAAAAAAAABBVcGdyYWRlYWJsZUVycm9yAAAAAwAAAAAAAAAUSW52YWxpZE1pZ3JhdGlvbkRhdGEAAAQaAAAAAAAAABNNaWdyYXRpb25Ob3RBbGxvd2VkAAAABBsAAAAAAAAADlVwZ3JhZGVzRnJvemVuAAAAAAQcAAAABAAAABhNdWx0aXNpZ0Vycm9yOiAxMDYwLTEwNjkAAAAAAAAADU11bHRpc2lnRXJyb3IAAAAAAAAIAAAAAAAAABJBbHJlYWR5SW5pdGlhbGl6ZWQAAAAABCQAAAAAAAAADUludmFsaWRTaWduZXIAAAAAAAQlAAAAAAAAAA5TaWduYXR1cmVFcnJvcgAAAAAEJgAAAAAAAAATU2lnbmVyQWxyZWFkeUV4aXN0cwAAAAQnAAAAAAAAAA5TaWduZXJOb3RGb3VuZAAAAAAEKAAAAAAAAAAdVG90YWxTaWduZXJzTGVzc1RoYW5UaHJlc2hvbGQAAAAAAAQpAAAAAAAAAA9VbnNvcnRlZFNpZ25lcnMAAAAEKgAAAAAAAAANWmVyb1RocmVzaG9sZAAAAAAABCsAAAAFAAAAMEV2ZW50IGVtaXR0ZWQgd2hlbiBhIHNpZ25lciBpcyBhZGRlZCBvciByZW1vdmVkLgAAAAAAAAAJU2lnbmVyU2V0AAAAAAAAAQAAAApzaWduZXJfc2V0AAAAAAACAAAAAAAAAAZzaWduZXIAAAAAA+4AAAAUAAAAAQAAAAAAAAAGYWN0aXZlAAAAAAABAAAAAAAAAAIAAAAFAAAANkV2ZW50IGVtaXR0ZWQgd2hlbiB0aGUgc2lnbmF0dXJlIHRocmVzaG9sZCBpcyBjaGFuZ2VkLgAAAAAAAAAAAAxUaHJlc2hvbGRTZXQAAAABAAAADXRocmVzaG9sZF9zZXQAAAAAAAABAAAAAAAAAAl0aHJlc2hvbGQAAAAAAAAEAAAAAAAAAAIAAAACAAAAAAAAAAAAAAAPTXVsdGlzaWdTdG9yYWdlAAAAAAIAAAAAAAAAAAAAAAdTaWduZXJzAAAAAAAAAAAAAAAACVRocmVzaG9sZAAAAAAAAAUAAABXRXZlbnQgZW1pdHRlZCB3aGVuIG93bmVyc2hpcCBpcyB0cmFuc2ZlcnJlZCAoYm90aCBzaW5nbGUtc3RlcCBhbmQgdHdvLXN0ZXAgY29tcGxldGlvbikuAAAAAAAAAAAUT3duZXJzaGlwVHJhbnNmZXJyZWQAAAABAAAAFW93bmVyc2hpcF90cmFuc2ZlcnJlZAAAAAAAAAIAAAAAAAAACW9sZF9vd25lcgAAAAAAABMAAAAAAAAAAAAAAAluZXdfb3duZXIAAAAAAAATAAAAAAAAAAIAAAAFAAAAO0V2ZW50IGVtaXR0ZWQgd2hlbiBhIDItc3RlcCBvd25lcnNoaXAgdHJhbnNmZXIgaXMgcHJvcG9zZWQuAAAAAAAAAAAVT3duZXJzaGlwVHJhbnNmZXJyaW5nAAAAAAAAAQAAABZvd25lcnNoaXBfdHJhbnNmZXJyaW5nAAAAAAADAAAAAAAAAAlvbGRfb3duZXIAAAAAAAATAAAAAAAAAAAAAAAJbmV3X293bmVyAAAAAAAAEwAAAAAAAAAAAAAAA3R0bAAAAAAEAAAAAAAAAAIAAAAFAAAAKkV2ZW50IGVtaXR0ZWQgd2hlbiBvd25lcnNoaXAgaXMgcmVub3VuY2VkLgAAAAAAAAAAABJPd25lcnNoaXBSZW5vdW5jZWQAAAAAAAEAAAATb3duZXJzaGlwX3Jlbm91bmNlZAAAAAABAAAAAAAAAAlvbGRfb3duZXIAAAAAAAATAAAAAAAAAAIAAAACAAAAAAAAAAAAAAAOT3duYWJsZVN0b3JhZ2UAAAAAAAIAAAAAAAAAAAAAAAVPd25lcgAAAAAAAAAAAAAAAAAADFBlbmRpbmdPd25lcgAAAAEAAABJVFRMIGNvbmZpZ3VyYXRpb246IHRocmVzaG9sZCAod2hlbiB0byBleHRlbmQpIGFuZCBleHRlbmRfdG8gKHRhcmdldCBUVEwpLgAAAAAAAAAAAAAJVHRsQ29uZmlnAAAAAAAAAgAAAChUYXJnZXQgVFRMIGFmdGVyIGV4dGVuc2lvbiAoaW4gbGVkZ2VycykuAAAACWV4dGVuZF90bwAAAAAAAAQAAAAzVFRMIHRocmVzaG9sZCB0aGF0IHRyaWdnZXJzIGV4dGVuc2lvbiAoaW4gbGVkZ2VycykuAAAAAAl0aHJlc2hvbGQAAAAAAAAEAAAABQAAACdFdmVudCBlbWl0dGVkIHdoZW4gVFRMIGNvbmZpZ3MgYXJlIHNldC4AAAAAAAAAAA1UdGxDb25maWdzU2V0AAAAAAAAAQAAAA90dGxfY29uZmlnc19zZXQAAAAAAgAAAAAAAAAIaW5zdGFuY2UAAAPoAAAH0AAAAAlUdGxDb25maWcAAAAAAAAAAAAAAAAAAApwZXJzaXN0ZW50AAAAAAPoAAAH0AAAAAlUdGxDb25maWcAAAAAAAAAAAAAAgAAAAUAAAAqRXZlbnQgZW1pdHRlZCB3aGVuIFRUTCBjb25maWdzIGFyZSBmcm96ZW4uAAAAAAAAAAAAEFR0bENvbmZpZ3NGcm96ZW4AAAABAAAAEnR0bF9jb25maWdzX2Zyb3plbgAAAAAAAAAAAAIAAAACAAAAAAAAAAAAAAAQVHRsQ29uZmlnU3RvcmFnZQAAAAMAAAAAAAAAAAAAAAZGcm96ZW4AAAAAAAAAAAAAAAAACEluc3RhbmNlAAAAAAAAAAAAAAAKUGVyc2lzdGVudAAAAAAAAgAAAAAAAAAAAAAAElVwZ3JhZGVhYmxlU3RvcmFnZQAAAAAAAgAAAAAAAAAAAAAABkZyb3plbgAAAAAAAAAAAAAAAAAJTWlncmF0aW5nAAAAAB4RY29udHJhY3RlbnZtZXRhdjAAAAAAAAAAFwAAAAAAbw5jb250cmFjdG1ldGF2MAAAAAAAAAAFcnN2ZXIAAAAAAAAGMS45MC4wAAAAAAAAAAAACHJzc2RrdmVyAAAALzIzLjQuMCM2NzNkNmM0ZjIzNjhkMjgyZDI1ZGEyOWJkYTU1YzIxYjhiZTY5Y2E2AA==";
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 = "eaee4dc138ccd2dd79d0eae000e0c22cd7dee1c3d67ac66313aafda6dab59894";
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
+ export type OFTFeeStorage = {
23
+ tag: "DefaultFeeBps";
24
+ values: void;
25
+ } | {
26
+ tag: "FeeBps";
27
+ values: readonly [u32];
28
+ } | {
29
+ tag: "FeeDepositAddress";
30
+ values: void;
31
+ };
32
+ export declare const OFTFeeError: {
33
+ 3100: {
34
+ message: string;
35
+ };
36
+ 3101: {
37
+ message: string;
38
+ };
39
+ 3102: {
40
+ message: string;
41
+ };
42
+ 3103: {
43
+ message: string;
44
+ };
45
+ };
46
+ export type OFTPausableStorage = {
47
+ tag: "Paused";
48
+ values: void;
49
+ };
50
+ export declare const OFTPausableError: {
51
+ 3110: {
52
+ message: string;
53
+ };
54
+ 3111: {
55
+ message: string;
56
+ };
57
+ };
58
+ export type Direction = {
59
+ tag: "Inbound";
60
+ values: void;
61
+ } | {
62
+ tag: "Outbound";
63
+ values: void;
64
+ };
65
+ export interface RateLimit {
66
+ in_flight_on_last_update: i128;
67
+ last_update: u64;
68
+ limit: i128;
69
+ window_seconds: u64;
70
+ }
71
+ export type RateLimitStorage = {
72
+ tag: "RateLimit";
73
+ values: readonly [Direction, u32];
74
+ };
75
+ export declare const RateLimitError: {
76
+ 3120: {
77
+ message: string;
78
+ };
79
+ 3121: {
80
+ message: string;
81
+ };
82
+ 3122: {
83
+ message: string;
84
+ };
85
+ 3123: {
86
+ message: string;
87
+ };
88
+ 3124: {
89
+ message: string;
90
+ };
91
+ };
92
+ /**
93
+ * The type of OFT operation mode
94
+ */
95
+ export declare enum OftType {
96
+ LockUnlock = 0,
97
+ MintBurn = 1
98
+ }
99
+ export declare const EndpointError: {
100
+ 1: {
101
+ message: string;
102
+ };
103
+ 2: {
104
+ message: string;
105
+ };
106
+ 3: {
107
+ message: string;
108
+ };
109
+ 4: {
110
+ message: string;
111
+ };
112
+ 5: {
113
+ message: string;
114
+ };
115
+ 6: {
116
+ message: string;
117
+ };
118
+ 7: {
119
+ message: string;
120
+ };
121
+ 8: {
122
+ message: string;
123
+ };
124
+ 9: {
125
+ message: string;
126
+ };
127
+ 10: {
128
+ message: string;
129
+ };
130
+ 11: {
131
+ message: string;
132
+ };
133
+ 12: {
134
+ message: string;
135
+ };
136
+ 13: {
137
+ message: string;
138
+ };
139
+ 14: {
140
+ message: string;
141
+ };
142
+ 15: {
143
+ message: string;
144
+ };
145
+ 16: {
146
+ message: string;
147
+ };
148
+ 17: {
149
+ message: string;
150
+ };
151
+ 18: {
152
+ message: string;
153
+ };
154
+ 19: {
155
+ message: string;
156
+ };
157
+ 20: {
158
+ message: string;
159
+ };
160
+ 21: {
161
+ message: string;
162
+ };
163
+ 22: {
164
+ message: string;
165
+ };
166
+ 23: {
167
+ message: string;
168
+ };
169
+ 24: {
170
+ message: string;
171
+ };
172
+ 25: {
173
+ message: string;
174
+ };
175
+ };
176
+ /**
177
+ * Parameters for sending a cross-chain message.
178
+ */
179
+ export interface MessagingParams {
180
+ /**
181
+ * Destination endpoint ID (chain identifier).
182
+ */
183
+ dst_eid: u32;
184
+ /**
185
+ * The message payload to send.
186
+ */
187
+ message: Buffer;
188
+ /**
189
+ * Encoded executor and DVN options.
190
+ */
191
+ options: Buffer;
192
+ /**
193
+ * Whether to pay fees in ZRO token instead of native token.
194
+ */
195
+ pay_in_zro: boolean;
196
+ /**
197
+ * Receiver address on the destination chain (32 bytes).
198
+ */
199
+ receiver: Buffer;
200
+ }
201
+ /**
202
+ * Source message information identifying where a cross-chain message came from.
203
+ */
204
+ export interface Origin {
205
+ /**
206
+ * Nonce for this pathway.
207
+ */
208
+ nonce: u64;
209
+ /**
210
+ * Sender address on the source chain (32 bytes).
211
+ */
212
+ sender: Buffer;
213
+ /**
214
+ * Source endpoint ID (chain identifier).
215
+ */
216
+ src_eid: u32;
217
+ }
218
+ /**
219
+ * Fee structure for cross-chain messaging.
220
+ */
221
+ export interface MessagingFee {
222
+ /**
223
+ * Fee paid in native token (XLM).
224
+ */
225
+ native_fee: i128;
226
+ /**
227
+ * Fee paid in ZRO token (LayerZero token).
228
+ */
229
+ zro_fee: i128;
230
+ }
231
+ /**
232
+ * Receipt returned after successfully sending a cross-chain message.
233
+ */
234
+ export interface MessagingReceipt {
235
+ /**
236
+ * The fees charged for sending the message.
237
+ */
238
+ fee: MessagingFee;
239
+ /**
240
+ * Globally unique identifier for the message.
241
+ */
242
+ guid: Buffer;
243
+ /**
244
+ * The outbound nonce for this pathway.
245
+ */
246
+ nonce: u64;
247
+ }
248
+ /**
249
+ * Type of message library indicating supported operations.
250
+ */
251
+ export type MessageLibType = {
252
+ tag: "Send";
253
+ values: void;
254
+ } | {
255
+ tag: "Receive";
256
+ values: void;
257
+ } | {
258
+ tag: "SendAndReceive";
259
+ values: void;
260
+ };
261
+ /**
262
+ * Version information for a message library.
263
+ *
264
+ * Note: `minor` and `endpoint_version` use `u32` instead of `u8` because Stellar does not
265
+ * support `u8` types in contract interface functions.
266
+ */
267
+ export interface MessageLibVersion {
268
+ /**
269
+ * Endpoint version (should not exceed u8::MAX = 255).
270
+ */
271
+ endpoint_version: u32;
272
+ /**
273
+ * Major version number.
274
+ */
275
+ major: u64;
276
+ /**
277
+ * Minor version number (should not exceed u8::MAX = 255).
278
+ */
279
+ minor: u32;
280
+ }
281
+ /**
282
+ * Timeout configuration for receive library transitions.
283
+ */
284
+ export interface Timeout {
285
+ /**
286
+ * Unix timestamp when the timeout expires.
287
+ */
288
+ expiry: u64;
289
+ /**
290
+ * The new library address to transition to.
291
+ */
292
+ lib: string;
293
+ }
294
+ /**
295
+ * Parameters for setting message library configuration.
296
+ */
297
+ export interface SetConfigParam {
298
+ /**
299
+ * XDR-encoded configuration data.
300
+ */
301
+ config: Buffer;
302
+ /**
303
+ * The type of configuration (e.g., executor, ULN).
304
+ */
305
+ config_type: u32;
306
+ /**
307
+ * The endpoint ID this config applies to.
308
+ */
309
+ eid: u32;
310
+ }
311
+ /**
312
+ * Resolved library information with default status.
313
+ */
314
+ export interface ResolvedLibrary {
315
+ /**
316
+ * Whether this is the default library (true) or OApp-specific (false).
317
+ */
318
+ is_default: boolean;
319
+ /**
320
+ * The resolved library address.
321
+ */
322
+ lib: string;
323
+ }
324
+ /**
325
+ * Outbound packet containing all information for cross-chain transmission.
326
+ */
327
+ export interface OutboundPacket {
328
+ /**
329
+ * Destination endpoint ID.
330
+ */
331
+ dst_eid: u32;
332
+ /**
333
+ * Globally unique identifier for this message.
334
+ */
335
+ guid: Buffer;
336
+ /**
337
+ * The message payload.
338
+ */
339
+ message: Buffer;
340
+ /**
341
+ * Outbound nonce for this pathway.
342
+ */
343
+ nonce: u64;
344
+ /**
345
+ * Receiver address on destination chain (32 bytes).
346
+ */
347
+ receiver: Buffer;
348
+ /**
349
+ * Sender address on source chain.
350
+ */
351
+ sender: string;
352
+ /**
353
+ * Source endpoint ID.
354
+ */
355
+ src_eid: u32;
356
+ }
357
+ /**
358
+ * A fee recipient with the amount to be paid.
359
+ */
360
+ export interface FeeRecipient {
361
+ /**
362
+ * Amount of fee to pay.
363
+ */
364
+ amount: i128;
365
+ /**
366
+ * The address to send the fee to.
367
+ */
368
+ to: string;
369
+ }
370
+ /**
371
+ * Result of send operation containing fees and encoded packet.
372
+ */
373
+ export interface FeesAndPacket {
374
+ /**
375
+ * The encoded packet ready for transmission.
376
+ */
377
+ encoded_packet: Buffer;
378
+ /**
379
+ * List of native token fee recipients (executor, DVNs, treasury).
380
+ */
381
+ native_fee_recipients: Array<FeeRecipient>;
382
+ /**
383
+ * List of ZRO token fee recipients (treasury).
384
+ */
385
+ zro_fee_recipients: Array<FeeRecipient>;
386
+ }
387
+ /**
388
+ * OAppError: 2000-2099
389
+ */
390
+ export declare const OAppError: {
391
+ 2000: {
392
+ message: string;
393
+ };
394
+ 2001: {
395
+ message: string;
396
+ };
397
+ 2002: {
398
+ message: string;
399
+ };
400
+ 2003: {
401
+ message: string;
402
+ };
403
+ };
404
+ export type OAppCoreStorage = {
405
+ tag: "Endpoint";
406
+ values: void;
407
+ } | {
408
+ tag: "Peer";
409
+ values: readonly [u32];
410
+ };
411
+ export interface EnforcedOptionParam {
412
+ eid: u32;
413
+ msg_type: u32;
414
+ options: Buffer;
415
+ }
416
+ export type OAppOptionsType3Storage = {
417
+ tag: "EnforcedOptions";
418
+ values: readonly [u32, u32];
419
+ };
420
+ /**
421
+ * OFTError: 3000-3099
422
+ */
423
+ export declare const OFTError: {
424
+ 3000: {
425
+ message: string;
426
+ };
427
+ 3001: {
428
+ message: string;
429
+ };
430
+ 3002: {
431
+ message: string;
432
+ };
433
+ 3003: {
434
+ message: string;
435
+ };
436
+ };
437
+ export type OFTStorage = {
438
+ tag: "DecimalConversionRate";
439
+ values: void;
440
+ } | {
441
+ tag: "Token";
442
+ values: void;
443
+ };
444
+ /**
445
+ * Parameters for sending OFT tokens cross-chain
446
+ */
447
+ export interface SendParam {
448
+ /**
449
+ * The amount to send in local decimals
450
+ */
451
+ amount_ld: i128;
452
+ /**
453
+ * Compose message to execute on the destination (Optional)
454
+ */
455
+ compose_msg: Buffer;
456
+ /**
457
+ * The destination endpoint ID
458
+ */
459
+ dst_eid: u32;
460
+ /**
461
+ * Additional options for the LayerZero message (Optional)
462
+ */
463
+ extra_options: Buffer;
464
+ /**
465
+ * The minimum amount to receive in local decimals (slippage protection)
466
+ */
467
+ min_amount_ld: i128;
468
+ /**
469
+ * OFT command for custom behavior (Optional)
470
+ */
471
+ oft_cmd: Buffer;
472
+ /**
473
+ * The recipient address on the destination chain (32 bytes)
474
+ */
475
+ to: Buffer;
476
+ }
477
+ /**
478
+ * Transfer limits for OFT operations
479
+ */
480
+ export interface OFTLimit {
481
+ /**
482
+ * The maximum amount to send in local decimals
483
+ */
484
+ max_amount_ld: i128;
485
+ /**
486
+ * The minimum amount to send in local decimals
487
+ */
488
+ min_amount_ld: i128;
489
+ }
490
+ /**
491
+ * Receipt containing amounts sent and received in an OFT transfer
492
+ */
493
+ export interface OFTReceipt {
494
+ /**
495
+ * The amount received in local decimals on the remote
496
+ */
497
+ amount_received_ld: i128;
498
+ /**
499
+ * The amount sent in local decimals
500
+ */
501
+ amount_sent_ld: i128;
502
+ }
503
+ /**
504
+ * Details about fees charged in an OFT operation
505
+ */
506
+ export interface OFTFeeDetail {
507
+ /**
508
+ * The description of the fee
509
+ */
510
+ description: Buffer;
511
+ /**
512
+ * The amount of the fee in local decimals. Positive values represent fees charged,
513
+ * while negative values represent rewards given.
514
+ */
515
+ fee_amount_ld: i128;
516
+ }
517
+ /**
518
+ * BufferReaderError: 1000-1009
519
+ */
520
+ export declare const BufferReaderError: {
521
+ 1000: {
522
+ message: string;
523
+ };
524
+ 1001: {
525
+ message: string;
526
+ };
527
+ };
528
+ /**
529
+ * BufferWriterError: 1010-1019
530
+ */
531
+ export declare const BufferWriterError: {
532
+ 1010: {
533
+ message: string;
534
+ };
535
+ };
536
+ /**
537
+ * TtlConfigurableError: 1020-1029
538
+ */
539
+ export declare const TtlConfigurableError: {
540
+ 1020: {
541
+ message: string;
542
+ };
543
+ 1021: {
544
+ message: string;
545
+ };
546
+ 1022: {
547
+ message: string;
548
+ };
549
+ };
550
+ /**
551
+ * OwnableError: 1030-1039
552
+ */
553
+ export declare const OwnableError: {
554
+ 1030: {
555
+ message: string;
556
+ };
557
+ 1031: {
558
+ message: string;
559
+ };
560
+ 1032: {
561
+ message: string;
562
+ };
563
+ 1033: {
564
+ message: string;
565
+ };
566
+ 1034: {
567
+ message: string;
568
+ };
569
+ 1035: {
570
+ message: string;
571
+ };
572
+ };
573
+ /**
574
+ * BytesExtError: 1040-1049
575
+ */
576
+ export declare const BytesExtError: {
577
+ 1040: {
578
+ message: string;
579
+ };
580
+ };
581
+ /**
582
+ * UpgradeableError: 1050-1059
583
+ */
584
+ export declare const UpgradeableError: {
585
+ 1050: {
586
+ message: string;
587
+ };
588
+ 1051: {
589
+ message: string;
590
+ };
591
+ 1052: {
592
+ message: string;
593
+ };
594
+ };
595
+ /**
596
+ * MultisigError: 1060-1069
597
+ */
598
+ export declare const MultisigError: {
599
+ 1060: {
600
+ message: string;
601
+ };
602
+ 1061: {
603
+ message: string;
604
+ };
605
+ 1062: {
606
+ message: string;
607
+ };
608
+ 1063: {
609
+ message: string;
610
+ };
611
+ 1064: {
612
+ message: string;
613
+ };
614
+ 1065: {
615
+ message: string;
616
+ };
617
+ 1066: {
618
+ message: string;
619
+ };
620
+ 1067: {
621
+ message: string;
622
+ };
623
+ };
624
+ export type MultisigStorage = {
625
+ tag: "Signers";
626
+ values: void;
627
+ } | {
628
+ tag: "Threshold";
629
+ values: void;
630
+ };
631
+ export type OwnableStorage = {
632
+ tag: "Owner";
633
+ values: void;
634
+ } | {
635
+ tag: "PendingOwner";
636
+ values: void;
637
+ };
638
+ /**
639
+ * TTL configuration: threshold (when to extend) and extend_to (target TTL).
640
+ */
641
+ export interface TtlConfig {
642
+ /**
643
+ * Target TTL after extension (in ledgers).
644
+ */
645
+ extend_to: u32;
646
+ /**
647
+ * TTL threshold that triggers extension (in ledgers).
648
+ */
649
+ threshold: u32;
650
+ }
651
+ export type TtlConfigStorage = {
652
+ tag: "Frozen";
653
+ values: void;
654
+ } | {
655
+ tag: "Instance";
656
+ values: void;
657
+ } | {
658
+ tag: "Persistent";
659
+ values: void;
660
+ };
661
+ export type UpgradeableStorage = {
662
+ tag: "Frozen";
663
+ values: void;
664
+ } | {
665
+ tag: "Migrating";
666
+ values: void;
667
+ };
668
+ export interface Client {
669
+ /**
670
+ * Construct and simulate a set_rate_limit 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.
671
+ */
672
+ set_rate_limit: ({ direction, eid, limit, window_seconds }: {
673
+ direction: Direction;
674
+ eid: u32;
675
+ limit: i128;
676
+ window_seconds: u64;
677
+ }, txnOptions?: {
678
+ /**
679
+ * The fee to pay for the transaction. Default: BASE_FEE
680
+ */
681
+ fee?: number;
682
+ /**
683
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
684
+ */
685
+ timeoutInSeconds?: number;
686
+ /**
687
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
688
+ */
689
+ simulate?: boolean;
690
+ }) => Promise<AssembledTransaction<null>>;
691
+ /**
692
+ * Construct and simulate a unset_rate_limit 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.
693
+ */
694
+ unset_rate_limit: ({ direction, eid }: {
695
+ direction: Direction;
696
+ eid: u32;
697
+ }, txnOptions?: {
698
+ /**
699
+ * The fee to pay for the transaction. Default: BASE_FEE
700
+ */
701
+ fee?: number;
702
+ /**
703
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
704
+ */
705
+ timeoutInSeconds?: number;
706
+ /**
707
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
708
+ */
709
+ simulate?: boolean;
710
+ }) => Promise<AssembledTransaction<null>>;
711
+ /**
712
+ * Construct and simulate a rate_limit_config transaction. Returns an `AssembledTransaction` object which will have a `result` field containing the result of the simulation. If this transaction changes contract state, you will need to call `signAndSend()` on the returned object.
713
+ */
714
+ rate_limit_config: ({ direction, eid }: {
715
+ direction: Direction;
716
+ eid: u32;
717
+ }, txnOptions?: {
718
+ /**
719
+ * The fee to pay for the transaction. Default: BASE_FEE
720
+ */
721
+ fee?: number;
722
+ /**
723
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
724
+ */
725
+ timeoutInSeconds?: number;
726
+ /**
727
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
728
+ */
729
+ simulate?: boolean;
730
+ }) => Promise<AssembledTransaction<readonly [i128, u64]>>;
731
+ /**
732
+ * Construct and simulate a rate_limit_in_flight 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.
733
+ */
734
+ rate_limit_in_flight: ({ direction, eid }: {
735
+ direction: Direction;
736
+ eid: u32;
737
+ }, txnOptions?: {
738
+ /**
739
+ * The fee to pay for the transaction. Default: BASE_FEE
740
+ */
741
+ fee?: number;
742
+ /**
743
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
744
+ */
745
+ timeoutInSeconds?: number;
746
+ /**
747
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
748
+ */
749
+ simulate?: boolean;
750
+ }) => Promise<AssembledTransaction<i128>>;
751
+ /**
752
+ * Construct and simulate a rate_limit_capacity 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.
753
+ */
754
+ rate_limit_capacity: ({ direction, eid }: {
755
+ direction: Direction;
756
+ eid: u32;
757
+ }, txnOptions?: {
758
+ /**
759
+ * The fee to pay for the transaction. Default: BASE_FEE
760
+ */
761
+ fee?: number;
762
+ /**
763
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
764
+ */
765
+ timeoutInSeconds?: number;
766
+ /**
767
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
768
+ */
769
+ simulate?: boolean;
770
+ }) => Promise<AssembledTransaction<i128>>;
771
+ /**
772
+ * Construct and simulate a set_default_fee_bps 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.
773
+ */
774
+ set_default_fee_bps: ({ default_fee_bps }: {
775
+ default_fee_bps: u64;
776
+ }, txnOptions?: {
777
+ /**
778
+ * The fee to pay for the transaction. Default: BASE_FEE
779
+ */
780
+ fee?: number;
781
+ /**
782
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
783
+ */
784
+ timeoutInSeconds?: number;
785
+ /**
786
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
787
+ */
788
+ simulate?: boolean;
789
+ }) => Promise<AssembledTransaction<null>>;
790
+ /**
791
+ * Construct and simulate a set_fee_bps 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.
792
+ */
793
+ set_fee_bps: ({ dst_eid, fee_bps }: {
794
+ dst_eid: u32;
795
+ fee_bps: u64;
796
+ }, txnOptions?: {
797
+ /**
798
+ * The fee to pay for the transaction. Default: BASE_FEE
799
+ */
800
+ fee?: number;
801
+ /**
802
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
803
+ */
804
+ timeoutInSeconds?: number;
805
+ /**
806
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
807
+ */
808
+ simulate?: boolean;
809
+ }) => Promise<AssembledTransaction<null>>;
810
+ /**
811
+ * Construct and simulate a unset_fee_bps 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.
812
+ */
813
+ unset_fee_bps: ({ dst_eid }: {
814
+ dst_eid: u32;
815
+ }, txnOptions?: {
816
+ /**
817
+ * The fee to pay for the transaction. Default: BASE_FEE
818
+ */
819
+ fee?: number;
820
+ /**
821
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
822
+ */
823
+ timeoutInSeconds?: number;
824
+ /**
825
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
826
+ */
827
+ simulate?: boolean;
828
+ }) => Promise<AssembledTransaction<null>>;
829
+ /**
830
+ * Construct and simulate a set_fee_deposit_address 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.
831
+ */
832
+ set_fee_deposit_address: ({ fee_deposit_address }: {
833
+ fee_deposit_address: string;
834
+ }, txnOptions?: {
835
+ /**
836
+ * The fee to pay for the transaction. Default: BASE_FEE
837
+ */
838
+ fee?: number;
839
+ /**
840
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
841
+ */
842
+ timeoutInSeconds?: number;
843
+ /**
844
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
845
+ */
846
+ simulate?: boolean;
847
+ }) => Promise<AssembledTransaction<null>>;
848
+ /**
849
+ * Construct and simulate a has_fee_bps transaction. Returns an `AssembledTransaction` object which will have a `result` field containing the result of the simulation. If this transaction changes contract state, you will need to call `signAndSend()` on the returned object.
850
+ */
851
+ has_fee_bps: ({ dst_eid }: {
852
+ dst_eid: u32;
853
+ }, txnOptions?: {
854
+ /**
855
+ * The fee to pay for the transaction. Default: BASE_FEE
856
+ */
857
+ fee?: number;
858
+ /**
859
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
860
+ */
861
+ timeoutInSeconds?: number;
862
+ /**
863
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
864
+ */
865
+ simulate?: boolean;
866
+ }) => Promise<AssembledTransaction<boolean>>;
867
+ /**
868
+ * Construct and simulate a effective_fee_bps 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.
869
+ */
870
+ effective_fee_bps: ({ dst_eid }: {
871
+ dst_eid: u32;
872
+ }, txnOptions?: {
873
+ /**
874
+ * The fee to pay for the transaction. Default: BASE_FEE
875
+ */
876
+ fee?: number;
877
+ /**
878
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
879
+ */
880
+ timeoutInSeconds?: number;
881
+ /**
882
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
883
+ */
884
+ simulate?: boolean;
885
+ }) => Promise<AssembledTransaction<u64>>;
886
+ /**
887
+ * Construct and simulate a default_fee_bps 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.
888
+ */
889
+ default_fee_bps: (txnOptions?: {
890
+ /**
891
+ * The fee to pay for the transaction. Default: BASE_FEE
892
+ */
893
+ fee?: number;
894
+ /**
895
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
896
+ */
897
+ timeoutInSeconds?: number;
898
+ /**
899
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
900
+ */
901
+ simulate?: boolean;
902
+ }) => Promise<AssembledTransaction<u64>>;
903
+ /**
904
+ * Construct and simulate a fee_bps 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.
905
+ */
906
+ fee_bps: ({ dst_eid }: {
907
+ dst_eid: u32;
908
+ }, txnOptions?: {
909
+ /**
910
+ * The fee to pay for the transaction. Default: BASE_FEE
911
+ */
912
+ fee?: number;
913
+ /**
914
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
915
+ */
916
+ timeoutInSeconds?: number;
917
+ /**
918
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
919
+ */
920
+ simulate?: boolean;
921
+ }) => Promise<AssembledTransaction<Option<u64>>>;
922
+ /**
923
+ * Construct and simulate a fee_deposit_address transaction. Returns an `AssembledTransaction` object which will have a `result` field containing the result of the simulation. If this transaction changes contract state, you will need to call `signAndSend()` on the returned object.
924
+ */
925
+ fee_deposit_address: (txnOptions?: {
926
+ /**
927
+ * The fee to pay for the transaction. Default: BASE_FEE
928
+ */
929
+ fee?: number;
930
+ /**
931
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
932
+ */
933
+ timeoutInSeconds?: number;
934
+ /**
935
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
936
+ */
937
+ simulate?: boolean;
938
+ }) => Promise<AssembledTransaction<string>>;
939
+ /**
940
+ * Construct and simulate a set_paused 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.
941
+ */
942
+ set_paused: ({ paused }: {
943
+ paused: boolean;
944
+ }, txnOptions?: {
945
+ /**
946
+ * The fee to pay for the transaction. Default: BASE_FEE
947
+ */
948
+ fee?: number;
949
+ /**
950
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
951
+ */
952
+ timeoutInSeconds?: number;
953
+ /**
954
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
955
+ */
956
+ simulate?: boolean;
957
+ }) => Promise<AssembledTransaction<null>>;
958
+ /**
959
+ * Construct and simulate a is_paused 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.
960
+ */
961
+ is_paused: (txnOptions?: {
962
+ /**
963
+ * The fee to pay for the transaction. Default: BASE_FEE
964
+ */
965
+ fee?: number;
966
+ /**
967
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
968
+ */
969
+ timeoutInSeconds?: number;
970
+ /**
971
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
972
+ */
973
+ simulate?: boolean;
974
+ }) => Promise<AssembledTransaction<boolean>>;
975
+ /**
976
+ * Construct and simulate a quote_oft 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.
977
+ */
978
+ quote_oft: ({ send_param }: {
979
+ send_param: SendParam;
980
+ }, txnOptions?: {
981
+ /**
982
+ * The fee to pay for the transaction. Default: BASE_FEE
983
+ */
984
+ fee?: number;
985
+ /**
986
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
987
+ */
988
+ timeoutInSeconds?: number;
989
+ /**
990
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
991
+ */
992
+ simulate?: boolean;
993
+ }) => Promise<AssembledTransaction<readonly [OFTLimit, Array<OFTFeeDetail>, OFTReceipt]>>;
994
+ /**
995
+ * Construct and simulate a token transaction. Returns an `AssembledTransaction` object which will have a `result` field containing the result of the simulation. If this transaction changes contract state, you will need to call `signAndSend()` on the returned object.
996
+ * Retrieves the token address associated with this OFT.
997
+ */
998
+ token: (txnOptions?: {
999
+ /**
1000
+ * The fee to pay for the transaction. Default: BASE_FEE
1001
+ */
1002
+ fee?: number;
1003
+ /**
1004
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1005
+ */
1006
+ timeoutInSeconds?: number;
1007
+ /**
1008
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1009
+ */
1010
+ simulate?: boolean;
1011
+ }) => Promise<AssembledTransaction<string>>;
1012
+ /**
1013
+ * Construct and simulate a oft_version 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.
1014
+ * Returns OFT version as (major, minor).
1015
+ */
1016
+ oft_version: (txnOptions?: {
1017
+ /**
1018
+ * The fee to pay for the transaction. Default: BASE_FEE
1019
+ */
1020
+ fee?: number;
1021
+ /**
1022
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1023
+ */
1024
+ timeoutInSeconds?: number;
1025
+ /**
1026
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1027
+ */
1028
+ simulate?: boolean;
1029
+ }) => Promise<AssembledTransaction<readonly [u64, u64]>>;
1030
+ /**
1031
+ * Construct and simulate a shared_decimals 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.
1032
+ * Retrieves the shared decimals used for cross-chain normalization.
1033
+ */
1034
+ shared_decimals: (txnOptions?: {
1035
+ /**
1036
+ * The fee to pay for the transaction. Default: BASE_FEE
1037
+ */
1038
+ fee?: number;
1039
+ /**
1040
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1041
+ */
1042
+ timeoutInSeconds?: number;
1043
+ /**
1044
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1045
+ */
1046
+ simulate?: boolean;
1047
+ }) => Promise<AssembledTransaction<u32>>;
1048
+ /**
1049
+ * Construct and simulate a decimal_conversion_rate 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.
1050
+ * Retrieves the decimal conversion rate used for cross-chain normalization.
1051
+ */
1052
+ decimal_conversion_rate: (txnOptions?: {
1053
+ /**
1054
+ * The fee to pay for the transaction. Default: BASE_FEE
1055
+ */
1056
+ fee?: number;
1057
+ /**
1058
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1059
+ */
1060
+ timeoutInSeconds?: number;
1061
+ /**
1062
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1063
+ */
1064
+ simulate?: boolean;
1065
+ }) => Promise<AssembledTransaction<i128>>;
1066
+ /**
1067
+ * Construct and simulate a approval_required transaction. Returns an `AssembledTransaction` object which will have a `result` field containing the result of the simulation. If this transaction changes contract state, you will need to call `signAndSend()` on the returned object.
1068
+ * Whether a separate token approval is required before sending.
1069
+ *
1070
+ * Helps wallet implementers determine integration requirements.
1071
+ *
1072
+ * # Returns
1073
+ * - `true` if a separate token approval step is required
1074
+ * - `false` if no separate approval is needed
1075
+ */
1076
+ approval_required: (txnOptions?: {
1077
+ /**
1078
+ * The fee to pay for the transaction. Default: BASE_FEE
1079
+ */
1080
+ fee?: number;
1081
+ /**
1082
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1083
+ */
1084
+ timeoutInSeconds?: number;
1085
+ /**
1086
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1087
+ */
1088
+ simulate?: boolean;
1089
+ }) => Promise<AssembledTransaction<boolean>>;
1090
+ /**
1091
+ * Construct and simulate a quote_send 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.
1092
+ * Quotes a send operation including LayerZero messaging fees.
1093
+ */
1094
+ quote_send: ({ from, send_param, pay_in_zro }: {
1095
+ from: string;
1096
+ send_param: SendParam;
1097
+ pay_in_zro: boolean;
1098
+ }, txnOptions?: {
1099
+ /**
1100
+ * The fee to pay for the transaction. Default: BASE_FEE
1101
+ */
1102
+ fee?: number;
1103
+ /**
1104
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1105
+ */
1106
+ timeoutInSeconds?: number;
1107
+ /**
1108
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1109
+ */
1110
+ simulate?: boolean;
1111
+ }) => Promise<AssembledTransaction<MessagingFee>>;
1112
+ /**
1113
+ * Construct and simulate a send 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.
1114
+ * Sends tokens cross-chain to another endpoint.
1115
+ *
1116
+ * From must be authenticated.
1117
+ *
1118
+ * # Returns
1119
+ * (MessagingReceipt, OFTReceipt)
1120
+ */
1121
+ send: ({ from, send_param, fee, refund_address }: {
1122
+ from: string;
1123
+ send_param: SendParam;
1124
+ fee: MessagingFee;
1125
+ refund_address: string;
1126
+ }, txnOptions?: {
1127
+ /**
1128
+ * The fee to pay for the transaction. Default: BASE_FEE
1129
+ */
1130
+ fee?: number;
1131
+ /**
1132
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1133
+ */
1134
+ timeoutInSeconds?: number;
1135
+ /**
1136
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1137
+ */
1138
+ simulate?: boolean;
1139
+ }) => Promise<AssembledTransaction<readonly [MessagingReceipt, OFTReceipt]>>;
1140
+ /**
1141
+ * Construct and simulate a oft_type transaction. Returns an `AssembledTransaction` object which will have a `result` field containing the result of the simulation. If this transaction changes contract state, you will need to call `signAndSend()` on the returned object.
1142
+ * Returns the type of operation for this OFT (LockUnlock or MintBurn)
1143
+ */
1144
+ oft_type: (txnOptions?: {
1145
+ /**
1146
+ * The fee to pay for the transaction. Default: BASE_FEE
1147
+ */
1148
+ fee?: number;
1149
+ /**
1150
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1151
+ */
1152
+ timeoutInSeconds?: number;
1153
+ /**
1154
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1155
+ */
1156
+ simulate?: boolean;
1157
+ }) => Promise<AssembledTransaction<OftType>>;
1158
+ /**
1159
+ * 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.
1160
+ */
1161
+ authorizer: (txnOptions?: {
1162
+ /**
1163
+ * The fee to pay for the transaction. Default: BASE_FEE
1164
+ */
1165
+ fee?: number;
1166
+ /**
1167
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1168
+ */
1169
+ timeoutInSeconds?: number;
1170
+ /**
1171
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1172
+ */
1173
+ simulate?: boolean;
1174
+ }) => Promise<AssembledTransaction<string>>;
1175
+ /**
1176
+ * Construct and simulate a enforced_options 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.
1177
+ * Retrieves the enforced options for a given endpoint and message type.
1178
+ *
1179
+ * # Arguments
1180
+ * * `eid` - The endpoint ID
1181
+ * * `msg_type` - The OApp message type
1182
+ *
1183
+ * # Returns
1184
+ * The enforced options for the given endpoint and message type
1185
+ */
1186
+ enforced_options: ({ eid, msg_type }: {
1187
+ eid: u32;
1188
+ msg_type: u32;
1189
+ }, txnOptions?: {
1190
+ /**
1191
+ * The fee to pay for the transaction. Default: BASE_FEE
1192
+ */
1193
+ fee?: number;
1194
+ /**
1195
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1196
+ */
1197
+ timeoutInSeconds?: number;
1198
+ /**
1199
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1200
+ */
1201
+ simulate?: boolean;
1202
+ }) => Promise<AssembledTransaction<Buffer>>;
1203
+ /**
1204
+ * Construct and simulate a set_enforced_options 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.
1205
+ * Sets the enforced options for specific endpoint and message type combinations.
1206
+ *
1207
+ * Only the `authorizer` of the OApp can call this function.
1208
+ * Provides a way for the OApp to enforce things like paying for PreCrime, AND/OR minimum dst lzReceive gas amounts etc.
1209
+ * These enforced options can vary as the potential options/execution on the remote may differ as per the msg_type.
1210
+ * e.g. Amount of lzReceive() gas necessary to deliver a lzCompose() message adds overhead you don't want to pay
1211
+ * if you are only making a standard LayerZero message ie. lzReceive() WITHOUT sendCompose().
1212
+ *
1213
+ * # Arguments
1214
+ * * `options` - A vector of EnforcedOptionParam structures specifying enforced options
1215
+ */
1216
+ set_enforced_options: ({ options }: {
1217
+ options: Array<EnforcedOptionParam>;
1218
+ }, txnOptions?: {
1219
+ /**
1220
+ * The fee to pay for the transaction. Default: BASE_FEE
1221
+ */
1222
+ fee?: number;
1223
+ /**
1224
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1225
+ */
1226
+ timeoutInSeconds?: number;
1227
+ /**
1228
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1229
+ */
1230
+ simulate?: boolean;
1231
+ }) => Promise<AssembledTransaction<null>>;
1232
+ /**
1233
+ * Construct and simulate a combine_options 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.
1234
+ * Combines options for a given endpoint and message type.
1235
+ *
1236
+ * If there is an enforced lzReceive option:
1237
+ * - {gas_limit: 200k, value: 1 XLM} AND a caller supplies a lzReceive option: {gas_limit: 100k, value: 0.5 XLM}
1238
+ * - The resulting options will be {gas_limit: 300k, value: 1.5 XLM} when the message is executed on the remote lz_receive() function.
1239
+ * The presence of duplicated options is handled off-chain in the verifier/executor.
1240
+ *
1241
+ * # Arguments
1242
+ * * `eid` - The endpoint ID
1243
+ * * `msg_type` - The OApp message type
1244
+ * * `extra_options` - Additional options passed by the caller
1245
+ *
1246
+ * # Returns
1247
+ * The combination of caller specified options AND enforced options
1248
+ */
1249
+ combine_options: ({ eid, msg_type, extra_options }: {
1250
+ eid: u32;
1251
+ msg_type: u32;
1252
+ extra_options: Buffer;
1253
+ }, txnOptions?: {
1254
+ /**
1255
+ * The fee to pay for the transaction. Default: BASE_FEE
1256
+ */
1257
+ fee?: number;
1258
+ /**
1259
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1260
+ */
1261
+ timeoutInSeconds?: number;
1262
+ /**
1263
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1264
+ */
1265
+ simulate?: boolean;
1266
+ }) => Promise<AssembledTransaction<Buffer>>;
1267
+ /**
1268
+ * Construct and simulate a allow_initialize_path 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.
1269
+ * Checks if a messaging path can be initialized for the given origin.
1270
+ *
1271
+ * # Arguments
1272
+ * * `origin` - The origin of the message
1273
+ *
1274
+ * # Returns
1275
+ * True if the path can be initialized, false otherwise
1276
+ */
1277
+ allow_initialize_path: ({ origin }: {
1278
+ origin: Origin;
1279
+ }, txnOptions?: {
1280
+ /**
1281
+ * The fee to pay for the transaction. Default: BASE_FEE
1282
+ */
1283
+ fee?: number;
1284
+ /**
1285
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1286
+ */
1287
+ timeoutInSeconds?: number;
1288
+ /**
1289
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1290
+ */
1291
+ simulate?: boolean;
1292
+ }) => Promise<AssembledTransaction<boolean>>;
1293
+ /**
1294
+ * Construct and simulate a next_nonce 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.
1295
+ * Retrieves the next nonce for a given source endpoint and sender address.
1296
+ *
1297
+ * The path nonce starts from 1. If 0 is returned it means that there is NO nonce ordered enforcement.
1298
+ * This is required by the off-chain executor to determine if the OApp expects message execution to be ordered.
1299
+ * This is also enforced by the OApp.
1300
+ * By default this is NOT enabled, i.e. next_nonce is hardcoded to return 0.
1301
+ *
1302
+ * # Arguments
1303
+ * * `src_eid` - The source endpoint ID
1304
+ * * `sender` - The sender OApp address
1305
+ *
1306
+ * # Returns
1307
+ * The next nonce
1308
+ */
1309
+ next_nonce: ({ src_eid, sender }: {
1310
+ src_eid: u32;
1311
+ sender: Buffer;
1312
+ }, txnOptions?: {
1313
+ /**
1314
+ * The fee to pay for the transaction. Default: BASE_FEE
1315
+ */
1316
+ fee?: number;
1317
+ /**
1318
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1319
+ */
1320
+ timeoutInSeconds?: number;
1321
+ /**
1322
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1323
+ */
1324
+ simulate?: boolean;
1325
+ }) => Promise<AssembledTransaction<u64>>;
1326
+ /**
1327
+ * Construct and simulate a lz_receive 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.
1328
+ * Entry point for receiving messages or packets from the LayerZero endpoint.
1329
+ *
1330
+ * The default implementation calls `clear_payload_and_transfer` to validate the message
1331
+ * and clear it from the endpoint, then delegates to `__lz_receive` for application logic.
1332
+ *
1333
+ * # Arguments
1334
+ * * `executor` - The address of the executor for the received message
1335
+ * * `origin` - The origin information containing the source endpoint and sender address:
1336
+ * - `src_eid`: The source chain endpoint ID
1337
+ * - `sender`: The sender address on the source chain
1338
+ * - `nonce`: The nonce of the message
1339
+ * * `guid` - The unique identifier for the received LayerZero message
1340
+ * * `message` - The payload of the received message
1341
+ * * `extra_data` - Additional arbitrary data provided by the corresponding executor
1342
+ * * `value` - The native token value sent with the message
1343
+ */
1344
+ lz_receive: ({ executor, origin, guid, message, extra_data, value }: {
1345
+ executor: string;
1346
+ origin: Origin;
1347
+ guid: Buffer;
1348
+ message: Buffer;
1349
+ extra_data: Buffer;
1350
+ value: i128;
1351
+ }, txnOptions?: {
1352
+ /**
1353
+ * The fee to pay for the transaction. Default: BASE_FEE
1354
+ */
1355
+ fee?: number;
1356
+ /**
1357
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1358
+ */
1359
+ timeoutInSeconds?: number;
1360
+ /**
1361
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1362
+ */
1363
+ simulate?: boolean;
1364
+ }) => Promise<AssembledTransaction<null>>;
1365
+ /**
1366
+ * Construct and simulate a is_compose_msg_sender 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.
1367
+ * Indicates whether an address is an approved composeMsg sender to the Endpoint.
1368
+ *
1369
+ * Applications can optionally choose to implement separate composeMsg senders that are NOT the bridging layer.
1370
+ * The default sender IS the OAppReceiver implementer.
1371
+ *
1372
+ * # Arguments
1373
+ * * `origin` - The origin information containing the source endpoint and sender address
1374
+ * * `message` - The lzReceive payload
1375
+ * * `sender` - The sender address to check
1376
+ *
1377
+ * # Returns
1378
+ * True if the sender is a valid composeMsg sender, false otherwise
1379
+ */
1380
+ is_compose_msg_sender: ({ origin, message, sender }: {
1381
+ origin: Origin;
1382
+ message: Buffer;
1383
+ sender: string;
1384
+ }, txnOptions?: {
1385
+ /**
1386
+ * The fee to pay for the transaction. Default: BASE_FEE
1387
+ */
1388
+ fee?: number;
1389
+ /**
1390
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1391
+ */
1392
+ timeoutInSeconds?: number;
1393
+ /**
1394
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1395
+ */
1396
+ simulate?: boolean;
1397
+ }) => Promise<AssembledTransaction<boolean>>;
1398
+ /**
1399
+ * Construct and simulate a oapp_version 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.
1400
+ * Retrieves the OApp version information.
1401
+ *
1402
+ * # Returns
1403
+ * A tuple containing:
1404
+ * - `sender_version`: The version of the OAppSender
1405
+ * - `receiver_version`: The version of the OAppReceiver
1406
+ */
1407
+ oapp_version: (txnOptions?: {
1408
+ /**
1409
+ * The fee to pay for the transaction. Default: BASE_FEE
1410
+ */
1411
+ fee?: number;
1412
+ /**
1413
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1414
+ */
1415
+ timeoutInSeconds?: number;
1416
+ /**
1417
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1418
+ */
1419
+ simulate?: boolean;
1420
+ }) => Promise<AssembledTransaction<readonly [u64, u64]>>;
1421
+ /**
1422
+ * 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.
1423
+ * Retrieves the LayerZero endpoint address associated with the OApp.
1424
+ *
1425
+ * # Returns
1426
+ * The LayerZero endpoint address
1427
+ */
1428
+ endpoint: (txnOptions?: {
1429
+ /**
1430
+ * The fee to pay for the transaction. Default: BASE_FEE
1431
+ */
1432
+ fee?: number;
1433
+ /**
1434
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1435
+ */
1436
+ timeoutInSeconds?: number;
1437
+ /**
1438
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1439
+ */
1440
+ simulate?: boolean;
1441
+ }) => Promise<AssembledTransaction<string>>;
1442
+ /**
1443
+ * Construct and simulate a peer 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.
1444
+ * Retrieves the peer (OApp) associated with a corresponding endpoint.
1445
+ *
1446
+ * # Arguments
1447
+ * * `eid` - The endpoint ID
1448
+ *
1449
+ * # Returns
1450
+ * The peer address (OApp instance) associated with the corresponding endpoint
1451
+ */
1452
+ peer: ({ eid }: {
1453
+ eid: u32;
1454
+ }, txnOptions?: {
1455
+ /**
1456
+ * The fee to pay for the transaction. Default: BASE_FEE
1457
+ */
1458
+ fee?: number;
1459
+ /**
1460
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1461
+ */
1462
+ timeoutInSeconds?: number;
1463
+ /**
1464
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1465
+ */
1466
+ simulate?: boolean;
1467
+ }) => Promise<AssembledTransaction<Option<Buffer>>>;
1468
+ /**
1469
+ * Construct and simulate a set_peer 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.
1470
+ * Sets or removes the peer address (OApp instance) for a corresponding endpoint.
1471
+ *
1472
+ * # Arguments
1473
+ * * `eid` - The endpoint ID
1474
+ * * `peer` - The address of the peer to be associated with the corresponding endpoint, or None to remove the peer
1475
+ */
1476
+ set_peer: ({ eid, peer }: {
1477
+ eid: u32;
1478
+ peer: Option<Buffer>;
1479
+ }, txnOptions?: {
1480
+ /**
1481
+ * The fee to pay for the transaction. Default: BASE_FEE
1482
+ */
1483
+ fee?: number;
1484
+ /**
1485
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1486
+ */
1487
+ timeoutInSeconds?: number;
1488
+ /**
1489
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1490
+ */
1491
+ simulate?: boolean;
1492
+ }) => Promise<AssembledTransaction<null>>;
1493
+ /**
1494
+ * Construct and simulate a set_delegate 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.
1495
+ * Sets the delegate address for the OApp Core.
1496
+ *
1497
+ * # Arguments
1498
+ * * `delegate` - The address of the delegate to be set, or None to remove the delegate
1499
+ */
1500
+ set_delegate: ({ delegate }: {
1501
+ delegate: Option<string>;
1502
+ }, txnOptions?: {
1503
+ /**
1504
+ * The fee to pay for the transaction. Default: BASE_FEE
1505
+ */
1506
+ fee?: number;
1507
+ /**
1508
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1509
+ */
1510
+ timeoutInSeconds?: number;
1511
+ /**
1512
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1513
+ */
1514
+ simulate?: boolean;
1515
+ }) => Promise<AssembledTransaction<null>>;
1516
+ /**
1517
+ * 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.
1518
+ * Sets TTL configs for instance and persistent storage.
1519
+ *
1520
+ * - `None` values remove the corresponding config (disables auto-extension for that type)
1521
+ * - Validates that `threshold <= extend_to <= MAX_TTL`
1522
+ *
1523
+ * # Arguments
1524
+ * - `instance` - TTL config for instance storage
1525
+ * - `persistent` - TTL config for persistent storage
1526
+ *
1527
+ * # Panics
1528
+ * - `TtlConfigFrozen` if configs are frozen
1529
+ * - `InvalidTtlConfig` if validation fails
1530
+ */
1531
+ set_ttl_configs: ({ instance, persistent }: {
1532
+ instance: Option<TtlConfig>;
1533
+ persistent: Option<TtlConfig>;
1534
+ }, txnOptions?: {
1535
+ /**
1536
+ * The fee to pay for the transaction. Default: BASE_FEE
1537
+ */
1538
+ fee?: number;
1539
+ /**
1540
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1541
+ */
1542
+ timeoutInSeconds?: number;
1543
+ /**
1544
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1545
+ */
1546
+ simulate?: boolean;
1547
+ }) => Promise<AssembledTransaction<null>>;
1548
+ /**
1549
+ * 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.
1550
+ * Returns the current TTL configs as (instance_config, persistent_config).
1551
+ */
1552
+ ttl_configs: (txnOptions?: {
1553
+ /**
1554
+ * The fee to pay for the transaction. Default: BASE_FEE
1555
+ */
1556
+ fee?: number;
1557
+ /**
1558
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1559
+ */
1560
+ timeoutInSeconds?: number;
1561
+ /**
1562
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1563
+ */
1564
+ simulate?: boolean;
1565
+ }) => Promise<AssembledTransaction<readonly [Option<TtlConfig>, Option<TtlConfig>]>>;
1566
+ /**
1567
+ * 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.
1568
+ * Permanently freezes TTL configs, preventing any future modifications.
1569
+ *
1570
+ * This is irreversible and provides immutability guarantees to users.
1571
+ * Emits `TtlConfigsFrozen` event.
1572
+ *
1573
+ * # Panics
1574
+ * - `TtlConfigAlreadyFrozen` if already frozen
1575
+ */
1576
+ freeze_ttl_configs: (txnOptions?: {
1577
+ /**
1578
+ * The fee to pay for the transaction. Default: BASE_FEE
1579
+ */
1580
+ fee?: number;
1581
+ /**
1582
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1583
+ */
1584
+ timeoutInSeconds?: number;
1585
+ /**
1586
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1587
+ */
1588
+ simulate?: boolean;
1589
+ }) => Promise<AssembledTransaction<null>>;
1590
+ /**
1591
+ * 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.
1592
+ * Returns whether TTL configs are frozen.
1593
+ */
1594
+ is_ttl_configs_frozen: (txnOptions?: {
1595
+ /**
1596
+ * The fee to pay for the transaction. Default: BASE_FEE
1597
+ */
1598
+ fee?: number;
1599
+ /**
1600
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1601
+ */
1602
+ timeoutInSeconds?: number;
1603
+ /**
1604
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1605
+ */
1606
+ simulate?: boolean;
1607
+ }) => Promise<AssembledTransaction<boolean>>;
1608
+ /**
1609
+ * 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.
1610
+ * Extends the instance TTL.
1611
+ *
1612
+ * # Arguments
1613
+ *
1614
+ * * `threshold` - The threshold to extend the TTL (if current TTL is below this, extend).
1615
+ * * `extend_to` - The TTL to extend to.
1616
+ */
1617
+ extend_instance_ttl: ({ threshold, extend_to }: {
1618
+ threshold: u32;
1619
+ extend_to: u32;
1620
+ }, txnOptions?: {
1621
+ /**
1622
+ * The fee to pay for the transaction. Default: BASE_FEE
1623
+ */
1624
+ fee?: number;
1625
+ /**
1626
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1627
+ */
1628
+ timeoutInSeconds?: number;
1629
+ /**
1630
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1631
+ */
1632
+ simulate?: boolean;
1633
+ }) => Promise<AssembledTransaction<null>>;
1634
+ /**
1635
+ * 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.
1636
+ * Returns the current owner address, or None if no owner is set.
1637
+ */
1638
+ owner: (txnOptions?: {
1639
+ /**
1640
+ * The fee to pay for the transaction. Default: BASE_FEE
1641
+ */
1642
+ fee?: number;
1643
+ /**
1644
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1645
+ */
1646
+ timeoutInSeconds?: number;
1647
+ /**
1648
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1649
+ */
1650
+ simulate?: boolean;
1651
+ }) => Promise<AssembledTransaction<Option<string>>>;
1652
+ /**
1653
+ * 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.
1654
+ * Returns the pending owner address for 2-step transfer, or None if no transfer is pending.
1655
+ */
1656
+ pending_owner: (txnOptions?: {
1657
+ /**
1658
+ * The fee to pay for the transaction. Default: BASE_FEE
1659
+ */
1660
+ fee?: number;
1661
+ /**
1662
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1663
+ */
1664
+ timeoutInSeconds?: number;
1665
+ /**
1666
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1667
+ */
1668
+ simulate?: boolean;
1669
+ }) => Promise<AssembledTransaction<Option<string>>>;
1670
+ /**
1671
+ * 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.
1672
+ * Transfers ownership immediately to a new address.
1673
+ *
1674
+ * Use with caution - if you transfer to a wrong address, ownership is lost forever.
1675
+ * Consider using `propose_ownership_transfer` instead.
1676
+ *
1677
+ * # Panics
1678
+ * - `OwnerNotSet` if no owner is currently set
1679
+ * - `TransferInProgress` if a 2-step transfer is in progress
1680
+ */
1681
+ transfer_ownership: ({ new_owner }: {
1682
+ new_owner: string;
1683
+ }, txnOptions?: {
1684
+ /**
1685
+ * The fee to pay for the transaction. Default: BASE_FEE
1686
+ */
1687
+ fee?: number;
1688
+ /**
1689
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1690
+ */
1691
+ timeoutInSeconds?: number;
1692
+ /**
1693
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1694
+ */
1695
+ simulate?: boolean;
1696
+ }) => Promise<AssembledTransaction<null>>;
1697
+ /**
1698
+ * 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.
1699
+ * Proposes an ownership transfer to a new address.
1700
+ *
1701
+ * The new owner must call `accept_ownership()` within `ttl` ledgers
1702
+ * to complete the transfer. The pending transfer will automatically expire after.
1703
+ *
1704
+ * # Arguments
1705
+ * - `new_owner` - The proposed new owner
1706
+ * - `ttl` - Number of ledgers the new owner has to accept.
1707
+ * Use `0` to cancel a pending transfer (new_owner must match pending).
1708
+ *
1709
+ * # Panics
1710
+ * - `OwnerNotSet` if no owner is currently set
1711
+ * - `NoPendingTransfer` when cancelling and no pending transfer exists
1712
+ * - `InvalidTtl` if ttl exceeds max TTL
1713
+ * - `InvalidPendingOwner` when cancelling with wrong new_owner address
1714
+ */
1715
+ propose_ownership_transfer: ({ new_owner, ttl }: {
1716
+ new_owner: string;
1717
+ ttl: u32;
1718
+ }, txnOptions?: {
1719
+ /**
1720
+ * The fee to pay for the transaction. Default: BASE_FEE
1721
+ */
1722
+ fee?: number;
1723
+ /**
1724
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1725
+ */
1726
+ timeoutInSeconds?: number;
1727
+ /**
1728
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1729
+ */
1730
+ simulate?: boolean;
1731
+ }) => Promise<AssembledTransaction<null>>;
1732
+ /**
1733
+ * 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.
1734
+ * Accepts a pending 2-step ownership transfer.
1735
+ *
1736
+ * Must be called by the pending owner before the TTL expires.
1737
+ *
1738
+ * # Panics
1739
+ * - `NoPendingTransfer` if there is no pending transfer (or it expired)
1740
+ */
1741
+ accept_ownership: (txnOptions?: {
1742
+ /**
1743
+ * The fee to pay for the transaction. Default: BASE_FEE
1744
+ */
1745
+ fee?: number;
1746
+ /**
1747
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1748
+ */
1749
+ timeoutInSeconds?: number;
1750
+ /**
1751
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1752
+ */
1753
+ simulate?: boolean;
1754
+ }) => Promise<AssembledTransaction<null>>;
1755
+ /**
1756
+ * 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.
1757
+ * Permanently renounces ownership.
1758
+ *
1759
+ * # Panics
1760
+ * - `OwnerNotSet` if no owner is currently set
1761
+ * - `TransferInProgress` if a 2-step transfer is in progress (cancel it first)
1762
+ */
1763
+ renounce_ownership: (txnOptions?: {
1764
+ /**
1765
+ * The fee to pay for the transaction. Default: BASE_FEE
1766
+ */
1767
+ fee?: number;
1768
+ /**
1769
+ * The maximum amount of time to wait for the transaction to complete. Default: DEFAULT_TIMEOUT
1770
+ */
1771
+ timeoutInSeconds?: number;
1772
+ /**
1773
+ * Whether to automatically simulate the transaction when constructing the AssembledTransaction. Default: true
1774
+ */
1775
+ simulate?: boolean;
1776
+ }) => Promise<AssembledTransaction<null>>;
1777
+ }
1778
+ export declare class Client extends ContractClient {
1779
+ readonly options: ContractClientOptions;
1780
+ static deploy<T = Client>(
1781
+ /** Constructor/Initialization Args for the contract's `__constructor` method */
1782
+ { token, owner, endpoint, delegate, shared_decimals, oft_type }: {
1783
+ token: string;
1784
+ owner: string;
1785
+ endpoint: string;
1786
+ delegate: Option<string>;
1787
+ shared_decimals: u32;
1788
+ oft_type: OftType;
1789
+ },
1790
+ /** Options for initializing a Client as well as for calling a method, with extras specific to deploying. */
1791
+ options: MethodOptions & Omit<ContractClientOptions, "contractId"> & {
1792
+ /** The hash of the Wasm blob, which must already be installed on-chain. */
1793
+ wasmHash: Buffer | string;
1794
+ /** Salt used to generate the contract's ID. Passed through to {@link Operation.createCustomContract}. Default: random. */
1795
+ salt?: Buffer | Uint8Array;
1796
+ /** The format used to decode `wasmHash`, if it's provided as a string. */
1797
+ format?: "hex" | "base64";
1798
+ }): Promise<AssembledTransaction<T>>;
1799
+ constructor(options: ContractClientOptions);
1800
+ readonly fromJSON: {
1801
+ set_rate_limit: (json: string) => AssembledTransaction<null>;
1802
+ unset_rate_limit: (json: string) => AssembledTransaction<null>;
1803
+ rate_limit_config: (json: string) => AssembledTransaction<readonly [bigint, bigint]>;
1804
+ rate_limit_in_flight: (json: string) => AssembledTransaction<bigint>;
1805
+ rate_limit_capacity: (json: string) => AssembledTransaction<bigint>;
1806
+ set_default_fee_bps: (json: string) => AssembledTransaction<null>;
1807
+ set_fee_bps: (json: string) => AssembledTransaction<null>;
1808
+ unset_fee_bps: (json: string) => AssembledTransaction<null>;
1809
+ set_fee_deposit_address: (json: string) => AssembledTransaction<null>;
1810
+ has_fee_bps: (json: string) => AssembledTransaction<boolean>;
1811
+ effective_fee_bps: (json: string) => AssembledTransaction<bigint>;
1812
+ default_fee_bps: (json: string) => AssembledTransaction<bigint>;
1813
+ fee_bps: (json: string) => AssembledTransaction<Option<bigint>>;
1814
+ fee_deposit_address: (json: string) => AssembledTransaction<string>;
1815
+ set_paused: (json: string) => AssembledTransaction<null>;
1816
+ is_paused: (json: string) => AssembledTransaction<boolean>;
1817
+ quote_oft: (json: string) => AssembledTransaction<readonly [OFTLimit, OFTFeeDetail[], OFTReceipt]>;
1818
+ token: (json: string) => AssembledTransaction<string>;
1819
+ oft_version: (json: string) => AssembledTransaction<readonly [bigint, bigint]>;
1820
+ shared_decimals: (json: string) => AssembledTransaction<number>;
1821
+ decimal_conversion_rate: (json: string) => AssembledTransaction<bigint>;
1822
+ approval_required: (json: string) => AssembledTransaction<boolean>;
1823
+ quote_send: (json: string) => AssembledTransaction<MessagingFee>;
1824
+ send: (json: string) => AssembledTransaction<readonly [MessagingReceipt, OFTReceipt]>;
1825
+ oft_type: (json: string) => AssembledTransaction<OftType>;
1826
+ authorizer: (json: string) => AssembledTransaction<string>;
1827
+ enforced_options: (json: string) => AssembledTransaction<Buffer<ArrayBufferLike>>;
1828
+ set_enforced_options: (json: string) => AssembledTransaction<null>;
1829
+ combine_options: (json: string) => AssembledTransaction<Buffer<ArrayBufferLike>>;
1830
+ allow_initialize_path: (json: string) => AssembledTransaction<boolean>;
1831
+ next_nonce: (json: string) => AssembledTransaction<bigint>;
1832
+ lz_receive: (json: string) => AssembledTransaction<null>;
1833
+ is_compose_msg_sender: (json: string) => AssembledTransaction<boolean>;
1834
+ oapp_version: (json: string) => AssembledTransaction<readonly [bigint, bigint]>;
1835
+ endpoint: (json: string) => AssembledTransaction<string>;
1836
+ peer: (json: string) => AssembledTransaction<Option<Buffer<ArrayBufferLike>>>;
1837
+ set_peer: (json: string) => AssembledTransaction<null>;
1838
+ set_delegate: (json: string) => AssembledTransaction<null>;
1839
+ set_ttl_configs: (json: string) => AssembledTransaction<null>;
1840
+ ttl_configs: (json: string) => AssembledTransaction<readonly [Option<TtlConfig>, Option<TtlConfig>]>;
1841
+ freeze_ttl_configs: (json: string) => AssembledTransaction<null>;
1842
+ is_ttl_configs_frozen: (json: string) => AssembledTransaction<boolean>;
1843
+ extend_instance_ttl: (json: string) => AssembledTransaction<null>;
1844
+ owner: (json: string) => AssembledTransaction<Option<string>>;
1845
+ pending_owner: (json: string) => AssembledTransaction<Option<string>>;
1846
+ transfer_ownership: (json: string) => AssembledTransaction<null>;
1847
+ propose_ownership_transfer: (json: string) => AssembledTransaction<null>;
1848
+ accept_ownership: (json: string) => AssembledTransaction<null>;
1849
+ renounce_ownership: (json: string) => AssembledTransaction<null>;
1850
+ };
1851
+ }