@layerzerolabs/lz-v2-stellar-sdk 0.2.29 → 0.2.30

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 (59) hide show
  1. package/.turbo/turbo-test.log +512 -351
  2. package/dist/generated/bml.d.ts +3 -9
  3. package/dist/generated/bml.js +6 -7
  4. package/dist/generated/counter.d.ts +22 -28
  5. package/dist/generated/counter.js +11 -12
  6. package/dist/generated/dvn.d.ts +36 -54
  7. package/dist/generated/dvn.js +10 -15
  8. package/dist/generated/dvn_fee_lib.d.ts +3 -21
  9. package/dist/generated/dvn_fee_lib.js +6 -11
  10. package/dist/generated/endpoint.d.ts +3 -9
  11. package/dist/generated/endpoint.js +6 -7
  12. package/dist/generated/executor.d.ts +80 -54
  13. package/dist/generated/executor.js +16 -16
  14. package/dist/generated/executor_fee_lib.d.ts +3 -21
  15. package/dist/generated/executor_fee_lib.js +6 -11
  16. package/dist/generated/executor_helper.d.ts +36 -42
  17. package/dist/generated/executor_helper.js +9 -10
  18. package/dist/generated/layerzero_view.d.ts +20 -32
  19. package/dist/generated/layerzero_view.js +25 -26
  20. package/dist/generated/oft.d.ts +147 -79
  21. package/dist/generated/oft.js +47 -54
  22. package/dist/generated/price_feed.d.ts +20 -38
  23. package/dist/generated/price_feed.js +15 -20
  24. package/dist/generated/sac_manager.d.ts +1309 -0
  25. package/dist/generated/sac_manager.js +484 -0
  26. package/dist/generated/sml.d.ts +3 -9
  27. package/dist/generated/sml.js +6 -7
  28. package/dist/generated/treasury.d.ts +3 -9
  29. package/dist/generated/treasury.js +8 -9
  30. package/dist/generated/uln302.d.ts +20 -20
  31. package/dist/generated/uln302.js +25 -22
  32. package/dist/generated/upgrader.d.ts +3 -9
  33. package/dist/generated/upgrader.js +6 -7
  34. package/dist/index.d.ts +1 -0
  35. package/dist/index.js +1 -0
  36. package/package.json +5 -5
  37. package/src/generated/bml.ts +7 -8
  38. package/src/generated/counter.ts +26 -27
  39. package/src/generated/dvn.ts +25 -42
  40. package/src/generated/dvn_fee_lib.ts +7 -24
  41. package/src/generated/endpoint.ts +7 -8
  42. package/src/generated/executor.ts +72 -45
  43. package/src/generated/executor_fee_lib.ts +7 -24
  44. package/src/generated/executor_helper.ts +25 -26
  45. package/src/generated/layerzero_view.ts +35 -48
  46. package/src/generated/oft.ts +163 -103
  47. package/src/generated/price_feed.ts +17 -34
  48. package/src/generated/sac_manager.ts +1296 -0
  49. package/src/generated/sml.ts +7 -8
  50. package/src/generated/treasury.ts +13 -14
  51. package/src/generated/uln302.ts +35 -32
  52. package/src/generated/upgrader.ts +7 -8
  53. package/src/index.ts +1 -0
  54. package/test/oft-sml.test.ts +7 -5
  55. package/test/sac-manager-redistribution.test.ts +578 -0
  56. package/test/suites/globalSetup.ts +11 -6
  57. package/test/test_data/test_upgradeable_dvn.wasm +0 -0
  58. package/test/upgrader.test.ts +75 -202
  59. package/test/utils.ts +40 -0
@@ -0,0 +1,1309 @@
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: 47427 bytes (46.32 KB)
10
+ */
11
+ export declare const WASM_BASE64 = "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gIAARQ0AIANCAhCAgICAACICQv8Bg0LNAFINASAAIAI3AwhCASECCyAAIAI3AwAPCwALkgECAX8BfiOAgICAAEEQayIBJICAgIAAAkACQAJAAkAgAEEBcUUNACABQaKGwIAAQQoQtoCAgAAgASgCAA0CIAEgASkDCBC3gICAAAwBCyABQZqGwIAAQQgQtoCAgAAgASgCAA0BIAEgASkDCBC3gICAAAsgASkDCCECIAEpAwBQDQELAAsgAUEQaiSAgICAACACCxUAIAAQpICAgAAgAUICEIGAgIAAGgtNAgF/AX4Qp4CAgABBACEAAkBBABCogICAACIBQgIQoYCAgABFDQBBASEAAkACQCABQgIQgICAgACnQf8BcQ4CAQIACwALQQAhAAsgAAtIAQF/I4CAgIAAQRBrIgAkgICAgAAgAEEEahCTgYCAAAJAIAAoAgRBAUcNACAAKAIIIAAoAgwQjoGAgAALIABBEGokgICAgAALwgECAX8BfiOAgICAAEEQayIBJICAgIAAAkACQAJAAkACQAJAIABB/wFxDgMAAQIACyABQY6JwIAAQQYQtoCAgAAgASgCAA0DIAEgASkDCBC3gICAAAwCCyABQZSJwIAAQQgQtoCAgAAgASgCAA0CIAEgASkDCBC3gICAAAwBCyABQZyJwIAAQQoQtoCAgAAgASgCAA0BIAEgASkDCBC3gICAAAsgASkDCCECIAEpAwBQDQELAAsgAUEQaiSAgICAACACC2sCAX8CfiOAgICAAEEQayICJICAgIAAIAJBBGoQqoCAgAACQCACKAIEQQFHDQAgAjUCDCEDIAI1AgghBCAAIAEQoICAgABCASAEQiCGQgSEIANCIIZCBIQQgoCAgAAaCyACQRBqJICAgIAACwwAIABBAhCbgYCAAAsPABCsgICAABCDgICAABoLRwIBfwF+I4CAgIAAQRBrIgAkgICAgAAQp4CAgAAgABCugICAACAAKQMIIQEgACkDAEGLCBCvgICAACAAQRBqJICAgIAAIAELbAIBfwF+I4CAgIAAQRBrIgAkgICAgAAgABCugICAACAAKQMIIQEgACkDAEGLCBCvgICAAAJAIAEQrICAgAAQsICAgAANAEKDgICA4IABELGAgIAAAAsgARCDgICAABogAEEQaiSAgICAACABCxAAEKeAgIAAIAAQtYCAgAALKQACQCAAp0EBcUUNAA8LIAFB+ndqrUIghkKDgICA4IABfBCxgICAAAALDQAgACABEJiAgIAAUAsLACAAEJ6AgIAAGgtCAQF/I4CAgIAAQRBrIgAkgICAgAAgABCzgICAAAJAIAApAwBQDQBCg4CAgMCBARCxgICAAAALIABBEGokgICAgAALUwECfhCngICAAEIAIQECQAJAQQEQtICAgAAiAkIAEKGAgIAARQ0AIAJCABCAgICAACIBQv8Bg0LNAFINASAAIAE3AwhCASEBCyAAIAE3AwAPCwALkgECAX8BfiOAgICAAEEQayIBJICAgIAAAkACQAJAAkAgAEEBcUUNACABQaGIwIAAQQwQtoCAgAAgASgCAA0CIAEgASkDCBC3gICAAAwBCyABQZyIwIAAQQUQtoCAgAAgASgCAA0BIAEgASkDCBC3gICAAAsgASkDCCECIAEpAwBQDQELAAsgAUEQaiSAgICAACACC00BAn5CACEBAkACQEEAELSAgIAAIgJCAhChgICAAEUNACACQgIQgICAgAAiAUL/AYNCzQBSDQEgACABNwMIQgEhAQsgACABNwMADwsAC1ECAX8BfiOAgICAAEEQayIDJICAgIAAIAMgASACEJiBgIAAQgEhBAJAIAMoAgANACAAIAMpAwg3AwhCACEECyAAIAQ3AwAgA0EQaiSAgICAAAtEAQF/I4CAgIAAQRBrIgIkgICAgAAgAiABNwMIIAJBCGpBARC4gICAACEBIABCADcDACAAIAE3AwggAkEQaiSAgICAAAsaACAArUIghkIEhCABrUIghkIEhBCQgICAAAtgAgF/AX4jgICAgABBEGsiACSAgICAACAAQayAwIAAQRUQtoCAgAACQAJAIAAoAgANACAAIAApAwgQt4CAgAAgACgCAEEBRw0BCwALIAApAwghASAAQRBqJICAgIAAIAELRwEBfyOAgICAAEEQayIEJICAgIAAIAQgACABIAIgAxC7gICAAAJAIAQoAgBBAUcNAAALIAQpAwghAyAEQRBqJICAgIAAIAMLhwEBAX8jgICAgABBEGsiBSSAgICAACAFIAEgAhDMgICAAEIBIQICQCAFKAIADQAgBSkDCCEBIAUgAyAEEMyAgIAAIAUoAgANACAFIAUpAwg3AwggBSABNwMAIABB4IDAgABBAiAFQQIQyICAgAA3AwhCACECCyAAIAI3AwAgBUEQaiSAgICAAAsZAAJAIAENAEEADwsgACABKQMAELCAgIAACxAAELmAgIAAQgIQoYCAgAALFgEBfkIAIAAQoICAgABCAhChgICAAAtVAQF/I4CAgIAAQdAAayICJICAgIAAIAIgARDAgICAAAJAIAItAEhBAkcNAEKDgICA0BkQsYCAgAAACyAAIAJB0AAQn4GAgAAaIAJB0ABqJICAgIAAC4EEBAF/AX4CfwJ+I4CAgIAAQcABayICJICAgIAAAkACQAJAQgEgARCggICAACIDQgEQoYCAgAANACAAQQI6AEgMAQsgA0IBEICAgIAAIQNBACEEAkADQCAEQRBGDQEgAiAEakICNwMAIARBCGohBAwACwsgA0L/AYNCzABSDQEgA0G4hcCAAEECIAJBAhDKgICAACACQcAAaiACKQMAEM6AgIAAIAItAGgiBUECRg0BIAJBgAFqIAJBwABqQSgQn4GAgAAaIAIgAkHsAGooAAA2AHsgAiACKABpNgJ4QQAhBAJAA0AgBEEQRg0BIAJBsAFqIARqQgI3AwAgBEEIaiEEDAALCyACKQMIIgNC/wGDQswAUg0BIANBkIHAgABBAiACQbABakECEMqAgIAAAkACQCACKQOwASIDp0H/AXEiBEHAAEYNACAEQQZHDQMgA0IIiCEDDAELIAMQhYCAgAAhAwsgAkHAAGogAikDuAEQy4CAgAAgAigCQEEBRg0BIAIpA1AhBiACKQNYIQcgAkEYaiACQYABakEoEJ+BgIAAGiAAQcwAaiACKAB7NgAAIAAgAigCeDYASSAAIAc3AwggACAGNwMAIAAgAzcDECAAQRhqIAJBEGpBMBCfgYCAABogACAFOgBIQgEgARCpgICAAAsgAkHAAWokgICAgAAPCwALJgAgABCDgICAABoCQCAAEMKAgIAADQBCg4CAgJAaELGAgIAAAAsLWgECfyOAgICAAEEQayIBJICAgIAAEKeAgIAAIAFBCGoQ1ICAgAAgABCIgICAABDVgICAAAJAIAEoAggiAkECRw0AENaAgIAAAAsgAUEQaiSAgICAACACQQBHCyQAAkACQCABQgBTDQAgA0J/VQ0BC0KDgICAwBkQsYCAgAAACwttAgF/AX4jgICAgABBEGsiAySAgICAAEGAgMCAAEESEMWAgIAAEMaAgIAAIQQgACABEMeAgIAAIQEgAyACNwMIIAMgATcDACAEQZyAwIAAQQIgA0ECEMiAgIAAEISAgIAAGiADQRBqJICAgIAAC0UCAX8BfiOAgICAAEEQayICJICAgIAAIAIgACABEJiBgIAAAkAgAigCAEEBRw0AAAsgAikDCCEDIAJBEGokgICAgAAgAwtjAwF/AX4BfyOAgICAAEEQayIBJICAgIAAIAEgADcDAEICIQJBASEDAkADQCADRQ0BIANBf2ohAyAAIQIMAAsLIAEgAjcDCCABQQhqQQEQuICAgAAhACABQRBqJICAgIAAIAALQwEBfyOAgICAAEEQayICJICAgIAAIAIgACABEMyAgIAAAkAgAigCAEEBRw0AAAsgAikDCCEBIAJBEGokgICAgAAgAQsuAAJAIAEgA0YNAAALIACtQiCGQgSEIAKtQiCGQgSEIAGtQiCGQgSEEJaAgIAAC+8BAgJ/A34jgICAgABBMGsiAiSAgICAAEEAIQMCQANAIANBEEYNASACIANqQgI3AwAgA0EIaiEDDAALC0IAIQRCASEFAkAgAUL/AYNCzABSDQAgAUHggMCAAEECIAJBAhDKgICAACACQRBqIAIpAwAQy4CAgAAgAigCEEEBRg0AIAIpAyghASACKQMgIQYgAkEQaiACKQMIEMuAgIAAIAIoAhBBAUYNACACKQMgIQQgACACKQMoNwMoIAAgBDcDICAAIAE3AxggACAGNwMQQgAhBUIAIQQLIAAgBTcDACAAIAQ3AwggAkEwaiSAgICAAAsxAAJAIAIgBEYNAAALIAAgAa1CIIZCBIQgA61CIIZCBIQgAq1CIIZCBIQQl4CAgAAaC30CAX8BfgJAAkACQAJAIAGnQf8BcSICQcUARg0AIAJBC0cNAiAAIAFCP4c3AxggACABQgiHNwMQDAELIAEQkYCAgAAhAyABEJKAgIAAIQEgACADNwMYIAAgATcDEAtCACEBDAELIABCg5CAgIABNwMIQgEhAQsgACABNwMAC1sAAkACQCABQoCAgICAgIDAAHxC//////////8AVg0AIAEgAYUgAiABQj+HhYRCAFINACABQgiGQguEIQEMAQsgAiABEJOAgIAAIQELIABCADcDACAAIAE3AwgLfwIBfwF+I4CAgIAAQSBrIgEkgICAgABBuITAgABB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QQhqIQUMAAsLIABCjvKz1wwgBEEQakECELiAgIAAEPCAgIAAIARBIGokgICAgAAPCyAEQRBqIAVqQgI3AwAgBUEIaiEFDAALCw8AEKeAgIAAEL2AgIAArQvUAgEDfyOAgICAAEEgayICJICAgIAAAkACQAJAAkAgAEL/AYNCzQBSDQBBASABp0H/AXEiA0EAR0EBdCADQQFGGyIDQQJGDQAQq4CAgAAQp4CAgAAgAkEIahDUgICAACIBIAAQiICAgAAQ1YCAgAAgAigCCCIEQQJGDQECQAJAIANBAXENACAERQ0EIAIoAgwiBCABEImAgIAAQiCIp08NASABIAStQiCGQgSEEIqAgIAAIQEMAQsgBA0EIAEgABCLgICAACEBC0IDIAEQooCAgABCAyAAEKmAgIAAQdSDwIAAQRcQxYCAgAAQxoCAgAAhASACIAA3AxggAiADrTcDECABQfSDwIAAQQIgAkEQakECEMiAgIAAEISAgIAAGiACQSBqJICAgIAAQgIPCwALENaAgIAAAAtCg4CAgNAZELGAgIAAAAtCg4CAgIAZELGAgIAAAAu/BQMCfwR+AX8jgICAgABBsAFrIgMkgICAgAACQAJAAkACQAJAIABC/wGDQs0AUg0AIAFC/wGDQs0AUg0AAkACQCACQgJSDQBBAiEEDAELIANBEGogAhDOgICAACADLQA4IgRBAkYNASADKQMoIQUgAykDICEGIAMpAxghByADKQMQIQIgAykDMCEICxCngICAACAAEMGAgIAAIAEQ0YCAgAAhCQJAAkAgBEECRg0AIAkNAyACIAcgBiAFEMOAgIAAEOCAgIAAIQAgAyAFNwNIIAMgBjcDQCADIAc3AzggAyACNwMwIAMgBzcDGCADIAI3AxAgAyAEOgBYIAMgCDcDUCADIAA3AyAgASADQRBqENCAgIAAENKAgIAAIAEQi4CAgAAQ04CAgAAgAyAFNwN4IAMgBjcDcCADIAc3A2ggAyACNwNgIAMgBDoAiAEgAyAINwOAASADIAE3A5ABQaCBwIAAQRcQxYCAgAAQxoCAgAAhACADQaABaiADQeAAahDPgICAACADKAKgAUEBRg0CIAMpA6gBIQIgAyABNwOoASADIAI3A6ABIABB0IHAgABBAiADQaABakECEMiAgIAAEISAgIAAGgwBCyAJRQ0DQgEgARCggICAAEIBEIyAgIAAGiADQQhqENKAgIAAIgAgARCIgICAABDVgICAACADKAIIIgRBAkYNBCAEQQFxRQ0FAkAgAygCDCIEIAAQiYCAgABCIIinTw0AIAAgBK1CIIZCBIQQioCAgAAhAAsgABDTgICAAEHggcCAAEEZEMWAgIAAEMaAgIAAIQAgAyABNwMQIABB/IHAgABBASADQRBqQQEQyICAgAAQhICAgAAaCyADQbABaiSAgICAAEICDwsAC0KDgICAgBkQsYCAgAAAC0KDgICA0BkQsYCAgAAACxDWgICAAAALENqAgIAAAAs9AgF+AX8CQBCZgICAACIAp0H/AXEiAUEGRg0AAkAgAUHAAEcNACAAEIWAgIAADwsQ1oCAgAAACyAAQgiIC/UCAgF/B34jgICAgABB8ABrIgMkgICAgAACQAJAIABC/wGDQs0AUg0AIAFC/wGDQs0AUg0AIAMgAhDJgICAACADKAIAQQFxDQAgAykDKCEEIAMpAyAhBSADKQMYIQIgAykDECEGEKeAgIAAIAAQwYCAgAAgBiACIAUgBBDDgICAACADIAEQv4CAgAAgAykDOCEAIAMpAzAhBwJAIAYgAykDICIIhSACIAMpAygiCYWEQgBSDQAgByAFhSAAIASFhEIAUQ0CCyADIAU3AzAgAyAGNwMgIAMgBDcDOCADIAI3AyggASADENCAgIAAQYSCwIAAQRQQxYCAgAAQxoCAgAAhCiAGIAIgBSAEELqAgIAAIQIgCCAJIAcgABC6gICAACEGIAMgATcDaCADIAY3A2AgAyACNwNYIApBuILAgABBAyADQdgAakEDEMiAgIAAEISAgIAAGiADQfAAaiSAgICAAEICDwsAC0KDgICAgBoQsYCAgAAAC/EBAQN/I4CAgIAAQfAAayIDJICAgIAAAkACQCAAQv8Bg0LNAFINACABQv8Bg0LNAFINAEEBIAKnQf8BcSIEQQBHQQF0IARBAUYbIgRBAkYNABCngICAACAAEMGAgIAAIAMgARC/gICAACADLQBIIgUgBEYNASADIAQ6AEggASADENCAgIAAQdCCwIAAQRsQxYCAgAAQxoCAgAAhACADIAE3A2ggAyAFrTcDYCADIAStNwNYIABBgIPAgABBAyADQdgAakEDEMiAgIAAEISAgIAAGiADQfAAaiSAgICAAEICDwsA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ATcDiAEgBCAANwOAASAEIAY3A3ggBUGghMCAAEEDIARB+ABqQQMQyICAgAAQhICAgAAaCwJAEL2AgIAARQ0AENiAgIAAIAEQ2YCAgAANACACIAMgARDEgICAACAEQSBqEK6AgIAAIAQoAiBFDQIgBCkDKCEBCxDYgICAACABIAIgAxDcgICAACAEQZABaiSAgICAAA8LQoOAgICgGRCxgICAAAALENqAgIAAAAuHAgIBfwF+I4CAgIAAQdAAayIDJICAgIAAAkACQCAAQv8Bg0LNAFINACABQv8Bg0LNAFINACADIAIQy4CAgAAgAygCAEEBRg0AIAMpAxghAiADKQMQIQQQp4CAgAAgABCDgICAABoCQAJAEL6AgIAADQAgAxCugICAACAAIANBCGpBACADKAIAGxC8gICAAA0BQoOAgIAwELGAgIAAAAsgAyAAEL+AgIAAIAMtAEhFDQIgAyAENwMAIAMgATcDGCADIAA3AxAgAyACNwMIIAMQzYCAgAALENiAgIAAIAEgBCACENuAgIAAIANB0ABqJICAgIAAQgIPCwALQoOAgICQGRCxgICAAAALbgIBfwF+I4CAgIAAQRBrIgEkgICAgAACQCAAQv8Bg0LNAFENAAALEKuAgIAAEKeAgIAAENiAgIAAIQIgASAANwMIIAJCjuauueqM5NU4IAFBCGpBARC4gICAABDwgICAACABQRBqJICAgIAAQgILIQACQCAAIAEgAhCVgICAAEL/AYNCAlENABDWgICAAAALC/EBAgN/AX4jgICAgABBIGsiAiSAgICAAAJAIABC/wGDQs0AUg0AQQAhA0EBIAGnQf8BcSIEQQBHQQF0IARBAUYbIgRBAkYNABCrgICAABCngICAABDYgICAACEBQayGwIAAQQ4QxYCAgAAhBSACIAStNwMIIAIgADcDAANAAkAgA0EQRw0AQQAhAwJAA0AgA0EQRg0BIAJBEGogA2ogAiADaikDADcDACADQQhqIQMMAAsLIAEgBSACQRBqQQIQuICAgAAQ8ICAgAAgAkEgaiSAgICAAEICDwsgAkEQaiADakICNwMAIANBCGohAwwACwsAC3gBAX8jgICAgABBEGsiASSAgICAAAJAAkAgAEL/AYNCzQBSDQAQq4CAgAAQp4CAgAAgARDzgICAACAAIAFBCGpBACABKAIAGxC8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AhAQ+oCAgAAMAQtBARCogICAAEICEIyAgIAAGgsCQAJAIAIoAhhBAUcNACACKAIcIAIoAiAQ+4CAgAAMAQtBAhCogICAAEICEIyAgIAAGgsgAkEoakEIaiACQQhqQQhqKAIANgIAIAJBPGogAkEYakEIaigCADYCACACIAIpAwg3AyggAiACKQMYNwI0QciIwIAAQQ8QxYCAgAAQxoCAgAAhACACQShqEJGBgIAAIQEgAiACQTRqEJGBgIAANwNIIAIgATcDQCAAQeyIwIAAQQIgAkHAAGpBAhDIgICAABCEgICAABogAkHQAGokgICAgABCAg8LAAtoAQF/I4CAgIAAQRBrIgIkgICAgAACQAJAIAFCAlENACACQQRqIAEQmYGAgAACQCACKAIERQ0AIABBAjYCAAwCCyAAIAIpAgg3AgQgAEEBNgIADAELIABBADYCAAsgAkEQaiSAgICAAAtDAgF/AX4jgICAgABBEGsiASSAgICAACABIAAQlIGAgAACQCABKAIAQQFHDQAACyABKQMIIQIgAUEQaiSAgICAACACC6ABAgJ/AX4jgICAgABBwABrIgAkgICAgAAQp4CAgAAgAEEIahCTgYCAACAAQRRqIgEQqoCAgAAgAEEwaiAAQQhqEJSBgIAAAkACQCAAKAIwDQAgACkDOCECIABBMGogARCUgYCAACAAKAIwQQFHDQELAAsgACAAKQM4NwMoIAAgAjcDICAAQSBqQQIQuICAgAAhAiAAQcAAaiSAgICAACACCwwAIABBARCbgYCAAAswAAJAIAEoAgBBAUcNACAAIAEoAgQgASgCCBCagYCAAA8LIABCADcDACAAQgI3AwgLiAEBAX8jgICAgABBEGsiACSAgICAABCrgICAABCngICAAAJAEKaAgIAARQ0AQoOAgIDg/wAQsYCAgAAAC0EAEKiAgIAAQgFCAhCBgICAABpB/IjAgABBEhDFgICAABDGgICAAEEEQQAgAEEIakEAEMiAgIAAEISAgIAAGiAAQRBqJICAgIAAQgILCQAQpoCAgACtCwMAAAvbAQIBfgR/AkACQCACQQlLDQBCACEDIAIhBCABIQUDQAJAIAQNACADQgiGQg6EIQMMAwtBASEGAkAgBS0AACIHQd8ARg0AAkAgB0FQakH/AXFBCkkNAAJAIAdBv39qQf8BcUEaSQ0AIAdBn39qQf8BcUEZSw0EIAdBRWohBgwCCyAHQUtqIQYMAQsgB0FSaiEGCyADQgaGIAatQv8Bg4QhAyAEQX9qIQQgBUEBaiEFDAALCyABrUIghkIEhCACrUIghkIEhBCUgICAACEDCyAAQgA3AwAgACADNwMIC60BAgJ/AX4jgICAgABBEGsiAiSAgICAAEEAIQMCQANAIANBEEYNASACIANqQgI3AwAgA0EIaiEDDAALC0EBIQMCQCABQv8Bg0LMAFINACABQbiIwIAAQQIgAkECEMqAgIAAIAIpAwAiAUL/AYNCBFINACACKQMIIgRC/wGDQgRSDQAgACABQiCIpzYCCCAAIARCIIg+AgRBACEDCyAAIAM2AgAgAkEQaiSAgICAAAtgAgF/AX4jgICAgABBEGsiAySAgICAACADIAGtQiCGQgSENwMIIAMgAq1CIIZCBIQ3AwBBuIjAgABBAiADQQIQyICAgAAhBCAAQgA3AwAgACAENwMIIANBEGokgICAgAALdwICfwF+I4CAgIAAQRBrIgIkgICAgABBACEDAkACQCABEKiAgIAAIgRCAhChgICAAEUNACACQQRqIARCAhCAgICAABCZgYCAAEEBIQMgAigCBEEBRg0BIAAgAikCCDcCBAsgACADNgIAIAJBEGokgICAgAAPCwALVgIBfwF+I4CAgIAAQRBrIgMkgICAgAAgABCogICAACEEIAMgASACEJqBgIAAAkAgAygCAEEBRw0AAAsgBCADKQMIQgIQgYCAgAAaIANBEGokgICAgAAL1QMDAX8CfgJ/I4CAgIAAQeAAayIGJICAgIAAQgAhB0IAIQhBACEJAkAgASAChFANACADIASEUA0AQgAgA30gAyAEQgBTIgkbIQdCACABfSABIAJCAFMiChshCEIAIAQgA0IAUq18fSAEIAkbIQMgBCAChSEEAkACQEIAIAIgAUIAUq18fSACIAobIgJQDQACQCADUA0AIAZB0ABqIAcgAyAIIAIQoIGAgABBASEJIAYpA1ghASAGKQNQIQIMAgsgBkHAAGogByADIAhCABCggYCAACAGQTBqIAcgAyACQgAQoIGAgAAgBikDSCICIAYpAzB8IgEgAlQgBikDOEIAUnIhCSAGKQNAIQIMAQsCQCADUA0AIAZBIGogB0IAIAggAhCggYCAACAGQRBqIANC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bGxlcnRvEgAQAAYAAAAUAhAACgAAAB4CEAACAAAAc3VwcGx5X2RlY3JlYXNlZGZyb20SABAABgAAABQCEAAKAAAASAIQAAQAAABhbGxvd19hbnlfbWludF9idXJubGltaXRfY29uZmlnd2hpdGVsaXN0X2FkZHJlc3NlcwAAZAIQABMAAAB3AhAADAAAAIMCEAATAAAAc3RhdGUAAAC3ABAABgAAALACEAAFAAAAU3VwcGx5Q29udHJvbEVuYWJsZWRTdXBwbHlDb250cm9sbGVyRW50cnlTdXBwbHlDb250cm9sbGVyc1N1cHBseUNvbnRyb2xsZXJNYW5hZ2Vyc1NhY1Rva2VuT2Z0QWRkcmVzc3NldF9hdXRob3JpemVkYXV0aG9yaXplZHRocmVzaG9sZG93bmVyc2hpcF90cmFuc2ZlcnJlZG5ld19vd25lcm9sZF9vd25lcmIDEAAJAAAAawMQAAkAAABvd25lcnNoaXBfdHJhbnNmZXJyaW5ndHRsAAAAYgMQAAkAAABrAxAACQAAAJoDEAADAAAAb3duZXJzaGlwX3RyYW5zZmVyX2NhbmNlbGxlZGNhbmNlbGxlZF9wZW5kaW5nX293bmVyb3duZXLUAxAAFwAAAOsDEAAFAAAAb3duZXJzaGlwX3Jlbm91bmNlZABrAxAACQAAAE93bmVyUGVuZGluZ093bmVyZXh0ZW5kX3RvAAAtBBAACQAAAEQDEAAJAAAAdHRsX2NvbmZpZ3Nfc2V0aW5zdGFuY2VwZXJzaXN0ZW50AAAAVwQQAAgAAABfBBAACgAAAHR0bF9jb25maWdzX2Zyb3plbkZyb3plbkluc3RhbmNlUGVyc2lzdGVudE1pZ3JhdGluZwDX3gEOY29udHJhY3RzcGVjdjAAAAAEAAAAAAAAAAAAAAATUmVkaXN0cmlidXRpb25FcnJvcgAAAAACAAAAOEFjY291bnQgaXMgbm90IGJsYWNrbGlzdGVkIChyZXF1aXJlZCBmb3IgcmVkaXN0cmlidXRpb24pAAAADk5vdEJsYWNrbGlzdGVkAAAAAABkAAAAHVJlZGlzdHJpYnV0aW9uIGlzIG5vdCBlbmFibGVkAAAAAAAAGFJlZGlzdHJpYnV0aW9uTm90RW5hYmxlZAAAAGUAAAAFAAAARkV2ZW50IGVtaXR0ZWQgd2hlbiBmdW5kcyBhcmUgcmVkaXN0cmlidXRlZCBmcm9tIGEgYmxhY2tsaXN0ZWQgYWNjb3VudC4AAAAAAAAAAAARUmVkaXN0cmlidXRlRnVuZHMAAAAAAAABAAAAEnJlZGlzdHJpYnV0ZV9mdW5kcwAAAAAAAgAAAAAAAAAEdXNlcgAAABMAAAAAAAAAAAAAAAZhbW91bnQAAAAAAAsAAAAAAAAAAgAAAAIAAAAAAAAAAAAAABVSZWRpc3RyaWJ1dGlvblN0b3JhZ2UAAAAAAAABAAAAAAAAAAAAAAAVUmVkaXN0cmlidXRpb25FbmFibGVkAAAAAAAAAQAAACZMaW1pdCBjb25maWd1cmF0aW9uIGZvciByYXRlIGxpbWl0aW5nLgAAAAAAAAAAAAtMaW1pdENvbmZpZwAAAAACAAAAHU1heCBhbW91bnQgZm9yIHRoZSByYXRlIGxpbWl0AAAAAAAADmxpbWl0X2NhcGFjaXR5AAAAAAALAAAAhUFtb3VudCB0byBhZGQgdG8gbGltaXQgZWFjaCBzZWNvbmQgdXAgdG8gdGhlIGxpbWl0Q2FwYWNpdHkuCkEgdmFsdWUgb2YgMCBtZWFucyByYXRlIGxpbWl0aW5nIGlzIGRpc2FibGVkICh1bmxpbWl0ZWQgbWludGluZyBhbGxvd2VkKS4AAAAAAAARcmVmaWxsX3Blcl9zZWNvbmQAAAAAAAALAAAAAQAAAElSYXRlIGxpbWl0IHN0YXRlICh0aGUgcnVudGltZSBzdGF0ZSB0aGF0IHBlcnNpc3RzIGFjcm9zcyBjb25maWcgdXBkYXRlcykuAAAAAAAAAAAAAA5SYXRlTGltaXRTdGF0ZQAAAAAAAgAAABhUaW1lc3RhbXAgb2YgbGFzdCByZWZpbGwAAAAQbGFzdF9yZWZpbGxfdGltZQAAAAYAAAAkUmVtYWluaW5nIGFtb3VudCBmb3IgdGhlIHRpbWUgcGVyaW9kAAAAEHJlbWFpbmluZ19hbW91bnQAAAALAAAABAAAACBTdXBwbHkgY29udHJvbCBlcnJvcnM6IDMyNTAtMzI5OQAAAAAAAAASU3VwcGx5Q29udHJvbEVycm9yAAAAAAAKAAAAR0VudHJ5IGFscmVhZHkgZXhpc3RzIChzdXBwbHkgY29udHJvbGxlciwgbWFuYWdlciwgb3Igd2hpdGVsaXN0IGFkZHJlc3MpAAAAAA1BbHJlYWR5RXhpc3RzAAAAAAAAyAAAAB1DYW5ub3QgYnVybiBmcm9tIHRoaXMgYWRkcmVzcwAAAAAAABVDYW5ub3RCdXJuRnJvbUFkZHJlc3MAAAAAAADJAAAALkNhbm5vdCBtaW50IHRvIHRoaXMgYWRkcmVzcyAobm90IGluIHdoaXRlbGlzdCkAAAAAABNDYW5ub3RNaW50VG9BZGRyZXNzAAAAAMoAAAAOSW52YWxpZCBhbW91bnQAAAAAAA1JbnZhbGlkQW1vdW50AAAAAAAAywAAABVJbnZhbGlkIGNvbmZpZ3VyYXRpb24AAAAAAAANSW52YWxpZENvbmZpZwAAAAAAAMwAAABCRW50cnkgbm90IGZvdW5kIChzdXBwbHkgY29udHJvbGxlciwgbWFuYWdlciwgb3Igd2hpdGVsaXN0IGFkZHJlc3MpAAAAAAAITm90Rm91bmQAAADNAAAALFRpbWVzdGFtcCBpcyBvbGRlciB0aGFuIHRoZSBsYXN0IHJlZmlsbCB0aW1lAAAADE9sZFRpbWVzdGFtcAAAAM4AAAATUmF0ZSBsaW1pdCBleGNlZWRlZAAAAAARUmF0ZUxpbWl0RXhjZWVkZWQAAAAAAADPAAAAJlZhbHVlIGlzIGFscmVhZHkgc2V0IHRvIHRoZSBzYW1lIHN0YXRlAAAAAAAJU2FtZVZhbHVlAAAAAAAA0AAAAD1DYWxsZXIgaXMgbm90IGF1dGhvcml6ZWQgKG5vdCBhIHN1cHBseSBjb250cm9sbGVyIG9yIG1hbmFnZXIpAAAAAAAADFVuYXV0aG9yaXplZAAAANEAAAAFAAAAMEV2ZW50IGVtaXR0ZWQgd2hlbiBhIHN1cHBseSBjb250cm9sbGVyIGlzIGFkZGVkLgAAAAAAAAAVU3VwcGx5Q29udHJvbGxlckFkZGVkAAAAAAAAAQAAABdzdXBwbHlfY29udHJvbGxlcl9hZGRlZAAAAAACAAAAAAAAABFzdXBwbHlfY29udHJvbGxlcgAAAAAAABMAAAAAAAAAAAAAAAZjb25maWcAAAAAB9AAAAAWU3VwcGx5Q29udHJvbGxlckNvbmZpZwAAAAAAAAAAAAIAAAAFAAAAMkV2ZW50IGVtaXR0ZWQgd2hlbiBhIHN1cHBseSBjb250cm9sbGVyIGlzIHJlbW92ZWQuAAAAAAAAAAAAF1N1cHBseUNvbnRyb2xsZXJSZW1vdmVkAAAAAAEAAAAZc3VwcGx5X2NvbnRyb2xsZXJfcmVtb3ZlZAAAAAAAAAEAAAAAAAAAEXN1cHBseV9jb250cm9sbGVyAAAAAAAAEwAAAAAAAAACAAAABQAAAEpFdmVudCBlbWl0dGVkIHdoZW4gbGltaXQgY29uZmlndXJhdGlvbiBpcyB1cGRhdGVkIGZvciBhIHN1cHBseSBjb250cm9sbGVyLgAAAAAAAAAAABJMaW1pdENvbmZpZ1VwZGF0ZWQAAAAAAAEAAAAUbGltaXRfY29uZmlnX3VwZGF0ZWQAAAADAAAAAAAAABFzdXBwbHlfY29udHJvbGxlcgAAAAAAABMAAAAAAAAAAAAAABBuZXdfbGltaXRfY29uZmlnAAAH0AAAAAtMaW1pdENvbmZpZwAAAAAAAAAAAAAAABBvbGRfbGltaXRfY29uZmlnAAAH0AAAAAtMaW1pdENvbmZpZwAAAAAAAAAAAgAAAAUAAABMRXZlbnQgZW1pdHRlZCB3aGVuIGBhbGxvd19hbnlfbWludF9idXJuYCBpcyB1cGRhdGVkIGZvciBhIHN1cHBseSBjb250cm9sbGVyLgAAAAAAAAAXQWxsb3dBbnlNaW50QnVyblVwZGF0ZWQAAAAAAQAAABthbGxvd19hbnlfbWludF9idXJuX3VwZGF0ZWQAAAAAAwAAAAAAAAARc3VwcGx5X2NvbnRyb2xsZXIAAAAAAAATAAAAAAAAAAAAAAAJbmV3X2FsbG93AAAAAAAAAQAAAAAAAAAAAAAACW9sZF9hbGxvdwAAAAAAAAEAAAAAAAAAAgAAAAUAAAA+RXZlbnQgZW1pdHRlZCB3aGVuIGEgbWludCB3aGl0ZWxpc3QgZW50cnkgaXMgYWRkZWQgb3IgcmVtb3ZlZC4AAAAAAAAAAAAQTWludFdoaXRlbGlzdFNldAAAAAEAAAASbWludF93aGl0ZWxpc3Rfc2V0AAAAAAADAAAAAAAAABFzdXBwbHlfY29udHJvbGxlcgAAAAAAABMAAAAAAAAAAAAAAAxtaW50X2FkZHJlc3MAAAATAAAAAAAAAAAAAAAGYWN0aXZlAAAAAAABAAAAAAAAAAIAAAAFAAAAQ0V2ZW50IGVtaXR0ZWQgd2hlbiBhIHN1cHBseSBjb250cm9sbGVyIG1hbmFnZXIgaXMgYWRkZWQgb3IgcmVtb3ZlZC4AAAAAAAAAABRTdXBwbHlDdHJsTWFuYWdlclNldAAAAAEAAAAXc3VwcGx5X2N0cmxfbWFuYWdlcl9zZXQAAAAAAgAAAAAAAAAHbWFuYWdlcgAAAAATAAAAAAAAAAAAAAAGYWN0aXZlAAAAAAABAAAAAAAAAAIAAAAFAAAAJUV2ZW50IGVtaXR0ZWQgd2hlbiB0b2tlbnMgYXJlIG1pbnRlZC4AAAAAAAAAAAAAD1N1cHBseUluY3JlYXNlZAAAAAABAAAAEHN1cHBseV9pbmNyZWFzZWQAAAADAAAAAAAAAApjb250cm9sbGVyAAAAAAATAAAAAAAAAAAAAAACdG8AAAAAABMAAAAAAAAAAAAAAAZhbW91bnQAAAAAAAsAAAAAAAAAAgAAAAUAAAAlRXZlbnQgZW1pdHRlZCB3aGVuIHRva2VucyBhcmUgYnVybmVkLgAAAAAAAAAAAAAPU3VwcGx5RGVjcmVhc2VkAAAAAAEAAAAQc3VwcGx5X2RlY3JlYXNlZAAAAAMAAAAAAAAACmNvbnRyb2xsZXIAAAAAABMAAAAAAAAAAAAAAARmcm9tAAAAEwAAAAAAAAAAAAAABmFtb3VudAAAAAAACwAAAAAAAAACAAAAAQAAAD5TdXBwbHkgY29udHJvbGxlciBjb25maWd1cmF0aW9uICh0aGUgY29uZmlndXJhYmxlIHBhcmFtZXRlcnMpLgAAAAAAAAAAABZTdXBwbHlDb250cm9sbGVyQ29uZmlnAAAAAAADAAAAk0lmIHRydWUsIGFsbG93cyB0aGUgc3VwcGx5IGNvbnRyb2xsZXIgdG8gbWludCB0byBhbmQgYnVybiBmcm9tIGFueSBhZGRyZXNzLgpXaGVuIGZhbHNlLCB0aGUgY29udHJvbGxlciBjYW4gb25seSBtaW50IHRvIGFkZHJlc3NlcyBpbiBpdHMgd2hpdGVsaXN0LgAAAAATYWxsb3dfYW55X21pbnRfYnVybgAAAAABAAAAE0xpbWl0IGNvbmZpZ3VyYXRpb24AAAAADGxpbWl0X2NvbmZpZwAAB9AAAAALTGltaXRDb25maWcAAAAAYkFkZHJlc3NlcyB0aGF0IHRoaXMgc3VwcGx5IGNvbnRyb2xsZXIgaXMgYWxsb3dlZCB0byBtaW50IHRvICh3aGVuIGBhbGxvd19hbnlfbWludF9idXJuYCBpcyBmYWxzZSkuAAAAAAATd2hpdGVsaXN0X2FkZHJlc3NlcwAAAAPqAAAAEwAAAAEAAAB3U3VwcGx5IGNvbnRyb2xsZXIgd2l0aCBib3RoIGNvbmZpZyBhbmQgc3RhdGUgbmVzdGVkIHRvZ2V0aGVyLgpTdG9yZWQgcGVyLWNvbnRyb2xsZXIgZm9yIE8oMSkgYWNjZXNzIG9uIGV2ZXJ5IG1pbnQvYnVybi4AAAAAAAAAABVTdXBwbHlDb250cm9sbGVyRW50cnkAAAAAAAACAAAALENvbmZpZ3VyYXRpb24gKGNhbiBiZSB1cGRhdGVkIGluZGVwZW5kZW50bHkpAAAABmNvbmZpZwAAAAAH0AAAABZTdXBwbHlDb250cm9sbGVyQ29uZmlnAAAAAAAyUmF0ZSBsaW1pdCBzdGF0ZSAocHJlc2VydmVkIGFjcm9zcyBjb25maWcgdXBkYXRlcykAAAAAAAVzdGF0ZQAAAAAAB9AAAAAOUmF0ZUxpbWl0U3RhdGUAAAAAAAIAAAAAAAAAAAAAABRTdXBwbHlDb250cm9sU3RvcmFnZQAAAAQAAAAAAAAAAAAAABRTdXBwbHlDb250cm9sRW5hYmxlZAAAAAEAAAAAAAAAFVN1cHBseUNvbnRyb2xsZXJFbnRyeQAAAAAAAAEAAAATAAAAAAAAAAAAAAARU3VwcGx5Q29udHJvbGxlcnMAAAAAAAAAAAAAAAAAABhTdXBwbHlDb250cm9sbGVyTWFuYWdlcnMAAAAEAAAAIkdlbmVyYWwgU2FjTWFuYWdlckVycm9yOiAzMjIwLTMyNDkAAAAAAAAAAAAPU2FjTWFuYWdlckVycm9yAAAAAAMAAAAgT0ZUIGFkZHJlc3MgaGFzIG5vdCBiZWVuIHNldCB5ZXQAAAAQT2Z0QWRkcmVzc05vdFNldAAAAAEAAAAXVGhlIHZhbHVlcyBhcmUgdGhlIHNhbWUAAAAACVNhbWVWYWx1ZQAAAAAAAAIAAAArQ2FsbGVyIGlzIG5vdCBhdXRob3JpemVkIGZvciB0aGlzIG9wZXJhdGlvbgAAAAAMVW5hdXRob3JpemVkAAAAAwAAAAAAAAA8UmVkaXN0cmlidXRlcyBmdW5kcyBmcm9tIGEgYmxhY2tsaXN0ZWQgYWNjb3VudCB0byB0aGUgb3duZXIuAAAAHnJlZGlzdHJpYnV0ZV9ibGFja2xpc3RlZF9mdW5kcwAAAAAAAgAAAAAAAAAEZnJvbQAAABMAAAAAAAAABmFtb3VudAAAAAAACwAAAAAAAAAAAAAAAAAAABZyZWRpc3RyaWJ1dGlvbl9lbmFibGVkAAAAAAAAAAAAAQAAAAEAAAAAAAAAQ1NldHMgd2hldGhlciBhbiBhZGRyZXNzIGlzIGEgc3VwcGx5IGNvbnRyb2xsZXIgbWFuYWdlci4gT3duZXItb25seS4AAAAAHXNldF9zdXBwbHlfY29udHJvbGxlcl9tYW5hZ2VyAAAAAAAAAgAAAAAAAAAHbWFuYWdlcgAAAAATAAAAAAAAAAZhY3RpdmUAAAAAAAEAAAAAAAAAAAAAAKlTZXRzIG9yIHJlbW92ZXMgYSBzdXBwbHkgY29udHJvbGxlci4gTWFuYWdlci1vbmx5LgoKLSBgU29tZShjb25maWcpYDogQWRkcyBhIG5ldyBzdXBwbHkgY29udHJvbGxlciB3aXRoIHRoZSBnaXZlbiBjb25maWd1cmF0aW9uLgotIGBOb25lYDogUmVtb3ZlcyB0aGUgc3VwcGx5IGNvbnRyb2xsZXIuAAAAAAAAFXNldF9zdXBwbHlfY29udHJvbGxlcgAAAAAAAAMAAAAAAAAABnNlbmRlcgAAAAAAEwAAAAAAAAARc3VwcGx5X2NvbnRyb2xsZXIAAAAAAAATAAAAAAAAAAZjb25maWcAAAAAA+gAAAfQAAAAFlN1cHBseUNvbnRyb2xsZXJDb25maWcAAAAAAAAAAAAAAAAAoFVwZGF0ZXMgdGhlIHJhdGUgbGltaXQgY29uZmlndXJhdGlvbiBmb3IgYSBzdXBwbHkgY29udHJvbGxlci4gTWFuYWdlci1vbmx5LgpOb3RlOiBUaGlzIGRvZXMgTk9UIHJlc2V0IHRoZSByYXRlIGxpbWl0IHN0YXRlIChyZW1haW5pbmdfYW1vdW50LCBsYXN0X3JlZmlsbF90aW1lKS4AAAATdXBkYXRlX2xpbWl0X2NvbmZpZwAAAAADAAAAAAAAAAZzZW5kZXIAAAAAABMAAAAAAAAAEXN1cHBseV9jb250cm9sbGVyAAAAAAAAEwAAAAAAAAAMbGltaXRfY29uZmlnAAAH0AAAAAtMaW1pdENvbmZpZwAAAAAAAAAAAAAAAFpVcGRhdGVzIHdoZXRoZXIgdGhlIHN1cHBseSBjb250cm9sbGVyIGNhbiBtaW50IHRvIGFuZCBidXJuIGZyb20gYW55IGFkZHJlc3MuIE1hbmFnZXItb25seS4AAAAAABp1cGRhdGVfYWxsb3dfYW55X21pbnRfYnVybgAAAAAAAwAAAAAAAAAGc2VuZGVyAAAAAAATAAAAAAAAABFzdXBwbHlfY29udHJvbGxlcgAAAAAAABMAAAAAAAAAE2FsbG93X2FueV9taW50X2J1cm4AAAAAAQAAAAAAAAAAAAAAVlNldHMgd2hldGhlciBhbiBhZGRyZXNzIGlzIGluIHRoZSBtaW50IHdoaXRlbGlzdCBvZiBhIHN1cHBseSBjb250cm9sbGVyLiBNYW5hZ2VyLW9ubHkuAAAAAAASc2V0X21pbnRfd2hpdGVsaXN0AAAAAAAEAAAAAAAAAAZzZW5kZXIAAAAAABMAAAAAAAAAEXN1cHBseV9jb250cm9sbGVyAAAAAAAAEwAAAAAAAAAMbWludF9hZGRyZXNzAAAAEwAAAAAAAAAGYWN0aXZlAAAAAAABAAAAAAAAAAAAAABBUmV0dXJucyB3aGV0aGVyIHRoZSBnaXZlbiBhZGRyZXNzIGlzIGEgc3VwcGx5IGNvbnRyb2xsZXIgbWFuYWdlci4AAAAAAAAcaXNfc3VwcGx5X2NvbnRyb2xsZXJfbWFuYWdlcgAAAAEAAAAAAAAAB2FkZHJlc3MAAAAAEwAAAAEAAAABAAAAAAAAAC1HZXRzIGFsbCBzdXBwbHkgY29udHJvbGxlciBtYW5hZ2VyIGFkZHJlc3Nlcy4AAAAAAAAeZ2V0X3N1cHBseV9jb250cm9sbGVyX21hbmFnZXJzAAAAAAAAAAAAAQAAA+oAAAATAAAAAAAAACVHZXRzIHN1cHBseSBjb250cm9sbGVyIGNvbmZpZ3VyYXRpb24uAAAAAAAAHGdldF9zdXBwbHlfY29udHJvbGxlcl9jb25maWcAAAABAAAAAAAAABFzdXBwbHlfY29udHJvbGxlcgAAAAAAABMAAAABAAAD6AAAB9AAAAAWU3VwcGx5Q29udHJvbGxlckNvbmZpZwAAAAAAAAAAAAAAAAATYWxsb3dfYW55X21pbnRfYnVybgAAAAABAAAAAAAAABFzdXBwbHlfY29udHJvbGxlcgAAAAAAABMAAAABAAAAAQAAAAAAAAAsR2V0cyBhbGwgYWN0aXZlIHN1cHBseSBjb250cm9sbGVyIGFkZHJlc3Nlcy4AAAAWZ2V0X3N1cHBseV9jb250cm9sbGVycwAAAAAAAAAAAAEAAAPqAAAAEwAAAAAAAABNUmV0dXJucyB3aGV0aGVyIHRoZSBnaXZlbiBhZGRyZXNzIGlzIGluIHRoZSB3aGl0ZWxpc3Qgb2YgYSBzdXBwbHkgY29udHJvbGxlci4AAAAAAAAWaXNfYWRkcmVzc193aGl0ZWxpc3RlZAAAAAAAAgAAAAAAAAARc3VwcGx5X2NvbnRyb2xsZXIAAAAAAAATAAAAAAAAAAxtaW50X2FkZHJlc3MAAAATAAAAAQAAAAEAAAAAAAAAP0dldHMgcmVtYWluaW5nIGFtb3VudCB3aGljaCBjYW4gYmUgbWludGVkIGF0IGN1cnJlbnQgdGltZXN0YW1wLgAAAAAZZ2V0X3JlbWFpbmluZ19taW50X2Ftb3VudAAAAAAAAAEAAAAAAAAAEXN1cHBseV9jb250cm9sbGVyAAAAAAAAEwAAAAEAAAALAAAAAAAAAAAAAAAWc3VwcGx5X2NvbnRyb2xfZW5hYmxlZAAAAAAAAAAAAAEAAAABAAAAAAAAAAAAAAAPYXV0aG9yaXplZF9taW50AAAAAAMAAAAAAAAABnNlbmRlcgAAAAAAEwAAAAAAAAACdG8AAAAAABMAAAAAAAAABmFtb3VudAAAAAAACwAAAAAAAAAAAAAAAAAAAAhjbGF3YmFjawAAAAMAAAAAAAAABnNlbmRlcgAAAAAAEwAAAAAAAAAEZnJvbQAAABMAAAAAAAAABmFtb3VudAAAAAAACwAAAAAAAAAAAAAAAAAAABFyZWxlYXNlX3NhY19hZG1pbgAAAAAAAAEAAAAAAAAAAnRvAAAAAAATAAAAAAAAAAAAAAAAAAAADnNldF9hdXRob3JpemVkAAAAAAACAAAAAAAAAAJpZAAAAAAAEwAAAAAAAAAJYXV0aG9yaXplAAAAAAAAAQAAAAAAAAAAAAAAAAAAAA9zZXRfb2Z0X2FkZHJlc3MAAAAAAQAAAAAAAAAHbmV3X29mdAAAAAATAAAAAAAAAAAAAAAAAAAADnVuZGVybHlpbmdfc2FjAAAAAAAAAAAAAQAAABMAAAAAAAAAAAAAAAtvZnRfYWRkcmVzcwAAAAAAAAAAAQAAABMAAAAAAAAAAAAAAARtaW50AAAAAgAAAAAAAAACdG8AAAAAABMAAAAAAAAABmFtb3VudAAAAAAACwAAAAAAAAAAAAAAAAAAAARidXJuAAAAAgAAAAAAAAAEZnJvbQAAABMAAAAAAAAABmFtb3VudAAAAAAACwAAAAAAAAAAAAACBENvbnN0cnVjdHMgdGhlIFNBQyBtYW5hZ2VyIGNvbnRyYWN0LgoKIyBBcmd1bWVudHMKKiBgc2FjX3Rva2VuYCAtIFRoZSB1bmRlcmx5aW5nIFN0ZWxsYXIgQXNzZXQgQ29udHJhY3QgYWRkcmVzcwoqIGBvd25lcmAgLSBUaGUgaW5pdGlhbCBvd25lciBhZGRyZXNzIChmb3IgdXBncmFkZXMsIG93bmVyIG9wcywgcmVkaXN0cmlidXRpb24gdGFyZ2V0KQoqIGByZWRpc3RyaWJ1dGlvbl9lbmFibGVkYCAtIFdoZXRoZXIgcmVkaXN0cmlidXRpb24gaXMgZW5hYmxlZCBnbG9iYWxseQoqIGBzdXBwbHlfY29udHJvbF9lbmFibGVkYCAtIFdoZXRoZXIgc3VwcGx5IGNvbnRyb2wgaXMgZW5hYmxlZCBnbG9iYWxseQoKTm90ZTogVGhlIE9GVCBhZGRyZXNzIG11c3QgYmUgc2V0IHNlcGFyYXRlbHkgdmlhIGBzZXRfb2Z0X2FkZHJlc3NgIGFmdGVyIGNvbnN0cnVjdGlvbiwKYmVjYXVzZSB0aGUgT0ZUIGFuZCBzYWMtbWFuYWdlciBoYXZlIGEgY2lyY3VsYXIgZGVwZW5kZW5jeSBvbiBlYWNoIG90aGVyJ3MgYWRkcmVzc2VzLgAAAA1fX2NvbnN0cnVjdG9yAAAAAAAABAAAAAAAAAAJc2FjX3Rva2VuAAAAAAAAEwAAAAAAAAAFb3duZXIAAAAAAAATAAAAAAAAABZyZWRpc3RyaWJ1dGlvbl9lbmFibGVkAAAAAAABAAAAAAAAABZzdXBwbHlfY29udHJvbF9lbmFibGVkAAAAAAABAAAAAAAAAAAAAABsVXBncmFkZXMgdGhlIGNvbnRyYWN0IHRvIG5ldyBXQVNNIGJ5dGVjb2RlLgpTZXRzIGEgbWlncmF0aW9uIGZsYWcgdGhhdCBtdXN0IGJlIGNsZWFyZWQgYnkgY2FsbGluZyBgbWlncmF0ZWAuAAAAB3VwZ3JhZGUAAAAAAQAAAAAAAAANbmV3X3dhc21faGFzaAAAAAAAA+4AAAAgAAAAAAAAAAAAAACHUnVucyBtaWdyYXRpb24gbG9naWMgYWZ0ZXIgYW4gdXBncmFkZS4KUGFyc2VzIFhEUi1lbmNvZGVkIGBtaWdyYXRpb25fZGF0YWAgYW5kIGNhbGxzIGBfX21pZ3JhdGVgLiBDbGVhcnMgdGhlIG1pZ3JhdGlvbiBmbGFnIG9uIHN1Y2Nlc3MuAAAAAAdtaWdyYXRlAAAAAAEAAAAAAAAADm1pZ3JhdGlvbl9kYXRhAAAAAAAOAAAAAAAAAAAAAAAAAAAACmF1dGhvcml6ZXIAAAAAAAAAAAABAAAAEwAAAAAAAAA+UmV0dXJucyB0aGUgY3VycmVudCBvd25lciBhZGRyZXNzLCBvciBOb25lIGlmIG5vIG93bmVyIGlzIHNldC4AAAAAAAVvd25lcgAAAAAAAAAAAAABAAAD6AAAABMAAAAAAAAAWVJldHVybnMgdGhlIHBlbmRpbmcgb3duZXIgYWRkcmVzcyBmb3IgMi1zdGVwIHRyYW5zZmVyLCBvciBOb25lIGlmIG5vIHRyYW5zZmVyIGlzIHBlbmRpbmcuAAAAAAAADXBlbmRpbmdfb3duZXIAAAAAAAAAAAAAAQAAA+gAAAATAAAAAAAAAStUcmFuc2ZlcnMgb3duZXJzaGlwIGltbWVkaWF0ZWx5IHRvIGEgbmV3IGFkZHJlc3MuCgpVc2Ugd2l0aCBjYXV0aW9uIC0gaWYgeW91IHRyYW5zZmVyIHRvIGEgd3JvbmcgYWRkcmVzcywgb3duZXJzaGlwIGlzIGxvc3QgZm9yZXZlci4KQ29uc2lkZXIgdXNpbmcgYHByb3Bvc2Vfb3duZXJzaGlwX3RyYW5zZmVyYCBpbnN0ZWFkLgoKIyBQYW5pY3MKLSBgT3duZXJOb3RTZXRgIGlmIG5vIG93bmVyIGlzIGN1cnJlbnRseSBzZXQKLSBgVHJhbnNmZXJJblByb2dyZXNzYCBpZiBhIDItc3RlcCB0cmFuc2ZlciBpcyBpbiBwcm9ncmVzcwAAAAASdHJhbnNmZXJfb3duZXJzaGlwAAAAAAABAAAAAAAAAAluZXdfb3duZXIAAAAAAAATAAAAAAAAAAAAAAJcUHJvcG9zZXMgYW4gb3duZXJzaGlwIHRyYW5zZmVyIHRvIGEgbmV3IGFkZHJlc3MuCgpUaGUgbmV3IG93bmVyIG11c3QgY2FsbCBgYWNjZXB0X293bmVyc2hpcCgpYCB3aXRoaW4gYHR0bGAgbGVkZ2Vycwp0byBjb21wbGV0ZSB0aGUgdHJhbnNmZXIuIFRoZSBwZW5kaW5nIHRyYW5zZmVyIHdpbGwgYXV0b21hdGljYWxseSBleHBpcmUgYWZ0ZXIuCgojIEFyZ3VtZW50cwotIGBuZXdfb3duZXJgIC0gVGhlIHByb3Bvc2VkIG5ldyBvd25lcgotIGB0dGxgIC0gTnVtYmVyIG9mIGxlZGdlcnMgdGhlIG5ldyBvd25lciBoYXMgdG8gYWNjZXB0LgpVc2UgYDBgIHRvIGNhbmNlbCBhIHBlbmRpbmcgdHJhbnNmZXIgKG5ld19vd25lciBtdXN0IG1hdGNoIHBlbmRpbmcpLgoKIyBQYW5pY3MKLSBgT3duZXJOb3RTZXRgIGlmIG5vIG93bmVyIGlzIGN1cnJlbnRseSBzZXQKLSBgTm9QZW5kaW5nVHJhbnNmZXJgIHdoZW4gY2FuY2VsbGluZyBhbmQgbm8gcGVuZGluZyB0cmFuc2ZlciBleGlzdHMKLSBgSW52YWxpZFR0bGAgaWYgdHRsIGV4Y2VlZHMgbWF4IFRUTAotIGBJbnZhbGlkUGVuZGluZ093bmVyYCB3aGVuIGNhbmNlbGxpbmcgd2l0aCB3cm9uZyBuZXdfb3duZXIgYWRkcmVzcwAAABpwcm9wb3NlX293bmVyc2hpcF90cmFuc2ZlcgAAAAAAAgAAAAAAAAAJbmV3X293bmVyAAAAAAAAEwAAAAAAAAADdHRsAAAAAAQAAAAAAAAAAAAAALlBY2NlcHRzIGEgcGVuZGluZyAyLXN0ZXAgb3duZXJzaGlwIHRyYW5zZmVyLgoKTXVzdCBiZSBjYWxsZWQgYnkgdGhlIHBlbmRpbmcgb3duZXIgYmVmb3JlIHRoZSBUVEwgZXhwaXJlcy4KCiMgUGFuaWNzCi0gYE5vUGVuZGluZ1RyYW5zZmVyYCBpZiB0aGVyZSBpcyBubyBwZW5kaW5nIHRyYW5zZmVyIChvciBpdCBleHBpcmVkKQAAAAAAABBhY2NlcHRfb3duZXJzaGlwAAAAAAAAAAAAAAAAAAAApFBlcm1hbmVudGx5IHJlbm91bmNlcyBvd25lcnNoaXAuCgojIFBhbmljcwotIGBPd25lck5vdFNldGAgaWYgbm8gb3duZXIgaXMgY3VycmVudGx5IHNldAotIGBUcmFuc2ZlckluUHJvZ3Jlc3NgIGlmIGEgMi1zdGVwIHRyYW5zZmVyIGlzIGluIHByb2dyZXNzIChjYW5jZWwgaXQgZmlyc3QpAAAAEnJlbm91bmNlX293bmVyc2hpcAAAAAAAAAAAAAAAAAAAAAAApUV4dGVuZHMgdGhlIGluc3RhbmNlIFRUTC4KCiMgQXJndW1lbnRzCgoqIGB0aHJlc2hvbGRgIC0gVGhlIHRocmVzaG9sZCB0byBleHRlbmQgdGhlIFRUTCAoaWYgY3VycmVudCBUVEwgaXMgYmVsb3cgdGhpcywgZXh0ZW5kKS4KKiBgZXh0ZW5kX3RvYCAtIFRoZSBUVEwgdG8gZXh0ZW5kIHRvLgAAAAAAABNleHRlbmRfaW5zdGFuY2VfdHRsAAAAAAIAAAAAAAAACXRocmVzaG9sZAAAAAAAAAQAAAAAAAAACWV4dGVuZF90bwAAAAAAAAQAAAAAAAAAAAAAAY9TZXRzIFRUTCBjb25maWdzIGZvciBpbnN0YW5jZSBhbmQgcGVyc2lzdGVudCBzdG9yYWdlLgoKLSBgTm9uZWAgdmFsdWVzIHJlbW92ZSB0aGUgY29ycmVzcG9uZGluZyBjb25maWcgKGRpc2FibGVzIGF1dG8tZXh0ZW5zaW9uIGZvciB0aGF0IHR5cGUpCi0gVmFsaWRhdGVzIHRoYXQgYHRocmVzaG9sZCA8PSBleHRlbmRfdG8gPD0gTUFYX1RUTGAKCiMgQXJndW1lbnRzCi0gYGluc3RhbmNlYCAtIFRUTCBjb25maWcgZm9yIGluc3RhbmNlIHN0b3JhZ2UKLSBgcGVyc2lzdGVudGAgLSBUVEwgY29uZmlnIGZvciBwZXJzaXN0ZW50IHN0b3JhZ2UKCiMgUGFuaWNzCi0gYFR0bENvbmZpZ0Zyb3plbmAgaWYgY29uZmlncyBhcmUgZnJvemVuCi0gYEludmFsaWRUdGxDb25maWdgIGlmIHZhbGlkYXRpb24gZmFpbHMAAAAAD3NldF90dGxfY29uZmlncwAAAAACAAAAAAAAAAhpbnN0YW5jZQAAA+gAAAfQAAAACVR0bENvbmZpZwAAAAAAAAAAAAAKcGVyc2lzdGVudAAAAAAD6AAAB9AAAAAJVHRsQ29uZmlnAAAAAAAAAAAAAAAAAABIUmV0dXJucyB0aGUgY3VycmVudCBUVEwgY29uZmlncyBhcyAoaW5zdGFuY2VfY29uZmlnLCBwZXJzaXN0ZW50X2NvbmZpZykuAAAAC3R0bF9jb25maWdzAAAAAAAAAAABAAAD7QAAAAIAAAPoAAAH0AAAAAlUdGxDb25maWcAAAAAAAPoAAAH0AAAAAlUdGxDb25maWcAAAAAAAAAAAAA4VBlcm1hbmVudGx5IGZyZWV6ZXMgVFRMIGNvbmZpZ3MsIHByZXZlbnRpbmcgYW55IGZ1dHVyZSBtb2RpZmljYXRpb25zLgoKVGhpcyBpcyBpcnJldmVyc2libGUgYW5kIHByb3ZpZGVzIGltbXV0YWJpbGl0eSBndWFyYW50ZWVzIHRvIHVzZXJzLgpFbWl0cyBgVHRsQ29uZmlnc0Zyb3plbmAgZXZlbnQuCgojIFBhbmljcwotIGBUdGxDb25maWdBbHJlYWR5RnJvemVuYCBpZiBhbHJlYWR5IGZyb3plbgAAAAAAABJmcmVlemVfdHRsX2NvbmZpZ3MAAAAAAAAAAAAAAAAAAAAAACdSZXR1cm5zIHdoZXRoZXIgVFRMIGNvbmZpZ3MgYXJlIGZyb3plbi4AAAAAFWlzX3R0bF9jb25maWdzX2Zyb3plbgAAAAAAAAAAAAABAAAAAQAAAAIAAAAAAAAAAAAAABFTYWNNYW5hZ2VyU3RvcmFnZQAAAAAAAAIAAAAAAAAAAAAAAAhTYWNUb2tlbgAAAAAAAAAAAAAACk9mdEFkZHJlc3MAAAAAAAUAAAAAAAAAAAAAAApQYWNrZXRTZW50AAAAAAABAAAAC3BhY2tldF9zZW50AAAAAAMAAAAAAAAADmVuY29kZWRfcGFja2V0AAAAAAAOAAAAAAAAAAAAAAAHb3B0aW9ucwAAAAAOAAAAAAAAAAAAAAAMc2VuZF9saWJyYXJ5AAAAEwAAAAAAAAACAAAABQAAAAAAAAAAAAAADlBhY2tldFZlcmlmaWVkAAAAAAABAAAAD3BhY2tldF92ZXJpZmllZAAAAAADAAAAAAAAAAZvcmlnaW4AAAAAB9AAAAAGT3JpZ2luAAAAAAABAAAAAAAAAAhyZWNlaXZlcgAAABMAAAABAAAAAAAAAAxwYXlsb2FkX2hhc2gAAAPuAAAAIAAAAAAAAAACAAAABQAAAAAAAAAAAAAAD1BhY2tldERlbGl2ZXJlZAAAAAABAAAAEHBhY2tldF9kZWxpdmVyZWQAAAACAAAAAAAAAAZvcmlnaW4AAAAAB9AAAAAGT3JpZ2luAAAAAAABAAAAAAAAAAhyZWNlaXZlcgAAABMAAAABAAAAAgAAAAUAAAAAAAAAAAAAAA5MelJlY2VpdmVBbGVydAAAAAAAAQAAABBsel9yZWNlaXZlX2FsZXJ0AAAACQAAAAAAAAAIcmVjZWl2ZXIAAAATAAAAAQAAAAAAAAAIZXhlY3V0b3IAAAATAAAAAQAAAAAAAAAGb3JpZ2luAAAAAAfQAAAABk9yaWdpbgAAAAAAAQAAAAAAAAAEZ3VpZAAAA+4AAAAgAAAAAQAAAAAAAAADZ2FzAAAAAAsAAAAAAAAAAAAAAAV2YWx1ZQAAAAAAAAsAAAAAAAAAAAAAAAdtZXNzYWdlAAAAAA4AAAAAAAAAAAAAAApleHRyYV9kYXRhAAAAAAAOAAAAAAAAAAAAAAAGcmVhc29uAAAAAAAOAAAAAAAAAAIAAAAFAAAAAAAAAAAAAAAGWnJvU2V0AAAAAAABAAAAB3pyb19zZXQAAAAAAQAAAAAAAAADenJvAAAAABMAAAAAAAAAAgAAAAUAAAAAAAAAAAAAAAtEZWxlZ2F0ZVNldAAAAAABAAAADGRlbGVnYXRlX3NldAAAAAIAAAAAAAAABG9hcHAAAAATAAAAAQAAAAAAAAAIZGVsZWdhdGUAAAPoAAAAEwAAAAAAAAACAAAABQAAAAAAAAAAAAAAE0luYm91bmROb25jZVNraXBwZWQAAAAAAQAAABVpbmJvdW5kX25vbmNlX3NraXBwZWQAAAAAAAAEAAAAAAAAAAdzcmNfZWlkAAAAAAQAAAABAAAAAAAAAAZzZW5kZXIAAAAAA+4AAAAgAAAAAQAAAAAAAAAIcmVjZWl2ZXIAAAATAAAAAQAAAAAAAAAFbm9uY2UAAAAAAAAGAAAAAQAAAAIAAAAFAAAAAAAAAAAAAAAOUGFja2V0TmlsaWZpZWQAAAAAAAEAAAAPcGFja2V0X25pbGlmaWVkAAAAAAUAAAAAAAAAB3NyY19laWQAAAAABAAAAAEAAAAAAAAABnNlbmRlcgAAAAAD7gAAACAAAAABAAAAAAAAAAhyZWNlaXZlcgAAABMAAAABAAAAAAAAAAVub25jZQAAAAAAAAYAAAABAAAAAAAAAAxwYXlsb2FkX2hhc2gAAAPoAAAD7gAAACAAAAAAAAAAAgAAAAUAAAAAAAAAAAAAAAtQYWNrZXRCdXJudAAAAAABAAAADHBhY2tldF9idXJudAAAAAUAAAAAAAAAB3NyY19laWQAAAAABAAAAAEAAAAAAAAABnNlbmRlcgAAAAAD7gAAACAAAAABAAAAAAAAAAhyZWNlaXZlcgAAABMAAAABAAAAAAAAAAVub25jZQAAAAAAAAYAAAABAAAAAAAAAAxwYXlsb2FkX2hhc2gAAAPuAAAAIAAAAAAAAAACAAAABQAAAAAAAAAAAAAAEUxpYnJhcnlSZWdpc3RlcmVkAAAAAAAAAQAAABJsaWJyYXJ5X3JlZ2lzdGVyZWQAAAAAAAEAAAAAAAAAB25ld19saWIAAAAAEwAAAAAAAAACAAAABQAAAAAAAAAAAAAAFURlZmF1bHRTZW5kTGlicmFyeVNldAAAAAAAAAEAAAAYZGVmYXVsdF9zZW5kX2xpYnJhcnlfc2V0AAAAAgAAAAAAAAAHZHN0X2VpZAAAAAAEAAAAAQAAAAAAAAAHbmV3X2xpYgAAAAATAAAAAAAAAAIAAAAFAAAAAAAAAAAAAAAYRGVmYXVsdFJlY2VpdmVMaWJyYXJ5U2V0AAAAAQAAABtkZWZhdWx0X3JlY2VpdmVfbGlicmFyeV9zZXQAAAAAAgAAAAAAAAAHc3JjX2VpZAAAAAAEAAAAAQAAAAAAAAAHbmV3X2xpYgAAAAATAAAAAAAAAAIAAAAFAAAAAAAAAAAAAAAbRGVmYXVsdFJlY2VpdmVMaWJUaW1lb3V0U2V0AAAAAAEAAAAfZGVmYXVsdF9yZWNlaXZlX2xpYl90aW1lb3V0X3NldAAAAAACAAAAAAAAAAdzcmNfZWlkAAAAAAQAAAABAAAAAAAAAAd0aW1lb3V0AAAAA+gAAAfQAAAAB1RpbWVvdXQAAAAAAAAAAAIAAAAFAAAAAAAAAAAAAAAOU2VuZExpYnJhcnlTZXQAAAAAAAEAAAAQc2VuZF9saWJyYXJ5X3NldAAAAAMAAAAAAAAABnNlbmRlcgAAAAAAEwAAAAEAAAAAAAAAB2RzdF9laWQAAAAABAAAAAEAAAAAAAAAB25ld19saWIAAAAD6AAAABMAAAAAAAAAAgAAAAUAAAAAAAAAAAAAABFSZWNlaXZlTGlicmFyeVNldAAAAAAAAAEAAAATcmVjZWl2ZV9saWJyYXJ5X3NldAAAAAADAAAAAAAAAAhyZWNlaXZlcgAAABMAAAABAAAAAAAAAAdzcmNfZWlkAAAAAAQAAAABAAAAAAAAAAduZXdfbGliAAAAA+gAAAATAAAAAAAAAAIAAAAFAAAAAAAAAAAAAAAYUmVjZWl2ZUxpYnJhcnlUaW1lb3V0U2V0AAAAAQAAABtyZWNlaXZlX2xpYnJhcnlfdGltZW91dF9zZXQAAAAAAwAAAAAAAAAIcmVjZWl2ZXIAAAATAAAAAQAAAAAAAAADZWlkAAAAAAQAAAABAAAAAAAAAAd0aW1lb3V0AAAAA+gAAAfQAAAAB1RpbWVvdXQAAAAAAAAAAAIAAAAFAAAAAAAAAAAAAAALQ29tcG9zZVNlbnQAAAAAAQAAAAxjb21wb3NlX3NlbnQAAAAFAAAAAAAAAARmcm9tAAAAEwAAAAEAAAAAAAAAAnRvAAAAAAATAAAAAQAAAAAAAAAEZ3VpZAAAA+4AAAAgAAAAAQAAAAAAAAAFaW5kZXgAAAAAAAAEAAAAAQAAAAAAAAAHbWVzc2FnZQAAAAAOAAAAAAAAAAIAAAAFAAAAAAAAAAAAAAAQQ29tcG9zZURlbGl2ZXJlZAAAAAEAAAARY29tcG9zZV9kZWxpdmVyZWQAAAAAAAAEAAAAAAAAAARmcm9tAAAAEwAAAAEAAAAAAAAAAnRvAAAAAAATAAAAAQAAAAAAAAAEZ3VpZAAAA+4AAAAgAAAAAQAAAAAAAAAFaW5kZXgAAAAAAAAEAAAAAQAAAAIAAAAFAAAAAAAAAAAAAAAOTHpDb21wb3NlQWxlcnQAAAAAAAEAAAAQbHpfY29tcG9zZV9hbGVydAAAAAoAAAAAAAAABGZyb20AAAATAAAAAQAAAAAAAAACdG8AAAAAABMAAAABAAAAAAAAAAhleGVjdXRvcgAAABMAAAABAAAAAAAAAARndWlkAAAD7gAAACAAAAABAAAAAAAAAAVpbmRleAAAAAAAAAQAAAABAAAAAAAAAANnYXMAAAAACwAAAAAAAAAAAAAABXZhbHVlAAAAAAAACwAAAAAAAAAAAAAAB21lc3NhZ2UAAAAADgAAAAAAAAAAAAAACmV4dHJhX2RhdGEAAAAAAA4AAAAAAAAAAAAAAAZyZWFzb24AAAAAAA4AAAAAAAAAAgAAAAQAAAAAAAAAAAAAAA1FbmRwb2ludEVycm9yAAAAAAAAGQAAAC9MaWJyYXJ5IGlzIGFscmVhZHkgcmVnaXN0ZXJlZCB3aXRoIHRoZSBlbmRwb2ludAAAAAARQWxyZWFkeVJlZ2lzdGVyZWQAAAAAAAABAAAANkNvbXBvc2UgbWVzc2FnZSBhbHJlYWR5IGV4aXN0cyBmb3IgdGhpcyBHVUlEIGFuZCBpbmRleAAAAAAADUNvbXBvc2VFeGlzdHMAAAAAAAACAAAANkNvbXBvc2UgbWVzc2FnZSBub3QgZm91bmQgZm9yIHRoZSBnaXZlbiBHVUlEIGFuZCBpbmRleAAAAAAAD0NvbXBvc2VOb3RGb3VuZAAAAAADAAAAOkRlZmF1bHQgcmVjZWl2ZSBsaWJyYXJ5IGlzIG5vdCBzZXQgZm9yIHRoZSBzb3VyY2UgZW5kcG9pbnQAAAAAABxEZWZhdWx0UmVjZWl2ZUxpYlVuYXZhaWxhYmxlAAAABAAAADxEZWZhdWx0IHNlbmQgbGlicmFyeSBpcyBub3Qgc2V0IGZvciB0aGUgZGVzdGluYXRpb24gZW5kcG9pbnQAAAAZRGVmYXVsdFNlbmRMaWJVbmF2YWlsYWJsZQAAAAAAAAUAAAAvU3VwcGxpZWQgbmF0aXZlIHRva2VuIGZlZSBpcyBsZXNzIHRoYW4gcmVxdWlyZWQAAAAAFUluc3VmZmljaWVudE5hdGl2ZUZlZQAAAAAAAAYAAAAsU3VwcGxpZWQgWlJPIHRva2VuIGZlZSBpcyBsZXNzIHRoYW4gcmVxdWlyZWQAAAASSW5zdWZmaWNpZW50WnJvRmVlAAAAAAAHAAAAK1RpbWVvdXQgZXhwaXJ5IGlzIGludmFsaWQgKGFscmVhZHkgZXhwaXJlZCkAAAAADUludmFsaWRFeHBpcnkAAAAAAAAIAAAAIEZlZSBhbW91bnQgaXMgaW52YWxpZCAobmVnYXRpdmUpAAAAEEludmFsaWRGZWVBbW91bnQAAAAJAAAAK0NvbXBvc2UgaW5kZXggZXhjZWVkcyBtYXhpbXVtIGFsbG93ZWQgdmFsdWUAAAAADEludmFsaWRJbmRleAAAAAoAAAAsTm9uY2UgaXMgaW52YWxpZCBmb3IgdGhlIHJlcXVlc3RlZCBvcGVyYXRpb24AAAAMSW52YWxpZE5vbmNlAAAACwAAADBQYXlsb2FkIGhhc2ggaXMgaW52YWxpZCAoZW1wdHkgaGFzaCBub3QgYWxsb3dlZCkAAAASSW52YWxpZFBheWxvYWRIYXNoAAAAAAAMAAAAQVJlY2VpdmUgbGlicmFyeSBpcyBub3QgdmFsaWQgZm9yIHRoZSByZWNlaXZlciBhbmQgc291cmNlIGVuZHBvaW50AAAAAAAAFUludmFsaWRSZWNlaXZlTGlicmFyeQAAAAAAAA0AAAAxT3BlcmF0aW9uIHJlcXVpcmVzIGEgbm9uLWRlZmF1bHQgKGN1c3RvbSkgbGlicmFyeQAAAAAAABFPbmx5Tm9uRGVmYXVsdExpYgAAAAAAAA4AAAAnTGlicmFyeSBtdXN0IHN1cHBvcnQgcmVjZWl2aW5nIG1lc3NhZ2VzAAAAAA5Pbmx5UmVjZWl2ZUxpYgAAAAAADwAAACxMaWJyYXJ5IG11c3QgYmUgcmVnaXN0ZXJlZCB3aXRoIHRoZSBlbmRwb2ludAAAABFPbmx5UmVnaXN0ZXJlZExpYgAAAAAAABAAAAAlTGlicmFyeSBtdXN0IHN1cHBvcnQgc2VuZGluZyBtZXNzYWdlcwAAAAAAAAtPbmx5U2VuZExpYgAAAAARAAAAOU1lc3NhZ2luZyBwYXRoIGNhbm5vdCBiZSBpbml0aWFsaXplZCBmb3IgdGhlIGdpdmVuIG9yaWdpbgAAAAAAABRQYXRoTm90SW5pdGlhbGl6YWJsZQAAABIAAAAvTWVzc2FnZSBjYW5ub3QgYmUgdmVyaWZpZWQgZm9yIHRoZSBnaXZlbiBvcmlnaW4AAAAAEVBhdGhOb3RWZXJpZmlhYmxlAAAAAAAAEwAAACtQYXlsb2FkIGhhc2ggZG9lcyBub3QgbWF0Y2ggdGhlIHN0b3JlZCBoYXNoAAAAABNQYXlsb2FkSGFzaE5vdEZvdW5kAAAAABQAAAAnTmV3IHZhbHVlIGlzIHRoZSBzYW1lIGFzIGV4aXN0aW5nIHZhbHVlAAAAAAlTYW1lVmFsdWUAAAAAAAAVAAAAL0NhbGxlciBpcyBub3QgYXV0aG9yaXplZCAobm90IE9BcHAgb3IgZGVsZWdhdGUpAAAAAAxVbmF1dGhvcml6ZWQAAAAWAAAAK0VuZHBvaW50IElEIGlzIG5vdCBzdXBwb3J0ZWQgYnkgdGhlIGxpYnJhcnkAAAAADlVuc3VwcG9ydGVkRWlkAAAAAAAXAAAAOVpSTyBmZWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gemVybyB3aGVuIHBheV9pbl96cm8gaXMgdHJ1ZQAAAAAAAApaZXJvWnJvRmVlAAAAAAAYAAAAHFpSTyB0b2tlbiBhZGRyZXNzIGlzIG5vdCBzZXQAAAAOWnJvVW5hdmFpbGFibGUAAAAAABkAAAABAAAALVBhcmFtZXRlcnMgZm9yIHNlbmRpbmcgYSBjcm9zcy1jaGFpbiBtZXNzYWdlLgAAAAAAAAAAAAAPTWVzc2FnaW5nUGFyYW1zAAAAAAUAAAArRGVzdGluYXRpb24gZW5kcG9pbnQgSUQgKGNoYWluIGlkZW50aWZpZXIpLgAAAAAHZHN0X2VpZAAAAAAEAAAAHFRoZSBtZXNzYWdlIHBheWxvYWQgdG8gc2VuZC4AAAAHbWVzc2FnZQAAAAAOAAAAIUVuY29kZWQgZXhlY3V0b3IgYW5kIERWTiBvcHRpb25zLgAAAAAAAAdvcHRpb25zAAAAAA4AAAA5V2hldGhlciB0byBwYXkgZmVlcyBpbiBaUk8gdG9rZW4gaW5zdGVhZCBvZiBuYXRpdmUgdG9rZW4uAAAAAAAACnBheV9pbl96cm8AAAAAAAEAAAA1UmVjZWl2ZXIgYWRkcmVzcyBvbiB0aGUgZGVzdGluYXRpb24gY2hhaW4gKDMyIGJ5dGVzKS4AAAAAAAAIcmVjZWl2ZXIAAAPuAAAAIAAAAAEAAABNU291cmNlIG1lc3NhZ2UgaW5mb3JtYXRpb24gaWRlbnRpZnlpbmcgd2hlcmUgYSBjcm9zcy1jaGFpbiBtZXNzYWdlIGNhbWUgZnJvbS4AAAAAAAAAAAAABk9yaWdpbgAAAAAAAwAAABdOb25jZSBmb3IgdGhpcyBwYXRod2F5LgAAAAAFbm9uY2UAAAAAAAAGAAAALlNlbmRlciBhZGRyZXNzIG9uIHRoZSBzb3VyY2UgY2hhaW4gKDMyIGJ5dGVzKS4AAAAAAAZzZW5kZXIAAAAAA+4AAAAgAAAAJlNvdXJjZSBlbmRwb2ludCBJRCAoY2hhaW4gaWRlbnRpZmllcikuAAAAAAAHc3JjX2VpZAAAAAAEAAAAAQAAAChGZWUgc3RydWN0dXJlIGZvciBjcm9zcy1jaGFpbiBtZXNzYWdpbmcuAAAAAAAAAAxNZXNzYWdpbmdGZWUAAAACAAAAH0ZlZSBwYWlkIGluIG5hdGl2ZSB0b2tlbiAoWExNKS4AAAAACm5hdGl2ZV9mZWUAAAAAAAsAAAAoRmVlIHBhaWQgaW4gWlJPIHRva2VuIChMYXllclplcm8gdG9rZW4pLgAAAAd6cm9fZmVlAAAAAAsAAAABAAAAQlJlY2VpcHQgcmV0dXJuZWQgYWZ0ZXIgc3VjY2Vzc2Z1bGx5IHNlbmRpbmcgYSBjcm9zcy1jaGFpbiBtZXNzYWdlLgAAAAAAAAAAABBNZXNzYWdpbmdSZWNlaXB0AAAAAwAAAClUaGUgZmVlcyBjaGFyZ2VkIGZvciBzZW5kaW5nIHRoZSBtZXNzYWdlLgAAAAAAAANmZWUAAAAH0AAAAAxNZXNzYWdpbmdGZWUAAAArR2xvYmFsbHkgdW5pcXVlIGlkZW50aWZpZXIgZm9yIHRoZSBtZXNzYWdlLgAAAAAEZ3VpZAAAA+4AAAAgAAAAJFRoZSBvdXRib3VuZCBub25jZSBmb3IgdGhpcyBwYXRod2F5LgAAAAVub25jZQAAAAAAAAYAAAACAAAAOFR5cGUgb2YgbWVzc2FnZSBsaWJyYXJ5IGluZGljYXRpbmcgc3VwcG9ydGVkIG9wZXJhdGlvbnMuAAAAAAAAAA5NZXNzYWdlTGliVHlwZQAAAAAAAwAAAAAAAAAfU3VwcG9ydHMgb25seSBzZW5kaW5nIG1lc3NhZ2VzLgAAAAAEU2VuZAAAAAAAAAAhU3VwcG9ydHMgb25seSByZWNlaXZpbmcgbWVzc2FnZXMuAAAAAAAAB1JlY2VpdmUAAAAAAAAAAC1TdXBwb3J0cyBib3RoIHNlbmRpbmcgYW5kIHJlY2VpdmluZyBtZXNzYWdlcy4AAAAAAAAOU2VuZEFuZFJlY2VpdmUAAAAAAAEAAAC3VmVyc2lvbiBpbmZvcm1hdGlvbiBmb3IgYSBtZXNzYWdlIGxpYnJhcnkuCgpOb3RlOiBgbWlub3JgIGFuZCBgZW5kcG9pbnRfdmVyc2lvbmAgdXNlIGB1MzJgIGluc3RlYWQgb2YgYHU4YCBiZWNhdXNlIFN0ZWxsYXIgZG9lcyBub3QKc3VwcG9ydCBgdThgIHR5cGVzIGluIGNvbnRyYWN0IGludGVyZmFjZSBmdW5jdGlvbnMuAAAAAAAAAAARTWVzc2FnZUxpYlZlcnNpb24AAAAAAAADAAAAM0VuZHBvaW50IHZlcnNpb24gKHNob3VsZCBub3QgZXhjZWVkIHU4OjpNQVggPSAyNTUpLgAAAAAQZW5kcG9pbnRfdmVyc2lvbgAAAAQAAAAVTWFqb3IgdmVyc2lvbiBudW1iZXIuAAAAAAAABW1ham9yAAAAAAAABgAAADdNaW5vciB2ZXJzaW9uIG51bWJlciAoc2hvdWxkIG5vdCBleGNlZWQgdTg6Ok1BWCA9IDI1NSkuAAAAAAVtaW5vcgAAAAAAAAQAAAABAAAANlRpbWVvdXQgY29uZmlndXJhdGlvbiBmb3IgcmVjZWl2ZSBsaWJyYXJ5IHRyYW5zaXRpb25zLgAAAAAAAAAAAAdUaW1lb3V0AAAAAAIAAAAzVW5peCB0aW1lc3RhbXAgaW4gc2Vjb25kcyB3aGVuIHRoZSB0aW1lb3V0IGV4cGlyZXMuAAAAAAZleHBpcnkAAAAAAAYAAABDVGhlIG9sZCBsaWJyYXJ5IGFkZHJlc3MgdGhhdCByZW1haW5zIHZhbGlkIGR1cmluZyB0aGUgZ3JhY2UgcGVyaW9kLgAAAAADbGliAAAAABMAAAABAAAANVBhcmFtZXRlcnMgZm9yIHNldHRpbmcgbWVzc2FnZSBsaWJyYXJ5IGNvbmZpZ3VyYXRpb24uAAAAAAAAAAAAAA5TZXRDb25maWdQYXJhbQAAAAAAAwAAAB9YRFItZW5jb2RlZCBjb25maWd1cmF0aW9uIGRhdGEuAAAAAAZjb25maWcAAAAAAA4AAAAwVGhlIHR5cGUgb2YgY29uZmlndXJhdGlvbiAoZS5nLiwgZXhlY3V0b3IsIFVMTikuAAAAC2NvbmZpZ190eXBlAAAAAAQAAAAnVGhlIGVuZHBvaW50IElEIHRoaXMgY29uZmlnIGFwcGxpZXMgdG8uAAAAAANlaWQAAAAABAAAAAEAAAAxUmVzb2x2ZWQgbGlicmFyeSBpbmZvcm1hdGlvbiB3aXRoIGRlZmF1bHQgc3RhdHVzLgAAAAAAAAAAAAAPUmVzb2x2ZWRMaWJyYXJ5AAAAAAIAAABEV2hldGhlciB0aGlzIGlzIHRoZSBkZWZhdWx0IGxpYnJhcnkgKHRydWUpIG9yIE9BcHAtc3BlY2lmaWMgKGZhbHNlKS4AAAAKaXNfZGVmYXVsdAAAAAAAAQAAAB1UaGUgcmVzb2x2ZWQgbGlicmFyeSBhZGRyZXNzLgAAAAAAAANsaWIAAAAAEwAAAAEAAABIT3V0Ym91bmQgcGFja2V0IGNvbnRhaW5pbmcgYWxsIGluZm9ybWF0aW9uIGZvciBjcm9zcy1jaGFpbiB0cmFuc21pc3Npb24uAAAAAAAAAA5PdXRib3VuZFBhY2tldAAAAAAABwAAABhEZXN0aW5hdGlvbiBlbmRwb2ludCBJRC4AAAAHZHN0X2VpZAAAAAAEAAAALEdsb2JhbGx5IHVuaXF1ZSBpZGVudGlmaWVyIGZvciB0aGlzIG1lc3NhZ2UuAAAABGd1aWQAAAPuAAAAIAAAABRUaGUgbWVzc2FnZSBwYXlsb2FkLgAAAAdtZXNzYWdlAAAAAA4AAAAgT3V0Ym91bmQgbm9uY2UgZm9yIHRoaXMgcGF0aHdheS4AAAAFbm9uY2UAAAAAAAAGAAAAMVJlY2VpdmVyIGFkZHJlc3Mgb24gZGVzdGluYXRpb24gY2hhaW4gKDMyIGJ5dGVzKS4AAAAAAAAIcmVjZWl2ZXIAAAPuAAAAIAAAAB9TZW5kZXIgYWRkcmVzcyBvbiBzb3VyY2UgY2hhaW4uAAAAAAZzZW5kZXIAAAAAABMAAAATU291cmNlIGVuZHBvaW50IElELgAAAAAHc3JjX2VpZAAAAAAEAAAAAQAAACtBIGZlZSByZWNpcGllbnQgd2l0aCB0aGUgYW1vdW50IHRvIGJlIHBhaWQuAAAAAAAAAAAMRmVlUmVjaXBpZW50AAAAAgAAABVBbW91bnQgb2YgZmVlIHRv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AAAACWluc3BlY3RvcgAAAAAAA+gAAAATAAAAAAAAAAIAAAACAAAAAAAAAAAAAAAKT0ZUU3RvcmFnZQAAAAAAAwAAAAAAAAAAAAAADERlY2ltYWxzRGlmZgAAAAAAAAAAAAAABVRva2VuAAAAAAAAAAAAAAAAAAAMTXNnSW5zcGVjdG9yAAAABAAAABNPRlRFcnJvcjogMzAwMC0zMDk5AAAAAAAAAAAIT0ZURXJyb3IAAAAGAAAAAAAAAA5JbnZhbGlkQWRkcmVzcwAAAAALuAAAAAAAAAANSW52YWxpZEFtb3VudAAAAAAAC7kAAAAAAAAAFEludmFsaWRMb2NhbERlY2ltYWxzAAALugAAAAAAAAAOTm90SW5pdGlhbGl6ZWQAAAAAC7sAAAAAAAAACE92ZXJmbG93AAALvAAAAAAAAAAQU2xpcHBhZ2VFeGNlZWRlZAAAC70AAAABAAAALVBhcmFtZXRlcnMgZm9yIHNlbmRpbmcgT0ZUIHRva2VucyBjcm9zcy1jaGFpbgAAAAAAAAAAAAAJU2VuZFBhcmFtAAAAAAAABwAAACRUaGUgYW1vdW50IHRvIHNlbmQgaW4gbG9jYWwgZGVjaW1hbHMAAAAJYW1vdW50X2xkAAAAAAAACwAAADhDb21wb3NlIG1lc3NhZ2UgdG8gZXhlY3V0ZSBvbiB0aGUgZGVzdGluYXRpb24gKE9wdGlvbmFsKQAAAAtjb21wb3NlX21zZwAAAAAOAAAAG1RoZSBkZXN0aW5hdGlvbiBlbmRwb2ludCBJRAAAAAAHZHN0X2VpZAAAAAAEAAAAN0FkZGl0aW9uYWwgb3B0aW9ucyBmb3IgdGhlIExheWVyWmVybyBtZXNzYWdlIChPcHRpb25hbCkAAAAADWV4dHJhX29wdGlvbnMAAAAAAAAOAAAARVRoZSBtaW5pbXVtIGFtb3VudCB0byByZWNlaXZlIGluIGxvY2FsIGRlY2ltYWxzIChzbGlwcGFnZSBwcm90ZWN0aW9uKQAAAAAAAA1taW5fYW1vdW50X2xkAAAAAAAACwAAACpPRlQgY29tbWFuZCBmb3IgY3VzdG9tIGJlaGF2aW9yIChPcHRpb25hbCkAAAAAAAdvZnRfY21kAAAAAA4AAAA5VGhlIHJlY2lwaWVudCBhZGRyZXNzIG9uIHRoZSBkZXN0aW5hdGlvbiBjaGFpbiAoMzIgYnl0ZXMpAAAAAAAAAnRvAAAAAAPuAAAAIAAAAAEAAAAiVHJhbnNmZXIgbGltaXRzIGZvciBPRlQgb3BlcmF0aW9ucwAAAAAAAAAAAAhPRlRMaW1pdAAAAAIAAAAsVGhlIG1heGltdW0gYW1vdW50IHRvIHNlbmQgaW4gbG9jYWwgZGVjaW1hbHMAAAANbWF4X2Ftb3VudF9sZAAAAAAAAAsAAAAsVGhlIG1pbmltdW0gYW1vdW50IHRvIHNlbmQgaW4gbG9jYWwgZGVjaW1hbHMAAAANbWluX2Ftb3VudF9sZAAAAAAAAAsAAAABAAAAP1JlY2VpcHQgY29udGFpbmluZyBhbW91bnRzIHNlbnQgYW5kIHJlY2VpdmVkIGluIGFuIE9GVCB0cmFuc2ZlcgAAAAAAAAAACk9GVFJlY2VpcHQAAAAAAAIAAAAzVGhlIGFtb3VudCByZWNlaXZlZCBpbiBsb2NhbCBkZWNpbWFscyBvbiB0aGUgcmVtb3RlAAAAABJhbW91bnRfcmVjZWl2ZWRfbGQAAAAAAAsAAAAhVGhlIGFtb3VudCBzZW50IGluIGxvY2FsIGRlY2ltYWxzAAAAAAAADmFtb3VudF9zZW50X2xkAAAAAAALAAAAAQAAAC5EZXRhaWxzIGFib3V0IGZlZXMgY2hhcmdlZCBpbiBhbiBPRlQgb3BlcmF0aW9uAAAAAAAAAAAADE9GVEZlZURldGFpbAAAAAIAAAAaVGhlIGRlc2NyaXB0aW9uIG9mIHRoZSBmZWUAAAAAAAtkZXNjcmlwdGlvbgAAAAAOAAAAf1RoZSBhbW91bnQgb2YgdGhlIGZlZSBpbiBsb2NhbCBkZWNpbWFscy4gUG9zaXRpdmUgdmFsdWVzIHJlcHJlc2VudCBmZWVzIGNoYXJnZWQsCndoaWxlIG5lZ2F0aXZlIHZhbHVlcyByZXByZXNlbnQgcmV3YXJkcyBnaXZlbi4AAAAADWZlZV9hbW91bnRfbGQAAAAAAAALAAAABAAAABxCdWZmZXJSZWFkZXJFcnJvcjogMTAwMC0xMDA5AAAAAAAAABFCdWZmZXJSZWFkZXJFcnJvcgAAAAAAAAIAAAAAAAAADUludmFsaWRMZW5ndGgAAAAAAAPoAAAAAAAAABVJbnZhbGlkQWRkcmVzc1BheWxvYWQAAAAAAAPpAAAABAAAABxCdWZmZXJXcml0ZXJFcnJvcjogMTAxMC0xMDE5AAAAAAAAABFCdWZmZXJXcml0ZXJFcnJvcgAAAAAAAAEAAAAAAAAAFUludmFsaWRBZGRyZXNzUGF5bG9hZAAAAAAAA/IAAAAEAAAAH1R0bENvbmZpZ3VyYWJsZUVycm9yOiAxMDIwLTEwMjkAAAAAAAAAABRUdGxDb25maWd1cmFibGVFcnJvcgAAAAMAAAAAAAAAEEludmFsaWRUdGxDb25maWcAAAP8AAAAAAAAAA9UdGxDb25maWdGcm96ZW4AAAAD/QAAAAAAAAAWVHRsQ29uZmlnQWxyZWFkeUZyb3plbgAAAAAD/gAAAAQAAAAXT3duYWJsZUVycm9yOiAxMDMwLTEwMzkAAAAAAAAAAAxPd25hYmxlRXJyb3IAAAAHAAAAAAAAABFJbnZhbGlkQXV0aG9yaXplcgAAAAAABAYAAAAAAAAAE0ludmFsaWRQZW5kaW5nT3duZXIAAAAEBwAAAAAAAAAKSW52YWxpZFR0bAAAAAAECAAAAAAAAAARTm9QZW5kaW5nVHJhbnNmZXIAAAAAAAQJAAAAAAAAAA9Pd25lckFscmVhZHlTZXQAAAAECgAAAAAAAAALT3duZXJOb3RTZXQAAAAECwAAAAAAAAASVHJhbnNmZXJJblByb2dyZXNzAAAAAAQMAAAABAAAABhCeXRlc0V4dEVycm9yOiAxMDQwLTEwNDkAAAAAAAAADUJ5dGVzRXh0RXJyb3IAAAAAAAABAAAAAAAAAA5MZW5ndGhNaXNtYXRjaAAAAAAEEAAAAAQAAAAbVXBncmFkZWFibGVFcnJvcjogMTA1MC0xMDU5AAAAAAAAAAAQVXBncmFkZWFibGVFcnJvcgAAAAIAAAAAAAAAFEludmFsaWRNaWdyYXRpb25EYXRhAAAEGgAAAAAAAAATTWlncmF0aW9uTm90QWxsb3dlZAAAAAQbAAAABAAAABhNdWx0aVNpZ0Vycm9yOiAxMDYwLTEwNjkAAAAAAAAADU11bHRpU2lnRXJyb3IAAAAAAAAJAAAAAAAAABJBbHJlYWR5SW5pdGlhbGl6ZWQAAAAABCQAAAAAAAAAEUludmFsaWRBdXRob3JpemVyAAAAAAAEJQAAAAAAAAANSW52YWxpZFNpZ25lcgAAAAAABCYAAAAAAAAADlNpZ25hdHVyZUVycm9yAAAAAAQnAAAAAAAAABNTaWduZXJBbHJlYWR5RXhpc3RzAAAABCgAAAAAAAAADlNpZ25lck5vdEZvdW5kAAAAAAQpAAAAAAAAAB1Ub3RhbFNpZ25lcnNMZXNzVGhhblRocmVzaG9sZAAAAAAABCoAAAAAAAAAD1Vuc29ydGVkU2lnbmVycwAAAAQrAAAAAAAAAA1aZXJvVGhyZXNob2xkAAAAAAAELAAAAAUAAAAwRXZlbnQgZW1pdHRlZCB3aGVuIGEgc2lnbmVyIGlzIGFkZGVkIG9yIHJlbW92ZWQuAAAAAAAAAAlTaWduZXJTZXQAAAAAAAABAAAACnNpZ25lcl9zZXQAAAAAAAIAAAAAAAAABnNpZ25lcgAAAAAD7gAAABQAAAABAAAAAAAAAAZhY3RpdmUAAAAAAAEAAAAAAAAAAgAAAAUAAAA2RXZlbnQgZW1pdHRlZCB3aGVuIHRoZSBzaWduYXR1cmUgdGhyZXNob2xkIGlzIGNoYW5nZWQuAAAAAAAAAAAADFRocmVzaG9sZFNldAAAAAEAAAANdGhyZXNob2xkX3NldAAAAAAAAAEAAAAAAAAACXRocmVzaG9sZAAAAAAAAAQAAAAAAAAAAgAAAAIAAAAAAAAAAAAAAA9NdWx0aVNpZ1N0b3JhZ2UAAAAAAgAAAAAAAAAAAAAAB1NpZ25lcnMAAAAAAAAAAAAAAAAJVGhyZXNob2xkAAAAAAAABQAAAFdFdmVudCBlbWl0dGVkIHdoZW4gb3duZXJzaGlwIGlzIHRyYW5zZmVycmVkIChib3RoIHNpbmdsZS1zdGVwIGFuZCB0d28tc3RlcCBjb21wbGV0aW9uKS4AAAAAAAAAABRPd25lcnNoaXBUcmFuc2ZlcnJlZAAAAAEAAAAVb3duZXJzaGlwX3RyYW5zZmVycmVkAAAAAAAAAgAAAAAAAAAJb2xkX293bmVyAAAAAAAAEwAAAAAAAAAAAAAACW5ld19vd25lcgAAAAAAABMAAAAAAAAAAgAAAAUAAAA7RXZlbnQgZW1pdHRlZCB3aGVuIGEgMi1zdGVwIG93bmVyc2hpcCB0cmFuc2ZlciBpcyBwcm9wb3NlZC4AAAAAAAAAABVPd25lcnNoaXBUcmFuc2ZlcnJpbmcAAAAAAAABAAAAFm93bmVyc2hpcF90cmFuc2ZlcnJpbmcAAAAAAAMAAAAAAAAACW9sZF9vd25lcgAAAAAAABMAAAAAAAAAAAAAAAluZXdfb3duZXIAAAAAAAATAAAAAAAAAAAAAAADdHRsAAAAAAQAAAAAAAAAAgAAAAUAAAA8RXZlbnQgZW1pdHRlZCB3aGVuIGEgMi1zdGVwIG93bmVyc2hpcCB0cmFuc2ZlciBpcyBjYW5jZWxsZWQuAAAAAAAAABpPd25lcnNoaXBUcmFuc2ZlckNhbmNlbGxlZAAAAAAAAQAAABxvd25lcnNoaXBfdHJhbnNmZXJfY2FuY2VsbGVkAAAAAgAAAAAAAAAFb3duZXIAAAAAAAATAAAAAAAAAAAAAAAXY2FuY2VsbGVkX3BlbmRpbmdfb3duZXIAAAAAEwAAAAAAAAACAAAABQAAACpFdmVudCBlbWl0dGVkIHdoZW4gb3duZXJzaGlwIGlzIHJlbm91bmNlZC4AAAAAAAAAAAAST3duZXJzaGlwUmVub3VuY2VkAAAAAAABAAAAE293bmVyc2hpcF9yZW5vdW5jZWQAAAAAAQAAAAAAAAAJb2xkX293bmVyAAAAAAAAEwAAAAAAAAACAAAAAgAAAAAAAAAAAAAADk93bmFibGVTdG9yYWdlAAAAAAACAAAAAAAAAAAAAAAFT3duZXIAAAAAAAAAAAAAAAAAAAxQZW5kaW5nT3duZXIAAAABAAAASVRUTCBjb25maWd1cmF0aW9uOiB0aHJlc2hvbGQgKHdoZW4gdG8gZXh0ZW5kKSBhbmQgZXh0ZW5kX3RvICh0YXJnZXQgVFRMKS4AAAAAAAAAAAAACVR0bENvbmZpZwAAAAAAAAIAAAAoVGFyZ2V0IFRUTCBhZnRlciBleHRlbnNpb24gKGluIGxlZGdlcnMpLgAAAAlleHRlbmRfdG8AAAAAAAAEAAAAM1RUTCB0aHJlc2hvbGQgdGhhdCB0cmlnZ2VycyBleHRlbnNpb24gKGluIGxlZGdlcnMpLgAAAAAJdGhyZXNob2xkAAAAAAAABAAAAAUAAAAnRXZlbnQgZW1pdHRlZCB3aGVuIFRUTCBjb25maWdzIGFyZSBzZXQuAAAAAAAAAAANVHRsQ29uZmlnc1NldAAAAAAAAAEAAAAPdHRsX2NvbmZpZ3Nfc2V0AAAAAAIAAAAAAAAACGluc3RhbmNlAAAD6AAAB9AAAAAJVHRsQ29uZmlnAAAAAAAAAAAAAAAAAAAKcGVyc2lzdGVudAAAAAAD6AAAB9AAAAAJVHRsQ29uZmlnAAAAAAAAAAAAAAIAAAAFAAAAKkV2ZW50IGVtaXR0ZWQgd2hlbiBUVEwgY29uZmlncyBhcmUgZnJvemVuLgAAAAAAAAAAABBUdGxDb25maWdzRnJvemVuAAAAAQAAABJ0dGxfY29uZmlnc19mcm96ZW4AAAAAAAAAAAACAAAAAgAAAAAAAAAAAAAAEFR0bENvbmZpZ1N0b3JhZ2UAAAADAAAAAAAAAAAAAAAGRnJvemVuAAAAAAAAAAAAAAAAAAhJbnN0YW5jZQAAAAAAAAAAAAAAClBlcnNpc3RlbnQAAAAAAAIAAAAAAAAAAAAAABJVcGdyYWRlYWJsZVN0b3JhZ2UAAAAAAAEAAAAAAAAAAAAAAAlNaWdyYXRpbmcAAAAAiwEOY29udHJhY3RtZXRhdjAAAAAAAAAABmJpbnZlcgAAAAAABTAuMC4xAAAAAAAAAAAAAAVyc3ZlcgAAAAAAAAYxLjkwLjAAAAAAAAAAAAAIcnNzZGt2ZXIAAAAvMjUuMS4wIzg2YzUwYTFlYTRmODdiNDBhZGQzMDY0ZmY5ZGY5NWM3NTUzNTY1YzUAAB4RY29udHJhY3RlbnZtZXRhdjAAAAAAAAAAGQAAAAAAUw5jb250cmFjdG1ldGF2MAAAAAAAAAAGY2xpdmVyAAAAAAAvMjUuMC4wI2E2NDkyNWU5MzkxYzNkM2IzZWY4ZTUzZGM2MGMyM2RiOWU2YTgyZTQA";
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 = "ce6445fdd02b7265220c941427d212a57b696bd4c044f5ec41463ec1f1f2fea6";
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 declare const RedistributionError: {
23
+ /**
24
+ * Account is not blacklisted (required for redistribution)
25
+ */
26
+ 100: {
27
+ message: string;
28
+ };
29
+ /**
30
+ * Redistribution is not enabled
31
+ */
32
+ 101: {
33
+ message: string;
34
+ };
35
+ };
36
+ export type RedistributionStorage = {
37
+ tag: "RedistributionEnabled";
38
+ values: void;
39
+ };
40
+ /**
41
+ * Limit configuration for rate limiting.
42
+ */
43
+ export interface LimitConfig {
44
+ /**
45
+ * Max amount for the rate limit
46
+ */
47
+ limit_capacity: i128;
48
+ /**
49
+ * Amount to add to limit each second up to the limitCapacity.
50
+ * A value of 0 means rate limiting is disabled (unlimited minting allowed).
51
+ */
52
+ refill_per_second: i128;
53
+ }
54
+ /**
55
+ * Rate limit state (the runtime state that persists across config updates).
56
+ */
57
+ export interface RateLimitState {
58
+ /**
59
+ * Timestamp of last refill
60
+ */
61
+ last_refill_time: u64;
62
+ /**
63
+ * Remaining amount for the time period
64
+ */
65
+ remaining_amount: i128;
66
+ }
67
+ /**
68
+ * Supply control errors: 3250-3299
69
+ */
70
+ export declare const SupplyControlError: {
71
+ /**
72
+ * Entry already exists (supply controller, manager, or whitelist address)
73
+ */
74
+ 200: {
75
+ message: string;
76
+ };
77
+ /**
78
+ * Cannot burn from this address
79
+ */
80
+ 201: {
81
+ message: string;
82
+ };
83
+ /**
84
+ * Cannot mint to this address (not in whitelist)
85
+ */
86
+ 202: {
87
+ message: string;
88
+ };
89
+ /**
90
+ * Invalid amount
91
+ */
92
+ 203: {
93
+ message: string;
94
+ };
95
+ /**
96
+ * Invalid configuration
97
+ */
98
+ 204: {
99
+ message: string;
100
+ };
101
+ /**
102
+ * Entry not found (supply controller, manager, or whitelist address)
103
+ */
104
+ 205: {
105
+ message: string;
106
+ };
107
+ /**
108
+ * Timestamp is older than the last refill time
109
+ */
110
+ 206: {
111
+ message: string;
112
+ };
113
+ /**
114
+ * Rate limit exceeded
115
+ */
116
+ 207: {
117
+ message: string;
118
+ };
119
+ /**
120
+ * Value is already set to the same state
121
+ */
122
+ 208: {
123
+ message: string;
124
+ };
125
+ /**
126
+ * Caller is not authorized (not a supply controller or manager)
127
+ */
128
+ 209: {
129
+ message: string;
130
+ };
131
+ };
132
+ /**
133
+ * Supply controller configuration (the configurable parameters).
134
+ */
135
+ export interface SupplyControllerConfig {
136
+ /**
137
+ * If true, allows the supply controller to mint to and burn from any address.
138
+ * When false, the controller can only mint to addresses in its whitelist.
139
+ */
140
+ allow_any_mint_burn: boolean;
141
+ /**
142
+ * Limit configuration
143
+ */
144
+ limit_config: LimitConfig;
145
+ /**
146
+ * Addresses that this supply controller is allowed to mint to (when `allow_any_mint_burn` is false).
147
+ */
148
+ whitelist_addresses: Array<string>;
149
+ }
150
+ /**
151
+ * Supply controller with both config and state nested together.
152
+ * Stored per-controller for O(1) access on every mint/burn.
153
+ */
154
+ export interface SupplyControllerEntry {
155
+ /**
156
+ * Configuration (can be updated independently)
157
+ */
158
+ config: SupplyControllerConfig;
159
+ /**
160
+ * Rate limit state (preserved across config updates)
161
+ */
162
+ state: RateLimitState;
163
+ }
164
+ export type SupplyControlStorage = {
165
+ tag: "SupplyControlEnabled";
166
+ values: void;
167
+ } | {
168
+ tag: "SupplyControllerEntry";
169
+ values: readonly [string];
170
+ } | {
171
+ tag: "SupplyControllers";
172
+ values: void;
173
+ } | {
174
+ tag: "SupplyControllerManagers";
175
+ values: void;
176
+ };
177
+ /**
178
+ * General SacManagerError: 3220-3249
179
+ */
180
+ export declare const SacManagerError: {
181
+ /**
182
+ * OFT address has not been set yet
183
+ */
184
+ 1: {
185
+ message: string;
186
+ };
187
+ /**
188
+ * The values are the same
189
+ */
190
+ 2: {
191
+ message: string;
192
+ };
193
+ /**
194
+ * Caller is not authorized for this operation
195
+ */
196
+ 3: {
197
+ message: string;
198
+ };
199
+ };
200
+ export type SacManagerStorage = {
201
+ tag: "SacToken";
202
+ values: void;
203
+ } | {
204
+ tag: "OftAddress";
205
+ values: void;
206
+ };
207
+ export declare const EndpointError: {
208
+ /**
209
+ * Library is already registered with the endpoint
210
+ */
211
+ 1: {
212
+ message: string;
213
+ };
214
+ /**
215
+ * Compose message already exists for this GUID and index
216
+ */
217
+ 2: {
218
+ message: string;
219
+ };
220
+ /**
221
+ * Compose message not found for the given GUID and index
222
+ */
223
+ 3: {
224
+ message: string;
225
+ };
226
+ /**
227
+ * Default receive library is not set for the source endpoint
228
+ */
229
+ 4: {
230
+ message: string;
231
+ };
232
+ /**
233
+ * Default send library is not set for the destination endpoint
234
+ */
235
+ 5: {
236
+ message: string;
237
+ };
238
+ /**
239
+ * Supplied native token fee is less than required
240
+ */
241
+ 6: {
242
+ message: string;
243
+ };
244
+ /**
245
+ * Supplied ZRO token fee is less than required
246
+ */
247
+ 7: {
248
+ message: string;
249
+ };
250
+ /**
251
+ * Timeout expiry is invalid (already expired)
252
+ */
253
+ 8: {
254
+ message: string;
255
+ };
256
+ /**
257
+ * Fee amount is invalid (negative)
258
+ */
259
+ 9: {
260
+ message: string;
261
+ };
262
+ /**
263
+ * Compose index exceeds maximum allowed value
264
+ */
265
+ 10: {
266
+ message: string;
267
+ };
268
+ /**
269
+ * Nonce is invalid for the requested operation
270
+ */
271
+ 11: {
272
+ message: string;
273
+ };
274
+ /**
275
+ * Payload hash is invalid (empty hash not allowed)
276
+ */
277
+ 12: {
278
+ message: string;
279
+ };
280
+ /**
281
+ * Receive library is not valid for the receiver and source endpoint
282
+ */
283
+ 13: {
284
+ message: string;
285
+ };
286
+ /**
287
+ * Operation requires a non-default (custom) library
288
+ */
289
+ 14: {
290
+ message: string;
291
+ };
292
+ /**
293
+ * Library must support receiving messages
294
+ */
295
+ 15: {
296
+ message: string;
297
+ };
298
+ /**
299
+ * Library must be registered with the endpoint
300
+ */
301
+ 16: {
302
+ message: string;
303
+ };
304
+ /**
305
+ * Library must support sending messages
306
+ */
307
+ 17: {
308
+ message: string;
309
+ };
310
+ /**
311
+ * Messaging path cannot be initialized for the given origin
312
+ */
313
+ 18: {
314
+ message: string;
315
+ };
316
+ /**
317
+ * Message cannot be verified for the given origin
318
+ */
319
+ 19: {
320
+ message: string;
321
+ };
322
+ /**
323
+ * Payload hash does not match the stored hash
324
+ */
325
+ 20: {
326
+ message: string;
327
+ };
328
+ /**
329
+ * New value is the same as existing value
330
+ */
331
+ 21: {
332
+ message: string;
333
+ };
334
+ /**
335
+ * Caller is not authorized (not OApp or delegate)
336
+ */
337
+ 22: {
338
+ message: string;
339
+ };
340
+ /**
341
+ * Endpoint ID is not supported by the library
342
+ */
343
+ 23: {
344
+ message: string;
345
+ };
346
+ /**
347
+ * ZRO fee must be greater than zero when pay_in_zro is true
348
+ */
349
+ 24: {
350
+ message: string;
351
+ };
352
+ /**
353
+ * ZRO token address is not set
354
+ */
355
+ 25: {
356
+ message: string;
357
+ };
358
+ };
359
+ /**
360
+ * Parameters for sending a cross-chain message.
361
+ */
362
+ export interface MessagingParams {
363
+ /**
364
+ * Destination endpoint ID (chain identifier).
365
+ */
366
+ dst_eid: u32;
367
+ /**
368
+ * The message payload to send.
369
+ */
370
+ message: Buffer;
371
+ /**
372
+ * Encoded executor and DVN options.
373
+ */
374
+ options: Buffer;
375
+ /**
376
+ * Whether to pay fees in ZRO token instead of native token.
377
+ */
378
+ pay_in_zro: boolean;
379
+ /**
380
+ * Receiver address on the destination chain (32 bytes).
381
+ */
382
+ receiver: Buffer;
383
+ }
384
+ /**
385
+ * Source message information identifying where a cross-chain message came from.
386
+ */
387
+ export interface Origin {
388
+ /**
389
+ * Nonce for this pathway.
390
+ */
391
+ nonce: u64;
392
+ /**
393
+ * Sender address on the source chain (32 bytes).
394
+ */
395
+ sender: Buffer;
396
+ /**
397
+ * Source endpoint ID (chain identifier).
398
+ */
399
+ src_eid: u32;
400
+ }
401
+ /**
402
+ * Fee structure for cross-chain messaging.
403
+ */
404
+ export interface MessagingFee {
405
+ /**
406
+ * Fee paid in native token (XLM).
407
+ */
408
+ native_fee: i128;
409
+ /**
410
+ * Fee paid in ZRO token (LayerZero token).
411
+ */
412
+ zro_fee: i128;
413
+ }
414
+ /**
415
+ * Receipt returned after successfully sending a cross-chain message.
416
+ */
417
+ export interface MessagingReceipt {
418
+ /**
419
+ * The fees charged for sending the message.
420
+ */
421
+ fee: MessagingFee;
422
+ /**
423
+ * Globally unique identifier for the message.
424
+ */
425
+ guid: Buffer;
426
+ /**
427
+ * The outbound nonce for this pathway.
428
+ */
429
+ nonce: u64;
430
+ }
431
+ /**
432
+ * Type of message library indicating supported operations.
433
+ */
434
+ export type MessageLibType = {
435
+ tag: "Send";
436
+ values: void;
437
+ } | {
438
+ tag: "Receive";
439
+ values: void;
440
+ } | {
441
+ tag: "SendAndReceive";
442
+ values: void;
443
+ };
444
+ /**
445
+ * Version information for a message library.
446
+ *
447
+ * Note: `minor` and `endpoint_version` use `u32` instead of `u8` because Stellar does not
448
+ * support `u8` types in contract interface functions.
449
+ */
450
+ export interface MessageLibVersion {
451
+ /**
452
+ * Endpoint version (should not exceed u8::MAX = 255).
453
+ */
454
+ endpoint_version: u32;
455
+ /**
456
+ * Major version number.
457
+ */
458
+ major: u64;
459
+ /**
460
+ * Minor version number (should not exceed u8::MAX = 255).
461
+ */
462
+ minor: u32;
463
+ }
464
+ /**
465
+ * Timeout configuration for receive library transitions.
466
+ */
467
+ export interface Timeout {
468
+ /**
469
+ * Unix timestamp in seconds when the timeout expires.
470
+ */
471
+ expiry: u64;
472
+ /**
473
+ * The old library address that remains valid during the grace period.
474
+ */
475
+ lib: string;
476
+ }
477
+ /**
478
+ * Parameters for setting message library configuration.
479
+ */
480
+ export interface SetConfigParam {
481
+ /**
482
+ * XDR-encoded configuration data.
483
+ */
484
+ config: Buffer;
485
+ /**
486
+ * The type of configuration (e.g., executor, ULN).
487
+ */
488
+ config_type: u32;
489
+ /**
490
+ * The endpoint ID this config applies to.
491
+ */
492
+ eid: u32;
493
+ }
494
+ /**
495
+ * Resolved library information with default status.
496
+ */
497
+ export interface ResolvedLibrary {
498
+ /**
499
+ * Whether this is the default library (true) or OApp-specific (false).
500
+ */
501
+ is_default: boolean;
502
+ /**
503
+ * The resolved library address.
504
+ */
505
+ lib: string;
506
+ }
507
+ /**
508
+ * Outbound packet containing all information for cross-chain transmission.
509
+ */
510
+ export interface OutboundPacket {
511
+ /**
512
+ * Destination endpoint ID.
513
+ */
514
+ dst_eid: u32;
515
+ /**
516
+ * Globally unique identifier for this message.
517
+ */
518
+ guid: Buffer;
519
+ /**
520
+ * The message payload.
521
+ */
522
+ message: Buffer;
523
+ /**
524
+ * Outbound nonce for this pathway.
525
+ */
526
+ nonce: u64;
527
+ /**
528
+ * Receiver address on destination chain (32 bytes).
529
+ */
530
+ receiver: Buffer;
531
+ /**
532
+ * Sender address on source chain.
533
+ */
534
+ sender: string;
535
+ /**
536
+ * Source endpoint ID.
537
+ */
538
+ src_eid: u32;
539
+ }
540
+ /**
541
+ * A fee recipient with the amount to be paid.
542
+ */
543
+ export interface FeeRecipient {
544
+ /**
545
+ * Amount of fee to pay.
546
+ */
547
+ amount: i128;
548
+ /**
549
+ * The address to send the fee to.
550
+ */
551
+ to: string;
552
+ }
553
+ /**
554
+ * Result of send operation containing fees and encoded packet.
555
+ */
556
+ export interface FeesAndPacket {
557
+ /**
558
+ * The encoded packet ready for transmission.
559
+ */
560
+ encoded_packet: Buffer;
561
+ /**
562
+ * List of native token fee recipients (executor, DVNs, treasury).
563
+ */
564
+ native_fee_recipients: Array<FeeRecipient>;
565
+ /**
566
+ * List of ZRO token fee recipients (treasury).
567
+ */
568
+ zro_fee_recipients: Array<FeeRecipient>;
569
+ }
570
+ export type OAppCoreStorage = {
571
+ tag: "Endpoint";
572
+ values: void;
573
+ } | {
574
+ tag: "Peer";
575
+ values: readonly [u32];
576
+ };
577
+ export interface EnforcedOptionParam {
578
+ eid: u32;
579
+ msg_type: u32;
580
+ options: Option<Buffer>;
581
+ }
582
+ export type OAppOptionsType3Storage = {
583
+ tag: "EnforcedOptions";
584
+ values: readonly [u32, u32];
585
+ };
586
+ /**
587
+ * OAppError: 2000-2099
588
+ */
589
+ export declare const OAppError: {
590
+ 2000: {
591
+ message: string;
592
+ };
593
+ 2001: {
594
+ message: string;
595
+ };
596
+ 2002: {
597
+ message: string;
598
+ };
599
+ 2003: {
600
+ message: string;
601
+ };
602
+ };
603
+ export type OFTFeeStorage = {
604
+ tag: "DefaultFeeBps";
605
+ values: void;
606
+ } | {
607
+ tag: "FeeBps";
608
+ values: readonly [u32];
609
+ } | {
610
+ tag: "FeeDepositAddress";
611
+ values: void;
612
+ };
613
+ export declare const OFTFeeError: {
614
+ 3100: {
615
+ message: string;
616
+ };
617
+ 3101: {
618
+ message: string;
619
+ };
620
+ 3102: {
621
+ message: string;
622
+ };
623
+ };
624
+ export type OFTPausableStorage = {
625
+ tag: "Paused";
626
+ values: void;
627
+ };
628
+ export declare const OFTPausableError: {
629
+ 3110: {
630
+ message: string;
631
+ };
632
+ 3111: {
633
+ message: string;
634
+ };
635
+ };
636
+ export type Direction = {
637
+ tag: "Inbound";
638
+ values: void;
639
+ } | {
640
+ tag: "Outbound";
641
+ values: void;
642
+ };
643
+ export type Mode = {
644
+ tag: "Net";
645
+ values: void;
646
+ } | {
647
+ tag: "Gross";
648
+ values: void;
649
+ };
650
+ /**
651
+ * Configuration for rate limiting, used as input parameter.
652
+ */
653
+ export interface RateLimitConfig {
654
+ limit: i128;
655
+ mode: Mode;
656
+ window_seconds: u64;
657
+ }
658
+ export declare const RateLimitError: {
659
+ 3120: {
660
+ message: string;
661
+ };
662
+ 3121: {
663
+ message: string;
664
+ };
665
+ 3122: {
666
+ message: string;
667
+ };
668
+ 3123: {
669
+ message: string;
670
+ };
671
+ 3124: {
672
+ message: string;
673
+ };
674
+ };
675
+ /**
676
+ * The OFT operation type.
677
+ */
678
+ export type OftType = {
679
+ tag: "LockUnlock";
680
+ values: void;
681
+ } | {
682
+ tag: "MintBurn";
683
+ values: readonly [string];
684
+ };
685
+ export type OFTStorage = {
686
+ tag: "DecimalsDiff";
687
+ values: void;
688
+ } | {
689
+ tag: "Token";
690
+ values: void;
691
+ } | {
692
+ tag: "MsgInspector";
693
+ values: void;
694
+ };
695
+ /**
696
+ * OFTError: 3000-3099
697
+ */
698
+ export declare const OFTError: {
699
+ 3000: {
700
+ message: string;
701
+ };
702
+ 3001: {
703
+ message: string;
704
+ };
705
+ 3002: {
706
+ message: string;
707
+ };
708
+ 3003: {
709
+ message: string;
710
+ };
711
+ 3004: {
712
+ message: string;
713
+ };
714
+ 3005: {
715
+ message: string;
716
+ };
717
+ };
718
+ /**
719
+ * Parameters for sending OFT tokens cross-chain
720
+ */
721
+ export interface SendParam {
722
+ /**
723
+ * The amount to send in local decimals
724
+ */
725
+ amount_ld: i128;
726
+ /**
727
+ * Compose message to execute on the destination (Optional)
728
+ */
729
+ compose_msg: Buffer;
730
+ /**
731
+ * The destination endpoint ID
732
+ */
733
+ dst_eid: u32;
734
+ /**
735
+ * Additional options for the LayerZero message (Optional)
736
+ */
737
+ extra_options: Buffer;
738
+ /**
739
+ * The minimum amount to receive in local decimals (slippage protection)
740
+ */
741
+ min_amount_ld: i128;
742
+ /**
743
+ * OFT command for custom behavior (Optional)
744
+ */
745
+ oft_cmd: Buffer;
746
+ /**
747
+ * The recipient address on the destination chain (32 bytes)
748
+ */
749
+ to: Buffer;
750
+ }
751
+ /**
752
+ * Transfer limits for OFT operations
753
+ */
754
+ export interface OFTLimit {
755
+ /**
756
+ * The maximum amount to send in local decimals
757
+ */
758
+ max_amount_ld: i128;
759
+ /**
760
+ * The minimum amount to send in local decimals
761
+ */
762
+ min_amount_ld: i128;
763
+ }
764
+ /**
765
+ * Receipt containing amounts sent and received in an OFT transfer
766
+ */
767
+ export interface OFTReceipt {
768
+ /**
769
+ * The amount received in local decimals on the remote
770
+ */
771
+ amount_received_ld: i128;
772
+ /**
773
+ * The amount sent in local decimals
774
+ */
775
+ amount_sent_ld: i128;
776
+ }
777
+ /**
778
+ * Details about fees charged in an OFT operation
779
+ */
780
+ export interface OFTFeeDetail {
781
+ /**
782
+ * The description of the fee
783
+ */
784
+ description: Buffer;
785
+ /**
786
+ * The amount of the fee in local decimals. Positive values represent fees charged,
787
+ * while negative values represent rewards given.
788
+ */
789
+ fee_amount_ld: i128;
790
+ }
791
+ /**
792
+ * BufferReaderError: 1000-1009
793
+ */
794
+ export declare const BufferReaderError: {
795
+ 1000: {
796
+ message: string;
797
+ };
798
+ 1001: {
799
+ message: string;
800
+ };
801
+ };
802
+ /**
803
+ * BufferWriterError: 1010-1019
804
+ */
805
+ export declare const BufferWriterError: {
806
+ 1010: {
807
+ message: string;
808
+ };
809
+ };
810
+ /**
811
+ * TtlConfigurableError: 1020-1029
812
+ */
813
+ export declare const TtlConfigurableError: {
814
+ 1020: {
815
+ message: string;
816
+ };
817
+ 1021: {
818
+ message: string;
819
+ };
820
+ 1022: {
821
+ message: string;
822
+ };
823
+ };
824
+ /**
825
+ * OwnableError: 1030-1039
826
+ */
827
+ export declare const OwnableError: {
828
+ 1030: {
829
+ message: string;
830
+ };
831
+ 1031: {
832
+ message: string;
833
+ };
834
+ 1032: {
835
+ message: string;
836
+ };
837
+ 1033: {
838
+ message: string;
839
+ };
840
+ 1034: {
841
+ message: string;
842
+ };
843
+ 1035: {
844
+ message: string;
845
+ };
846
+ 1036: {
847
+ message: string;
848
+ };
849
+ };
850
+ /**
851
+ * BytesExtError: 1040-1049
852
+ */
853
+ export declare const BytesExtError: {
854
+ 1040: {
855
+ message: string;
856
+ };
857
+ };
858
+ /**
859
+ * UpgradeableError: 1050-1059
860
+ */
861
+ export declare const UpgradeableError: {
862
+ 1050: {
863
+ message: string;
864
+ };
865
+ 1051: {
866
+ message: string;
867
+ };
868
+ };
869
+ /**
870
+ * MultiSigError: 1060-1069
871
+ */
872
+ export declare const MultiSigError: {
873
+ 1060: {
874
+ message: string;
875
+ };
876
+ 1061: {
877
+ message: string;
878
+ };
879
+ 1062: {
880
+ message: string;
881
+ };
882
+ 1063: {
883
+ message: string;
884
+ };
885
+ 1064: {
886
+ message: string;
887
+ };
888
+ 1065: {
889
+ message: string;
890
+ };
891
+ 1066: {
892
+ message: string;
893
+ };
894
+ 1067: {
895
+ message: string;
896
+ };
897
+ 1068: {
898
+ message: string;
899
+ };
900
+ };
901
+ export type MultiSigStorage = {
902
+ tag: "Signers";
903
+ values: void;
904
+ } | {
905
+ tag: "Threshold";
906
+ values: void;
907
+ };
908
+ export type OwnableStorage = {
909
+ tag: "Owner";
910
+ values: void;
911
+ } | {
912
+ tag: "PendingOwner";
913
+ values: void;
914
+ };
915
+ /**
916
+ * TTL configuration: threshold (when to extend) and extend_to (target TTL).
917
+ */
918
+ export interface TtlConfig {
919
+ /**
920
+ * Target TTL after extension (in ledgers).
921
+ */
922
+ extend_to: u32;
923
+ /**
924
+ * TTL threshold that triggers extension (in ledgers).
925
+ */
926
+ threshold: u32;
927
+ }
928
+ export type TtlConfigStorage = {
929
+ tag: "Frozen";
930
+ values: void;
931
+ } | {
932
+ tag: "Instance";
933
+ values: void;
934
+ } | {
935
+ tag: "Persistent";
936
+ values: void;
937
+ };
938
+ export type UpgradeableStorage = {
939
+ tag: "Migrating";
940
+ values: void;
941
+ };
942
+ export interface Client {
943
+ /**
944
+ * Construct and simulate a redistribute_blacklisted_funds transaction. Returns an `AssembledTransaction` object which will have a `result` field containing the result of the simulation. If this transaction changes contract state, you will need to call `signAndSend()` on the returned object.
945
+ * Redistributes funds from a blacklisted account to the owner.
946
+ */
947
+ redistribute_blacklisted_funds: ({ from, amount }: {
948
+ from: string;
949
+ amount: i128;
950
+ }, txnOptions?: MethodOptions) => Promise<AssembledTransaction<null>>;
951
+ /**
952
+ * Construct and simulate a redistribution_enabled transaction. Returns an `AssembledTransaction` object which will have a `result` field containing the result of the simulation. If this transaction changes contract state, you will need to call `signAndSend()` on the returned object.
953
+ */
954
+ redistribution_enabled: (options?: MethodOptions) => Promise<AssembledTransaction<boolean>>;
955
+ /**
956
+ * Construct and simulate a set_supply_controller_manager 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.
957
+ * Sets whether an address is a supply controller manager. Owner-only.
958
+ */
959
+ set_supply_controller_manager: ({ manager, active }: {
960
+ manager: string;
961
+ active: boolean;
962
+ }, txnOptions?: MethodOptions) => Promise<AssembledTransaction<null>>;
963
+ /**
964
+ * Construct and simulate a set_supply_controller 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.
965
+ * Sets or removes a supply controller. Manager-only.
966
+ *
967
+ * - `Some(config)`: Adds a new supply controller with the given configuration.
968
+ * - `None`: Removes the supply controller.
969
+ */
970
+ set_supply_controller: ({ sender, supply_controller, config }: {
971
+ sender: string;
972
+ supply_controller: string;
973
+ config: Option<SupplyControllerConfig>;
974
+ }, txnOptions?: MethodOptions) => Promise<AssembledTransaction<null>>;
975
+ /**
976
+ * Construct and simulate a update_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.
977
+ * Updates the rate limit configuration for a supply controller. Manager-only.
978
+ * Note: This does NOT reset the rate limit state (remaining_amount, last_refill_time).
979
+ */
980
+ update_limit_config: ({ sender, supply_controller, limit_config }: {
981
+ sender: string;
982
+ supply_controller: string;
983
+ limit_config: LimitConfig;
984
+ }, txnOptions?: MethodOptions) => Promise<AssembledTransaction<null>>;
985
+ /**
986
+ * Construct and simulate a update_allow_any_mint_burn 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.
987
+ * Updates whether the supply controller can mint to and burn from any address. Manager-only.
988
+ */
989
+ update_allow_any_mint_burn: ({ sender, supply_controller, allow_any_mint_burn }: {
990
+ sender: string;
991
+ supply_controller: string;
992
+ allow_any_mint_burn: boolean;
993
+ }, txnOptions?: MethodOptions) => Promise<AssembledTransaction<null>>;
994
+ /**
995
+ * Construct and simulate a set_mint_whitelist 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
+ * Sets whether an address is in the mint whitelist of a supply controller. Manager-only.
997
+ */
998
+ set_mint_whitelist: ({ sender, supply_controller, mint_address, active }: {
999
+ sender: string;
1000
+ supply_controller: string;
1001
+ mint_address: string;
1002
+ active: boolean;
1003
+ }, txnOptions?: MethodOptions) => Promise<AssembledTransaction<null>>;
1004
+ /**
1005
+ * Construct and simulate a is_supply_controller_manager 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.
1006
+ * Returns whether the given address is a supply controller manager.
1007
+ */
1008
+ is_supply_controller_manager: ({ address }: {
1009
+ address: string;
1010
+ }, txnOptions?: MethodOptions) => Promise<AssembledTransaction<boolean>>;
1011
+ /**
1012
+ * Construct and simulate a get_supply_controller_managers 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.
1013
+ * Gets all supply controller manager addresses.
1014
+ */
1015
+ get_supply_controller_managers: (options?: MethodOptions) => Promise<AssembledTransaction<Array<string>>>;
1016
+ /**
1017
+ * Construct and simulate a get_supply_controller_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.
1018
+ * Gets supply controller configuration.
1019
+ */
1020
+ get_supply_controller_config: ({ supply_controller }: {
1021
+ supply_controller: string;
1022
+ }, txnOptions?: MethodOptions) => Promise<AssembledTransaction<Option<SupplyControllerConfig>>>;
1023
+ /**
1024
+ * Construct and simulate a allow_any_mint_burn 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.
1025
+ */
1026
+ allow_any_mint_burn: ({ supply_controller }: {
1027
+ supply_controller: string;
1028
+ }, txnOptions?: MethodOptions) => Promise<AssembledTransaction<boolean>>;
1029
+ /**
1030
+ * Construct and simulate a get_supply_controllers 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.
1031
+ * Gets all active supply controller addresses.
1032
+ */
1033
+ get_supply_controllers: (options?: MethodOptions) => Promise<AssembledTransaction<Array<string>>>;
1034
+ /**
1035
+ * Construct and simulate a is_address_whitelisted 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.
1036
+ * Returns whether the given address is in the whitelist of a supply controller.
1037
+ */
1038
+ is_address_whitelisted: ({ supply_controller, mint_address }: {
1039
+ supply_controller: string;
1040
+ mint_address: string;
1041
+ }, txnOptions?: MethodOptions) => Promise<AssembledTransaction<boolean>>;
1042
+ /**
1043
+ * Construct and simulate a get_remaining_mint_amount 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.
1044
+ * Gets remaining amount which can be minted at current timestamp.
1045
+ */
1046
+ get_remaining_mint_amount: ({ supply_controller }: {
1047
+ supply_controller: string;
1048
+ }, txnOptions?: MethodOptions) => Promise<AssembledTransaction<i128>>;
1049
+ /**
1050
+ * Construct and simulate a supply_control_enabled transaction. Returns an `AssembledTransaction` object which will have a `result` field containing the result of the simulation. If this transaction changes contract state, you will need to call `signAndSend()` on the returned object.
1051
+ */
1052
+ supply_control_enabled: (options?: MethodOptions) => Promise<AssembledTransaction<boolean>>;
1053
+ /**
1054
+ * Construct and simulate a authorized_mint 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.
1055
+ */
1056
+ authorized_mint: ({ sender, to, amount }: {
1057
+ sender: string;
1058
+ to: string;
1059
+ amount: i128;
1060
+ }, txnOptions?: MethodOptions) => Promise<AssembledTransaction<null>>;
1061
+ /**
1062
+ * Construct and simulate a clawback 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.
1063
+ */
1064
+ clawback: ({ sender, from, amount }: {
1065
+ sender: string;
1066
+ from: string;
1067
+ amount: i128;
1068
+ }, txnOptions?: MethodOptions) => Promise<AssembledTransaction<null>>;
1069
+ /**
1070
+ * Construct and simulate a release_sac_admin 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.
1071
+ */
1072
+ release_sac_admin: ({ to }: {
1073
+ to: string;
1074
+ }, txnOptions?: MethodOptions) => Promise<AssembledTransaction<null>>;
1075
+ /**
1076
+ * Construct and simulate a set_authorized transaction. Returns an `AssembledTransaction` object which will have a `result` field containing the result of the simulation. If this transaction changes contract state, you will need to call `signAndSend()` on the returned object.
1077
+ */
1078
+ set_authorized: ({ id, authorize }: {
1079
+ id: string;
1080
+ authorize: boolean;
1081
+ }, txnOptions?: MethodOptions) => Promise<AssembledTransaction<null>>;
1082
+ /**
1083
+ * Construct and simulate a set_oft_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.
1084
+ */
1085
+ set_oft_address: ({ new_oft }: {
1086
+ new_oft: string;
1087
+ }, txnOptions?: MethodOptions) => Promise<AssembledTransaction<null>>;
1088
+ /**
1089
+ * Construct and simulate a underlying_sac 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.
1090
+ */
1091
+ underlying_sac: (options?: MethodOptions) => Promise<AssembledTransaction<string>>;
1092
+ /**
1093
+ * Construct and simulate a oft_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.
1094
+ */
1095
+ oft_address: (options?: MethodOptions) => Promise<AssembledTransaction<string>>;
1096
+ /**
1097
+ * Construct and simulate a mint 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.
1098
+ */
1099
+ mint: ({ to, amount }: {
1100
+ to: string;
1101
+ amount: i128;
1102
+ }, txnOptions?: MethodOptions) => Promise<AssembledTransaction<null>>;
1103
+ /**
1104
+ * Construct and simulate a burn 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.
1105
+ */
1106
+ burn: ({ from, amount }: {
1107
+ from: string;
1108
+ amount: i128;
1109
+ }, txnOptions?: MethodOptions) => Promise<AssembledTransaction<null>>;
1110
+ /**
1111
+ * Construct and simulate a upgrade transaction. Returns an `AssembledTransaction` object which will have a `result` field containing the result of the simulation. If this transaction changes contract state, you will need to call `signAndSend()` on the returned object.
1112
+ * Upgrades the contract to new WASM bytecode.
1113
+ * Sets a migration flag that must be cleared by calling `migrate`.
1114
+ */
1115
+ upgrade: ({ new_wasm_hash }: {
1116
+ new_wasm_hash: Buffer;
1117
+ }, txnOptions?: MethodOptions) => Promise<AssembledTransaction<null>>;
1118
+ /**
1119
+ * Construct and simulate a migrate transaction. Returns an `AssembledTransaction` object which will have a `result` field containing the result of the simulation. If this transaction changes contract state, you will need to call `signAndSend()` on the returned object.
1120
+ * Runs migration logic after an upgrade.
1121
+ * Parses XDR-encoded `migration_data` and calls `__migrate`. Clears the migration flag on success.
1122
+ */
1123
+ migrate: ({ migration_data }: {
1124
+ migration_data: Buffer;
1125
+ }, txnOptions?: MethodOptions) => Promise<AssembledTransaction<null>>;
1126
+ /**
1127
+ * 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.
1128
+ */
1129
+ authorizer: (options?: MethodOptions) => Promise<AssembledTransaction<string>>;
1130
+ /**
1131
+ * 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.
1132
+ * Returns the current owner address, or None if no owner is set.
1133
+ */
1134
+ owner: (options?: MethodOptions) => Promise<AssembledTransaction<Option<string>>>;
1135
+ /**
1136
+ * 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.
1137
+ * Returns the pending owner address for 2-step transfer, or None if no transfer is pending.
1138
+ */
1139
+ pending_owner: (options?: MethodOptions) => Promise<AssembledTransaction<Option<string>>>;
1140
+ /**
1141
+ * 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.
1142
+ * Transfers ownership immediately to a new address.
1143
+ *
1144
+ * Use with caution - if you transfer to a wrong address, ownership is lost forever.
1145
+ * Consider using `propose_ownership_transfer` instead.
1146
+ *
1147
+ * # Panics
1148
+ * - `OwnerNotSet` if no owner is currently set
1149
+ * - `TransferInProgress` if a 2-step transfer is in progress
1150
+ */
1151
+ transfer_ownership: ({ new_owner }: {
1152
+ new_owner: string;
1153
+ }, txnOptions?: MethodOptions) => Promise<AssembledTransaction<null>>;
1154
+ /**
1155
+ * 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.
1156
+ * Proposes an ownership transfer to a new address.
1157
+ *
1158
+ * The new owner must call `accept_ownership()` within `ttl` ledgers
1159
+ * to complete the transfer. The pending transfer will automatically expire after.
1160
+ *
1161
+ * # Arguments
1162
+ * - `new_owner` - The proposed new owner
1163
+ * - `ttl` - Number of ledgers the new owner has to accept.
1164
+ * Use `0` to cancel a pending transfer (new_owner must match pending).
1165
+ *
1166
+ * # Panics
1167
+ * - `OwnerNotSet` if no owner is currently set
1168
+ * - `NoPendingTransfer` when cancelling and no pending transfer exists
1169
+ * - `InvalidTtl` if ttl exceeds max TTL
1170
+ * - `InvalidPendingOwner` when cancelling with wrong new_owner address
1171
+ */
1172
+ propose_ownership_transfer: ({ new_owner, ttl }: {
1173
+ new_owner: string;
1174
+ ttl: u32;
1175
+ }, txnOptions?: MethodOptions) => Promise<AssembledTransaction<null>>;
1176
+ /**
1177
+ * 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.
1178
+ * Accepts a pending 2-step ownership transfer.
1179
+ *
1180
+ * Must be called by the pending owner before the TTL expires.
1181
+ *
1182
+ * # Panics
1183
+ * - `NoPendingTransfer` if there is no pending transfer (or it expired)
1184
+ */
1185
+ accept_ownership: (options?: MethodOptions) => Promise<AssembledTransaction<null>>;
1186
+ /**
1187
+ * 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.
1188
+ * Permanently renounces ownership.
1189
+ *
1190
+ * # Panics
1191
+ * - `OwnerNotSet` if no owner is currently set
1192
+ * - `TransferInProgress` if a 2-step transfer is in progress (cancel it first)
1193
+ */
1194
+ renounce_ownership: (options?: MethodOptions) => Promise<AssembledTransaction<null>>;
1195
+ /**
1196
+ * 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.
1197
+ * Extends the instance TTL.
1198
+ *
1199
+ * # Arguments
1200
+ *
1201
+ * * `threshold` - The threshold to extend the TTL (if current TTL is below this, extend).
1202
+ * * `extend_to` - The TTL to extend to.
1203
+ */
1204
+ extend_instance_ttl: ({ threshold, extend_to }: {
1205
+ threshold: u32;
1206
+ extend_to: u32;
1207
+ }, txnOptions?: MethodOptions) => Promise<AssembledTransaction<null>>;
1208
+ /**
1209
+ * 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.
1210
+ * Sets TTL configs for instance and persistent storage.
1211
+ *
1212
+ * - `None` values remove the corresponding config (disables auto-extension for that type)
1213
+ * - Validates that `threshold <= extend_to <= MAX_TTL`
1214
+ *
1215
+ * # Arguments
1216
+ * - `instance` - TTL config for instance storage
1217
+ * - `persistent` - TTL config for persistent storage
1218
+ *
1219
+ * # Panics
1220
+ * - `TtlConfigFrozen` if configs are frozen
1221
+ * - `InvalidTtlConfig` if validation fails
1222
+ */
1223
+ set_ttl_configs: ({ instance, persistent }: {
1224
+ instance: Option<TtlConfig>;
1225
+ persistent: Option<TtlConfig>;
1226
+ }, txnOptions?: MethodOptions) => Promise<AssembledTransaction<null>>;
1227
+ /**
1228
+ * 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.
1229
+ * Returns the current TTL configs as (instance_config, persistent_config).
1230
+ */
1231
+ ttl_configs: (options?: MethodOptions) => Promise<AssembledTransaction<readonly [Option<TtlConfig>, Option<TtlConfig>]>>;
1232
+ /**
1233
+ * 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.
1234
+ * Permanently freezes TTL configs, preventing any future modifications.
1235
+ *
1236
+ * This is irreversible and provides immutability guarantees to users.
1237
+ * Emits `TtlConfigsFrozen` event.
1238
+ *
1239
+ * # Panics
1240
+ * - `TtlConfigAlreadyFrozen` if already frozen
1241
+ */
1242
+ freeze_ttl_configs: (options?: MethodOptions) => Promise<AssembledTransaction<null>>;
1243
+ /**
1244
+ * 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.
1245
+ * Returns whether TTL configs are frozen.
1246
+ */
1247
+ is_ttl_configs_frozen: (options?: MethodOptions) => Promise<AssembledTransaction<boolean>>;
1248
+ }
1249
+ export declare class Client extends ContractClient {
1250
+ readonly options: ContractClientOptions;
1251
+ static deploy<T = Client>(
1252
+ /** Constructor/Initialization Args for the contract's `__constructor` method */
1253
+ { sac_token, owner, redistribution_enabled, supply_control_enabled }: {
1254
+ sac_token: string;
1255
+ owner: string;
1256
+ redistribution_enabled: boolean;
1257
+ supply_control_enabled: boolean;
1258
+ },
1259
+ /** Options for initializing a Client as well as for calling a method, with extras specific to deploying. */
1260
+ options: MethodOptions & Omit<ContractClientOptions, "contractId"> & {
1261
+ /** The hash of the Wasm blob, which must already be installed on-chain. */
1262
+ wasmHash: Buffer | string;
1263
+ /** Salt used to generate the contract's ID. Passed through to {@link Operation.createCustomContract}. Default: random. */
1264
+ salt?: Buffer | Uint8Array;
1265
+ /** The format used to decode `wasmHash`, if it's provided as a string. */
1266
+ format?: "hex" | "base64";
1267
+ }): Promise<AssembledTransaction<T>>;
1268
+ constructor(options: ContractClientOptions);
1269
+ readonly fromJSON: {
1270
+ redistribute_blacklisted_funds: (json: string) => AssembledTransaction<null>;
1271
+ redistribution_enabled: (json: string) => AssembledTransaction<boolean>;
1272
+ set_supply_controller_manager: (json: string) => AssembledTransaction<null>;
1273
+ set_supply_controller: (json: string) => AssembledTransaction<null>;
1274
+ update_limit_config: (json: string) => AssembledTransaction<null>;
1275
+ update_allow_any_mint_burn: (json: string) => AssembledTransaction<null>;
1276
+ set_mint_whitelist: (json: string) => AssembledTransaction<null>;
1277
+ is_supply_controller_manager: (json: string) => AssembledTransaction<boolean>;
1278
+ get_supply_controller_managers: (json: string) => AssembledTransaction<string[]>;
1279
+ get_supply_controller_config: (json: string) => AssembledTransaction<Option<SupplyControllerConfig>>;
1280
+ allow_any_mint_burn: (json: string) => AssembledTransaction<boolean>;
1281
+ get_supply_controllers: (json: string) => AssembledTransaction<string[]>;
1282
+ is_address_whitelisted: (json: string) => AssembledTransaction<boolean>;
1283
+ get_remaining_mint_amount: (json: string) => AssembledTransaction<bigint>;
1284
+ supply_control_enabled: (json: string) => AssembledTransaction<boolean>;
1285
+ authorized_mint: (json: string) => AssembledTransaction<null>;
1286
+ clawback: (json: string) => AssembledTransaction<null>;
1287
+ release_sac_admin: (json: string) => AssembledTransaction<null>;
1288
+ set_authorized: (json: string) => AssembledTransaction<null>;
1289
+ set_oft_address: (json: string) => AssembledTransaction<null>;
1290
+ underlying_sac: (json: string) => AssembledTransaction<string>;
1291
+ oft_address: (json: string) => AssembledTransaction<string>;
1292
+ mint: (json: string) => AssembledTransaction<null>;
1293
+ burn: (json: string) => AssembledTransaction<null>;
1294
+ upgrade: (json: string) => AssembledTransaction<null>;
1295
+ migrate: (json: string) => AssembledTransaction<null>;
1296
+ authorizer: (json: string) => AssembledTransaction<string>;
1297
+ owner: (json: string) => AssembledTransaction<Option<string>>;
1298
+ pending_owner: (json: string) => AssembledTransaction<Option<string>>;
1299
+ transfer_ownership: (json: string) => AssembledTransaction<null>;
1300
+ propose_ownership_transfer: (json: string) => AssembledTransaction<null>;
1301
+ accept_ownership: (json: string) => AssembledTransaction<null>;
1302
+ renounce_ownership: (json: string) => AssembledTransaction<null>;
1303
+ extend_instance_ttl: (json: string) => AssembledTransaction<null>;
1304
+ set_ttl_configs: (json: string) => AssembledTransaction<null>;
1305
+ ttl_configs: (json: string) => AssembledTransaction<readonly [Option<TtlConfig>, Option<TtlConfig>]>;
1306
+ freeze_ttl_configs: (json: string) => AssembledTransaction<null>;
1307
+ is_ttl_configs_frozen: (json: string) => AssembledTransaction<boolean>;
1308
+ };
1309
+ }