@layerzerolabs/protocol-stellar-v2 0.2.35 → 0.2.37

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 (105) hide show
  1. package/.turbo/turbo-build.log +274 -268
  2. package/.turbo/turbo-lint.log +216 -213
  3. package/.turbo/turbo-test.log +1735 -1994
  4. package/contracts/common-macros/src/auth.rs +5 -5
  5. package/contracts/common-macros/src/lib.rs +69 -0
  6. package/contracts/common-macros/src/rbac.rs +90 -0
  7. package/contracts/common-macros/src/tests/lz_contract.rs +5 -7
  8. package/contracts/common-macros/src/tests/mod.rs +1 -0
  9. package/contracts/common-macros/src/tests/rbac.rs +420 -0
  10. package/contracts/common-macros/src/tests/snapshots/common_macros__tests__auth__snapshot_generated_multisig_code.snap +4 -4
  11. package/contracts/common-macros/src/tests/snapshots/common_macros__tests__auth__snapshot_generated_ownable_code.snap +5 -12
  12. package/contracts/common-macros/src/tests/snapshots/common_macros__tests__rbac__snapshot_preserve_function_signature.snap +17 -0
  13. package/contracts/common-macros/src/tests/storage/parse_name.rs +0 -1
  14. package/contracts/macro-integration-tests/tests/runtime/lz_contract/wrapper_default.rs +1 -1
  15. package/contracts/macro-integration-tests/tests/runtime/lz_contract/wrapper_multisig.rs +1 -1
  16. package/contracts/macro-integration-tests/tests/runtime/lz_contract/wrapper_multisig_upgradeable.rs +1 -1
  17. package/contracts/macro-integration-tests/tests/runtime/multisig/self_auth.rs +1 -1
  18. package/contracts/macro-integration-tests/tests/runtime/ownable/initialization.rs +8 -5
  19. package/contracts/macro-integration-tests/tests/runtime/ownable/ownership_transfer.rs +2 -2
  20. package/contracts/macro-integration-tests/tests/runtime/rbac/guard_behavior.rs +91 -0
  21. package/contracts/macro-integration-tests/tests/runtime/rbac/mod.rs +30 -0
  22. package/contracts/macro-integration-tests/tests/runtime/ttl_configurable/configuration.rs +2 -2
  23. package/contracts/macro-integration-tests/tests/runtime/upgradeable/migrate_guard_and_state.rs +4 -4
  24. package/contracts/macro-integration-tests/tests/ui/lz_contract/pass/basic.rs +1 -1
  25. package/contracts/macro-integration-tests/tests/ui/ownable/pass/basic.rs +1 -1
  26. package/contracts/macro-integration-tests/tests/ui/rbac/fail/missing_env.rs +18 -0
  27. package/contracts/macro-integration-tests/tests/ui/rbac/fail/missing_env.stderr +16 -0
  28. package/contracts/macro-integration-tests/tests/ui/rbac/fail/param_not_address.rs +18 -0
  29. package/contracts/macro-integration-tests/tests/ui/rbac/fail/param_not_address.stderr +24 -0
  30. package/contracts/macro-integration-tests/tests/ui/rbac/fail/param_not_found.rs +18 -0
  31. package/contracts/macro-integration-tests/tests/ui/rbac/fail/param_not_found.stderr +24 -0
  32. package/contracts/macro-integration-tests/tests/ui/rbac/pass/basic.rs +71 -0
  33. package/contracts/macro-integration-tests/tests/ui_rbac.rs +12 -0
  34. package/contracts/oapps/oft/src/interfaces/mintable.rs +2 -2
  35. package/contracts/oapps/oft/src/tests/extensions/oft_fee.rs +2 -2
  36. package/contracts/oapps/oft/src/tests/extensions/pausable.rs +2 -2
  37. package/contracts/oapps/oft/src/tests/extensions/rate_limiter.rs +2 -2
  38. package/contracts/oapps/sac-manager/Cargo.toml +0 -1
  39. package/contracts/oapps/sac-manager/src/interfaces/mod.rs +3 -0
  40. package/contracts/oapps/sac-manager/src/interfaces/sac_admin_wrapper.rs +49 -0
  41. package/contracts/oapps/sac-manager/src/lib.rs +3 -3
  42. package/contracts/oapps/sac-manager/src/sac_manager.rs +45 -73
  43. package/contracts/oapps/sac-manager/src/storage.rs +2 -9
  44. package/contracts/oapps/sac-manager/src/tests/sac_manager/clawback.rs +8 -10
  45. package/contracts/oapps/sac-manager/src/tests/sac_manager/mint.rs +13 -18
  46. package/contracts/oapps/sac-manager/src/tests/sac_manager/mod.rs +0 -1
  47. package/contracts/oapps/sac-manager/src/tests/sac_manager/set_admin.rs +22 -12
  48. package/contracts/oapps/sac-manager/src/tests/sac_manager/set_authorized.rs +19 -9
  49. package/contracts/oapps/sac-manager/src/tests/sac_manager/test_helper.rs +27 -10
  50. package/contracts/oapps/sac-manager/src/tests/sac_manager/view_functions.rs +0 -15
  51. package/contracts/oapps/sac-manager/src/tests/test_helper.rs +19 -28
  52. package/contracts/upgrader/src/lib.rs +5 -2
  53. package/contracts/utils/src/auth.rs +6 -2
  54. package/contracts/utils/src/errors.rs +18 -0
  55. package/contracts/utils/src/lib.rs +1 -0
  56. package/contracts/utils/src/multisig.rs +5 -1
  57. package/contracts/utils/src/ownable.rs +1 -1
  58. package/contracts/utils/src/rbac.rs +428 -0
  59. package/contracts/utils/src/tests/auth.rs +2 -2
  60. package/contracts/utils/src/tests/mod.rs +1 -0
  61. package/contracts/utils/src/tests/multisig.rs +2 -2
  62. package/contracts/utils/src/tests/ownable.rs +4 -5
  63. package/contracts/utils/src/tests/rbac.rs +559 -0
  64. package/contracts/utils/src/tests/ttl_configurable.rs +5 -6
  65. package/contracts/utils/src/tests/upgradeable.rs +4 -5
  66. package/contracts/workers/worker/src/worker.rs +1 -1
  67. package/package.json +3 -3
  68. package/sdk/.turbo/turbo-test.log +368 -366
  69. package/sdk/dist/generated/bml.d.ts +53 -3
  70. package/sdk/dist/generated/bml.js +27 -3
  71. package/sdk/dist/generated/counter.d.ts +55 -5
  72. package/sdk/dist/generated/counter.js +28 -4
  73. package/sdk/dist/generated/dvn.d.ts +55 -5
  74. package/sdk/dist/generated/dvn.js +28 -4
  75. package/sdk/dist/generated/dvn_fee_lib.d.ts +55 -5
  76. package/sdk/dist/generated/dvn_fee_lib.js +28 -4
  77. package/sdk/dist/generated/endpoint.d.ts +55 -5
  78. package/sdk/dist/generated/endpoint.js +28 -4
  79. package/sdk/dist/generated/executor.d.ts +55 -5
  80. package/sdk/dist/generated/executor.js +28 -4
  81. package/sdk/dist/generated/executor_fee_lib.d.ts +55 -5
  82. package/sdk/dist/generated/executor_fee_lib.js +28 -4
  83. package/sdk/dist/generated/executor_helper.d.ts +53 -3
  84. package/sdk/dist/generated/executor_helper.js +27 -3
  85. package/sdk/dist/generated/layerzero_view.d.ts +55 -5
  86. package/sdk/dist/generated/layerzero_view.js +28 -4
  87. package/sdk/dist/generated/oft.d.ts +55 -5
  88. package/sdk/dist/generated/oft.js +28 -4
  89. package/sdk/dist/generated/price_feed.d.ts +55 -5
  90. package/sdk/dist/generated/price_feed.js +28 -4
  91. package/sdk/dist/generated/sac_manager.d.ts +213 -687
  92. package/sdk/dist/generated/sac_manager.js +57 -239
  93. package/sdk/dist/generated/sml.d.ts +55 -5
  94. package/sdk/dist/generated/sml.js +28 -4
  95. package/sdk/dist/generated/treasury.d.ts +55 -5
  96. package/sdk/dist/generated/treasury.js +28 -4
  97. package/sdk/dist/generated/uln302.d.ts +55 -5
  98. package/sdk/dist/generated/uln302.js +28 -4
  99. package/sdk/dist/generated/upgrader.d.ts +53 -3
  100. package/sdk/dist/generated/upgrader.js +27 -3
  101. package/sdk/package.json +1 -1
  102. package/sdk/test/oft-sml.test.ts +10 -9
  103. package/sdk/test/{sac-manager-redistribution.test.ts → sac-manager.test.ts} +49 -25
  104. package/contracts/oapps/sac-manager/src/errors.rs +0 -14
  105. package/contracts/oapps/sac-manager/src/tests/sac_manager/set_minter.rs +0 -69
@@ -1,659 +1,28 @@
1
1
  import { Buffer } from "buffer";
2
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';
3
+ import type { u32, i128, Option } from '@stellar/stellar-sdk/contract';
4
4
  export * from '@stellar/stellar-sdk';
5
5
  export * as contract from '@stellar/stellar-sdk/contract';
6
6
  export * as rpc from '@stellar/stellar-sdk/rpc';
7
7
  /**
8
8
  * Embedded WASM bytecode (base64-encoded)
9
- * Size: 31206 bytes (30.47 KB)
9
+ * Size: 23526 bytes (22.97 KB)
10
10
  */
11
- export declare const WASM_BASE64 = "AGFzbQEAAAABbRRgAn5+AX5gBH5+fn4BfmABfgF+YAN+fn4BfmAAAX5gAAF/YAAAYAF/AX5gAn5+AX9gAX8AYAJ+fwBgAX4AYAN/f38AYAJ/fgBgAn9/AX5gA35+fgBgAn9/AGACfn4AYAR/f39/AX5gA39+fgACqQEcAWwBMQAAAWwBNwABAWEBMAACAXYBZAAAAWwBXwADAXYBMwACAXYBMgAAAXYBNgAAAWIBOAACAWwBNgACAWIBMAACAXgBMQAAAWwBMgAAAXYBXwAEAXYBZwAAAWkBOAACAWkBNwACAWIBagAAAWkBNgAAAWQBXwADAW0BOQADAXgBMAAAAXgBMwAEAXgBOAAEAWwBMAAAAWwBOAAAAXgBNQACAW0BYQABA0xLBQYHCAYJBwYEBAkKCAsGCQcJDA0DDQQEAA4PABAQCwACAA4ABAYEBAYCCQIEBAQABAIRAAYCEgUTBAQAEAANBwQJEAQEBgwNDBAMBQMBABEGIQR/AUGAgMAAC38AQY+AwAALfwBBi4PAAAt/AEGQg8AACweOAxoGbWVtb3J5AgAEbWludAAwDV9fY29uc3RydWN0b3IANwhjbGF3YmFjawA7EXJlbGVhc2Vfc2FjX2FkbWluADwOc2V0X2F1dGhvcml6ZWQAPQpzZXRfbWludGVyAD8OdW5kZXJseWluZ19zYWMAQgdtaW50ZXJzAEMHdXBncmFkZQBFB21pZ3JhdGUARwphdXRob3JpemVyAEkFb3duZXIASg1wZW5kaW5nX293bmVyAEwSdHJhbnNmZXJfb3duZXJzaGlwAE0acHJvcG9zZV9vd25lcnNoaXBfdHJhbnNmZXIATxBhY2NlcHRfb3duZXJzaGlwAFUScmVub3VuY2Vfb3duZXJzaGlwAFYTZXh0ZW5kX2luc3RhbmNlX3R0bABXD3NldF90dGxfY29uZmlncwBZC3R0bF9jb25maWdzAFwSZnJlZXplX3R0bF9jb25maWdzAF8VaXNfdHRsX2NvbmZpZ3NfZnJvemVuAGABXwMBCl9fZGF0YV9lbmQDAgtfX2hlYXBfYmFzZQMDCsM0S00CAX8BfhCdgICAAEEAIQACQEEAEJ6AgIAAIgFCAhCfgICAAEUNAEEBIQACQAJAIAFCAhCAgICAAKdB/wFxDgIBAgALAAtBACEACyAAC0gBAX8jgICAgABBEGsiACSAgICAACAAQQRqEN2AgIAAAkAgACgCBEEBRw0AIAAoAgggACgCDBDYgICAAAsgAEEQaiSAgICAAAvCAQIBfwF+I4CAgIAAQRBrIgEkgICAgAACQAJAAkACQAJAAkAgAEH/AXEOAwABAgALIAFB6oLAgABBBhCugICAACABKAIADQMgASABKQMIEK+AgIAADAILIAFB8ILAgABBCBCugICAACABKAIADQIgASABKQMIEK+AgIAADAELIAFB+ILAgABBChCugICAACABKAIADQEgASABKQMIEK+AgIAACyABKQMIIQIgASkDAFANAQsACyABQRBqJICAgIAAIAILDwAgACABEJiAgIAAQgFRC2kCAX8CfiOAgICAAEEQayIAJICAgIAAIABBBGoQoYCAgAACQCAAKAIEQQFHDQAgADUCDCEBIAA1AgghAkEBEKKAgIAAQgEgAkIghkIEhCABQiCGQgSEEIGAgIAAGgsgAEEQaiSAgICAAAsMACAAQQIQ5YCAgAALkgECAX8BfiOAgICAAEEQayIBJICAgIAAAkACQAJAAkAgAEEBcUUNACABQYiAwIAAQQcQroCAgAAgASgCAA0CIAEgASkDCBCvgICAAAwBCyABQYCAwIAAQQgQroCAgAAgASgCAA0BIAEgASkDCBCvgICAAAsgASkDCCECIAEpAwBQDQELAAsgAUEQaiSAgICAACACCw8AEKSAgIAAEIKAgIAAGgtHAgF/AX4jgICAgABBEGsiACSAgICAABCdgICAACAAEKaAgIAAIAApAwghASAAKQMAQYsIEKeAgIAAIABBEGokgICAgAAgAQtsAgF/AX4jgICAgABBEGsiACSAgICAACAAEKaAgIAAIAApAwghASAAKQMAQYsIEKeAgIAAAkAgARCkgICAABCogICAAA0AQoOAgIDggAEQqYCAgAAACyABEIKAgIAAGiAAQRBqJICAgIAAIAELEAAQnYCAgAAgABCtgICAAAspAAJAIACnQQFxRQ0ADwsgAUH6d2qtQiCGQoOAgIDggAF8EKmAgIAAAAsNACAAIAEQlYCAgABQCwsAIAAQmoCAgAAaC0IBAX8jgICAgABBEGsiACSAgICAACAAEKuAgIAAAkAgACkDAFANAEKDgICAwIEBEKmAgIAAAAsgAEEQaiSAgICAAAtTAQJ+EJ2AgIAAQgAhAQJAAkBBARCsgICAACICQgAQn4CAgABFDQAgAkIAEICAgIAAIgFC/wGDQs0AUg0BIAAgATcDCEIBIQELIAAgATcDAA8LAAuSAQIBfwF+I4CAgIAAQRBrIgEkgICAgAACQAJAAkACQCAAQQFxRQ0AIAFB/YHAgABBDBCugICAACABKAIADQIgASABKQMIEK+AgIAADAELIAFB+IHAgABBBRCugICAACABKAIADQEgASABKQMIEK+AgIAACyABKQMIIQIgASkDAFANAQsACyABQRBqJICAgIAAIAILTQECfkIAIQECQAJAQQAQrICAgAAiAkICEJ+AgIAARQ0AIAJCAhCAgICAACIBQv8Bg0LNAFINASAAIAE3AwhCASEBCyAAIAE3AwAPCwALUQIBfwF+I4CAgIAAQRBrIgMkgICAgAAgAyABIAIQ4oCAgABCASEEAkAgAygCAA0AIAAgAykDCDcDCEIAIQQLIAAgBDcDACADQRBqJICAgIAAC0QBAX8jgICAgABBEGsiAiSAgICAACACIAE3AwggAkEIakEBELWAgIAAIQEgAEIANwMAIAAgATcDCCACQRBqJICAgIAAC54CAwF/AX4BfyOAgICAAEEwayIDJICAgIAAAkAgAEL/AYNCzQBSDQAgAyABELGAgIAAIAMoAgBBAUYNACACQv8Bg0LNAFINACADKQMYIQEgAykDECEEEJ2AgIAAAkAQsoCAgAAgAhCDgICAAEICUQ0AIAIQgoCAgAAaELOAgIAAIQIgAyAEIAEQtICAgAA3AyggAyAANwMgQQAhBQNAAkAgBUEQRw0AQQAhBQJAA0AgBUEQRg0BIAMgBWogA0EgaiAFaikDADcDACAFQQhqIQUMAAsLIAJCjvKz1wwgA0ECELWAgIAAELaAgIAAIANBMGokgICAgABCAg8LIAMgBWpCAjcDACAFQQhqIQUMAAsLQoOAgIAwEKmAgIAAAAsAC30CAX8BfgJAAkACQAJAIAGnQf8BcSICQcUARg0AIAJBC0cNAiAAIAFCP4c3AxggACABQgiHNwMQDAELIAEQj4CAgAAhAyABEJCAgIAAIQEgACADNwMYIAAgATcDEAtCACEBDAELIABCg5CAgIABNwMIQgEhAQsgACABNwMACw4AEJ2AgIAAEMCAgIAAC0UBAX4QnYCAgAACQAJAQQAQooCAgAAiAEICEJ+AgIAARQ0AIABCAhCAgICAACIAQv8Bg0LNAFENAQALEMSAgIAAAAsgAAtFAAJAIABCgICAgICAgMAAfEL//////////wBWDQAgACAAhSABIABCP4eFhEIAUg0AIABCCIZCC4QPCyABIAAQkoCAgAALGgAgAK1CIIZCBIQgAa1CIIZCBIQQjoCAgAALIQACQCAAIAEgAhCTgICAAEL/AYNCAlENABDBgICAAAALC3wAAkACQCAAQv8Bg0LNAFINACABQv8Bg0LNAFINAEGAyx5BgNIfELiAgIAAQYDLHkGA0h8QuYCAgABBABCsgICAAEICEJ+AgIAADQEgARC6gICAAEEAEKKAgIAAIABCAhCEgICAABpCAg8LAAtCg4CAgKCBARCpgICAAAALDgBBASAAIAEQ5oCAgAALDgBBAiAAIAEQ5oCAgAALDgBBACAAQgIQ1ICAgAAL8AEDAX8CfgF/I4CAgIAAQTBrIgIkgICAgAACQCAAQv8Bg0LNAFINACACIAEQsYCAgAAgAigCAEEBRg0AIAIpAxghASACKQMQIQMQo4CAgAAQnYCAgAAQs4CAgAAhBCACIAMgARC0gICAADcDKCACIAA3AyBBACEFA0ACQCAFQRBHDQBBACEFAkADQCAFQRBGDQEgAiAFaiACQSBqIAVqKQMANwMAIAVBCGohBQwACwsgBEKO4KjzybfG0QAgAkECELWAgIAAELaAgIAAIAJBMGokgICAgABCAg8LIAIgBWpCAjcDACAFQQhqIQUMAAsLAAtuAgF/AX4jgICAgABBEGsiASSAgICAAAJAIABC/wGDQs0AUQ0AAAsQo4CAgAAQnYCAgAAQs4CAgAAhAiABIAA3AwggAkKO5q656ozk1TggAUEIakEBELWAgIAAELaAgIAAIAFBEGokgICAgABCAgvxAQIDfwF+I4CAgIAAQSBrIgIkgICAgAACQCAAQv8Bg0LNAFINAEEAIQNBASABp0H/AXEiBEEAR0EBdCAEQQFGGyIEQQJGDQAQo4CAgAAQnYCAgAAQs4CAgAAhAUGPgMCAAEEOEL6AgIAAIQUgAiAErTcDCCACIAA3AwADQAJAIANBEEcNAEEAIQMCQANAIANBEEYNASACQRBqIANqIAIgA2opAwA3AwAgA0EIaiEDDAALCyABIAUgAkEQakECELWAgIAAELaAgIAAIAJBIGokgICAgABCAg8LIAJBEGogA2pCAjcDACADQQhqIQMMAAsLAAtFAgF/AX4jgICAgABBEGsiAiSAgICAACACIAAgARDigICAAAJAIAIoAgBBAUcNAAALIAIpAwghAyACQRBqJICAgIAAIAML9AECAX8BfgJAIABC/wGDQs0AUg0AQQEgAadB/wFxIgJBAEdBAXQgAkEBRhsiAkECRg0AEKOAgIAAEJ2AgIAAAkACQAJAAkAQwICAgAAiASAAEIOAgIAAIgNCAlENACADQv8Bg0IEUQ0BEMGAgIAAAAsgAkEBcQ0BQoOAgIAgEKmAgIAAAAsCQCACQQFxDQAgA0IgiKciAiABEIWAgIAAQiCIp08NAiABIAKtQiCGQgSEEIaAgIAAIQEMAgtCg4CAgBAQqYCAgAAACyABIAAQh4CAgAAhAQtBARCigICAACABQgEQhICAgAAaEKCAgIAAQgIPCwALRgEBfgJAAkBBARCigICAACIAQgEQn4CAgABFDQAgAEIBEICAgIAAIgBC/wGDQssAUg0BEKCAgIAAIAAPCxCNgICAAA8LAAsJABDhgICAAAALCAAQs4CAgAALCAAQsoCAgAALCQAQwYCAgAAAC00AAkACQCAAQv8Bg0LIAFINACAAEIiAgIAAQoCAgIBwg0KAgICAgARRDQELAAsQo4CAgAAQnYCAgABBARDGgICAACAAEImAgIAAGkICCxgAEMiAgIAAIACtQv8Bg0ICEISAgIAAGguKAQEBfgJAAkAgAEL/AYNCyABSDQAQo4CAgAAQnYCAgAACQAJAEMiAgIAAIgFCAhCfgICAAEUNACABQgIQgICAgACnQf8BcQ4CAAECC0KDgICAsIMBEKmAgIAAAAsgABCKgICAAEL/AYNCAlINAUEAEMaAgIAAQgIPCwALQoOAgICggwEQqYCAgAAAC2ACAX8BfiOAgICAAEEQayIAJICAgIAAIABBgoPAgABBCRCugICAAAJAAkAgACgCAA0AIAAgACkDCBCvgICAACAAKAIAQQFHDQELAAsgACkDCCEBIABBEGokgICAgAAgAQsIABCkgICAAAs+AgF/AX4jgICAgABBEGsiACSAgICAACAAEKaAgIAAIAApAwAgACkDCBDLgICAACEBIABBEGokgICAgAAgAQsNACABQgIgAKdBAXEbCz4CAX8BfiOAgICAAEEQayIAJICAgIAAIAAQq4CAgAAgACkDACAAKQMIEMuAgIAAIQEgAEEQaiSAgICAACABCzwBAX4CQCAAQv8Bg0LNAFENAAALEJ2AgIAAEKWAgIAAIQEQqoCAgAAgABC6gICAACABIAAQzoCAgABCAgthAgF/AX4jgICAgABBEGsiAiSAgICAAEGmgMCAAEEVEL6AgIAAENGAgIAAIQMgAiAANwMIIAIgATcDACADQdCAwIAAQQIgAkECENKAgIAAEIuAgIAAGiACQRBqJICAgIAAC/wCAgF/An4jgICAgABBIGsiAiSAgICAAAJAAkACQCAAQv8Bg0LNAFINACABQv8Bg0IEUg0AEJ2AgIAAEKWAgIAAIQMCQAJAIAFC/////w9WDQAgAkEIahCrgICAACACKQMQIQEgAikDCEGJCBCngICAACABIAAQqICAgABFDQMQ0ICAgABBlIHAgABBHBC+gICAABDRgICAACEAIAIgAzcDECACIAE3AwggAEHMgcCAAEECIAJBCGpBAhDSgICAABCLgICAABoMAQsQ04CAgAAgAUIgiKdJDQNBASAAQgAQ1ICAgABBARCsgICAAEIAIAFChICAgHCDIgEgARCBgICAABpB4IDAgABBFhC+gICAABDRgICAACEEIAIgATcDGCACIAM3AxAgAiAANwMIIARB/IDAgABBAyACQQhqQQMQ0oCAgAAQi4CAgAAaCyACQSBqJICAgIAAQgIPCwALQoOAgIDwgAEQqYCAgAAAC0KDgICAgIEBEKmAgIAAAAsTAEEBEKyAgIAAQgAQjICAgAAaC2MDAX8BfgF/I4CAgIAAQRBrIgEkgICAgAAgASAANwMAQgIhAkEBIQMCQANAIANFDQEgA0F/aiEDIAAhAgwACwsgASACNwMIIAFBCGpBARC1gICAACEAIAFBEGokgICAgAAgAAsuAAJAIAEgA0YNAAALIACtQiCGQgSEIAKtQiCGQgSEIAGtQiCGQgSEEJSAgIAACzMBAn4QloCAgAAhAAJAEJeAgIAAQiCIIgEgAEIgiCIAVA0AIAGnIACnaw8LEMGAgIAAAAsVACAAEKyAgIAAIAEgAhCEgICAABoLiAECAX8CfiOAgICAAEEQayIAJICAgIAAEJ2AgIAAIAAQq4CAgAAgACkDCCEBIAApAwBBiQgQp4CAgAAgARCCgICAABogABCtgICAAAJAIAAoAgANABDEgICAAAALIAApAwghAhDQgICAACABELqAgIAAIAIgARDOgICAACAAQRBqJICAgIAAQgILhAECAX8CfiOAgICAAEEQayIAJICAgIAAEJ2AgIAAEKWAgIAAIQEQqoCAgABBABCsgICAAEICEIyAgIAAGkHcgcCAAEETEL6AgIAAENGAgIAAIQIgACABNwMIIAJB8IHAgABBASAAQQhqQQEQ0oCAgAAQi4CAgAAaIABBEGokgICAgABCAgsxAAJAIABC/wGDQgRSDQAgAUL/AYNCBFINACAAQiCIpyABQiCIpxDYgICAAEICDwsACxsAIACtQiCGQgSEIAGtQiCGQgSEEJmAgIAAGgu8BAEFfyOAgICAAEHQAGsiAiSAgICAACACQShqIAAQ2oCAgAACQCACKAIoQQJGDQAgAkEIakEIaiACQShqQQhqIgMoAgA2AgAgAiACKQIoNwMIIAJBKGogARDagICAACACKAIoQQJGDQAgAkEYakEIaiADKAIANgIAIAIgAikCKDcDGBCjgICAABCdgICAAAJAAkACQBCcgICAAA0AENOAgIAAIgNBgPuAAyADQYD7gANJGyEEIAIgAkEYajYCLCACIAJBCGo2AihBACEDA0AgA0EIRg0DAkAgAkEoaiADaigCACIFKAIAQQFxRQ0AIAUoAggiBiAESw0DIAUoAgQgBksNAwsgA0EEaiEDDAALC0KDgICA0P8AEKmAgIAAAAtCg4CAgMD/ABCpgICAAAALAkACQCACKAIIQQFHDQAgAigCDCACKAIQELiAgIAADAELQQEQnoCAgABCAhCMgICAABoLAkACQCACKAIYQQFHDQAgAigCHCACKAIgELmAgIAADAELQQIQnoCAgABCAhCMgICAABoLIAJBKGpBCGogAkEIakEIaigCADYCACACQTxqIAJBGGpBCGooAgA2AgAgAiACKQMINwMoIAIgAikDGDcCNEGkgsCAAEEPEL6AgIAAENGAgIAAIQAgAkEoahDbgICAACEBIAIgAkE0ahDbgICAADcDSCACIAE3A0AgAEHIgsCAAEECIAJBwABqQQIQ0oCAgAAQi4CAgAAaIAJB0ABqJICAgIAAQgIPCwALaAEBfyOAgICAAEEQayICJICAgIAAAkACQCABQgJR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aW50ZXIgYWRkcmVzcyBub3QgaW4gdGhlIG1pbnRlcnMgbGlzdCAoZS5nLiB3aGVuIGRlYWN0aXZhdGluZykAAAAADk1pbnRlck5vdEZvdW5kAAAAAAACAAAAK0NhbGxlciBpcyBub3QgYXV0aG9yaXplZCBmb3IgdGhpcyBvcGVyYXRpb24AAAAADFVuYXV0aG9yaXplZAAAAAMAAAAAAAAAAAAAAARtaW50AAAAAwAAAAAAAAACdG8AAAAAABMAAAAAAAAABmFtb3VudAAAAAAACwAAAAAAAAAJb3BlcmF0aW9uAAAAAAAAEwAAAAAAAAAAAAAA80NvbnN0cnVjdHMgdGhlIFNBQyBtYW5hZ2VyIGNvbnRyYWN0LgoKIyBBcmd1bWVudHMKKiBgc2FjX3Rva2VuYCAtIFRoZSB1bmRlcmx5aW5nIFN0ZWxsYXIgQXNzZXQgQ29udHJhY3QgYWRkcmVzcwoqIGBvd25lcmAgLSBUaGUgaW5pdGlhbCBvd25lciBhZGRyZXNzIChmb3IgdXBncmFkZXMsIG93bmVyIG9wcykKCk1pbnRlcnMgY2FuIGJlIHNldCBzZXBhcmF0ZWx5IHZpYSBgc2V0X21pbnRlcmAgYWZ0ZXIgY29uc3RydWN0aW9uLgAAAAANX19jb25zdHJ1Y3RvcgAAAAAAAAIAAAAAAAAACXNhY190b2tlbgAAAAAAABMAAAAAAAAABW93bmVyAAAAAAAAEwAAAAAAAAAAAAAASURlbGVnYXRlcyB0byB0aGUgdW5kZXJseWluZyBTQUMgdG8gY2xhd2JhY2sgYGFtb3VudGAgZnJvbSBgZnJvbWAgYWNjb3VudC4AAAAAAAAIY2xhd2JhY2sAAAACAAAAAAAAAARmcm9tAAAAEwAAAAAAAAAGYW1vdW50AAAAAAALAAAAAAAAAAAAAABoRGVsZWdhdGVzIHRvIHRoZSB1bmRlcmx5aW5nIFNBQyBgc2V0X2FkbWluYCB0byByZWxlYXNlIHRoZSBhZG1pbiByb2xlIGZyb20gdGhlIGN1cnJlbnQgY29udHJhY3QgdG8gYHRvYC4AAAARcmVsZWFzZV9zYWNfYWRtaW4AAAAAAAABAAAAAAAAAAJ0bwAAAAAAEwAAAAAAAAAAAAAAZkRlbGVnYXRlcyB0byB0aGUgdW5kZXJseWluZyBTQUMgYHNldF9hdXRob3JpemVkYCB0byBzZXQgd2hldGhlciBgaWRgIGlzIGF1dGhvcml6ZWQgdG8gdXNlIGl0cyBiYWxhbmNlLgAAAAAADnNldF9hdXRob3JpemVkAAAAAAACAAAAAAAAAAJpZAAAAAAAEwAAAAAAAAAJYXV0aG9yaXplAAAAAAAAAQAAAAAAAAAAAAAAPkFkZHMgKGBhY3RpdmUgPSB0cnVlYCkgb3IgcmVtb3ZlcyAoYGFjdGl2ZSA9IGZhbHNlYCkgYSBtaW50ZXIuAAAAAAAKc2V0X21pbnRlcgAAAAAAAgAAAAAAAAAGbWludGVyAAAAAAATAAAAAAAAAAZhY3RpdmUAAAAAAAEAAAAAAAAAAAAAADxSZXR1cm5zIHRoZSB1bmRlcmx5aW5nIFNBQyAoU3RlbGxhciBBc3NldCBDb250cmFjdCkgYWRkcmVzcy4AAAAOdW5kZXJseWluZ19zYWMAAAAAAAAAAAABAAAAEwAAAAAAAAA2UmV0dXJucyB0aGUgbGlzdCBvZiBhZGRyZXNzZXMgYXV0aG9yaXplZCB0byBjYWxsIG1pbnQuAAAAAAAHbWludGVycwAAAAAAAAAAAQAAA+oAAAATAAAAAAAAAGxVcGdyYWRlcyB0aGUgY29udHJhY3QgdG8gbmV3IFdBU00gYnl0ZWNvZGUuClNldHMgYSBtaWdyYXRpb24gZmxhZyB0aGF0IG11c3QgYmUgY2xlYXJlZCBieSBjYWxsaW5nIGBtaWdyYXRlYC4AAAAHdXBncmFkZQAAAAABAAAAAAAAAA1uZXdfd2FzbV9oYXNoAAAAAAAD7gAAACAAAAAAAAAAAAAAAIdSdW5zIG1pZ3JhdGlvbiBsb2dpYyBhZnRlciBhbiB1cGdyYWRlLgpQYXJzZXMgWERSLWVuY29kZWQgYG1pZ3JhdGlvbl9kYXRhYCBhbmQgY2FsbHMgYF9fbWlncmF0ZWAuIENsZWFycyB0aGUgbWlncmF0aW9uIGZsYWcgb24gc3VjY2Vzcy4AAAAAB21pZ3JhdGUAAAAAAQAAAAAAAAAObWlncmF0aW9uX2RhdGEAAAAAAA4AAAAAAAAAAAAAAAAAAAAKYXV0aG9yaXplcgAAAAAAAAAAAAEAAAATAAAAAAAAAD5SZXR1cm5zIHRoZSBjdXJyZW50IG93bmVyIGFkZHJlc3MsIG9yIE5vbmUgaWYgbm8gb3duZXIgaXMgc2V0LgAAAAAABW93bmVyAAAAAAAAAAAAAAEAAAPoAAAAEwAAAAAAAABZUmV0dXJucyB0aGUgcGVuZGluZyBvd25lciBhZGRyZXNzIGZvciAyLXN0ZXAgdHJhbnNmZXIsIG9yIE5vbmUgaWYgbm8gdHJhbnNmZXIgaXMgcGVuZGluZy4AAAAAAAANcGVuZGluZ19vd25lcgAAAAAAAAAAAAABAAAD6AAAABMAAAAAAAABK1RyYW5zZmVycyBvd25lcnNoaXAgaW1tZWRpYXRlbHkgdG8gYSBuZXcgYWRkcmVzcy4KClVzZSB3aXRoIGNhdXRpb24gLSBpZiB5b3UgdHJhbnNmZXIgdG8gYSB3cm9uZyBhZGRyZXNzLCBvd25lcnNoaXAgaXMgbG9zdCBmb3JldmVyLgpDb25zaWRlciB1c2luZyBgcHJvcG9zZV9vd25lcnNoaXBfdHJhbnNmZXJgIGluc3RlYWQuCgojIFBhbmljcwotIGBPd25lck5vdFNldGAgaWYgbm8gb3duZXIgaXMgY3VycmVudGx5IHNldAotIGBUcmFuc2ZlckluUHJvZ3Jlc3NgIGlmIGEgMi1zdGVwIHRyYW5zZmVyIGlzIGluIHByb2dyZXNzAAAAABJ0cmFuc2Zlcl9vd25lcnNoaXAAAAAAAAEAAAAAAAAACW5ld19vd25lcgAAAAAAABMAAAAAAAAAAAAAAlxQcm9wb3NlcyBhbiBvd25lcnNoaXAgdHJhbnNmZXIgdG8gYSBuZXcgYWRkcmVzcy4KClRoZSBuZXcgb3duZXIgbXVzdCBjYWxsIGBhY2NlcHRfb3duZXJzaGlwKClgIHdpdGhpbiBgdHRsYCBsZWRnZXJzCnRvIGNvbXBsZXRlIHRoZSB0cmFuc2Zlci4gVGhlIHBlbmRpbmcgdHJhbnNmZXIgd2lsbCBhdXRvbWF0aWNhbGx5IGV4cGlyZSBhZnRlci4KCiMgQXJndW1lbnRzCi0gYG5ld19vd25lcmAgLSBUaGUgcHJvcG9zZWQgbmV3IG93bmVyCi0gYHR0bGAgLSBOdW1iZXIgb2YgbGVkZ2VycyB0aGUgbmV3IG93bmVyIGhhcyB0byBhY2NlcHQuClVzZSBgMGAgdG8gY2FuY2VsIGEgcGVuZGluZyB0cmFuc2ZlciAobmV3X293bmVyIG11c3QgbWF0Y2ggcGVuZGluZykuCgojIFBhbmljcwotIGBPd25lck5vdFNldGAgaWYgbm8gb3duZXIgaXMgY3VycmVudGx5IHNldAotIGBOb1BlbmRpbmdUcmFuc2ZlcmAgd2hlbiBjYW5jZWxsaW5nIGFuZCBubyBwZW5kaW5nIHRyYW5zZmVyIGV4aXN0cwotIGBJbnZhbGlkVHRsYCBpZiB0dGwgZXhjZWVkcyBtYXggVFRMCi0gYEludmFsaWRQZW5kaW5nT3duZXJgIHdoZW4gY2FuY2VsbGluZyB3aXRoIHdyb25nIG5ld19vd25lciBhZGRyZXNzAAAAGnByb3Bvc2Vfb3duZXJzaGlwX3RyYW5zZmVyAAAAAAACAAAAAAAAAAluZXdfb3duZXIAAAAAAAATAAAAAAAAAAN0dGwAAAAABAAAAAAAAAAAAAAAuUFjY2VwdHMgYSBwZW5kaW5nIDItc3RlcCBvd25lcnNoaXAgdHJhbnNmZXIuCgpNdXN0IGJlIGNhbGxlZCBieSB0aGUgcGVuZGluZyBvd25lciBiZWZvcmUgdGhlIFRUTCBleHBpcmVzLgoKIyBQYW5pY3MKLSBgTm9QZW5kaW5nVHJhbnNmZXJgIGlmIHRoZXJlIGlzIG5vIHBlbmRpbmcgdHJhbnNmZXIgKG9yIGl0IGV4cGlyZWQpAAAAAAAAEGFjY2VwdF9vd25lcnNoaXAAAAAAAAAAAAAAAAAAAACkUGVybWFuZW50bHkgcmVub3VuY2VzIG93bmVyc2hpcC4KCiMgUGFuaWNzCi0gYE93bmVyTm90U2V0YCBpZiBubyBvd25lciBpcyBjdXJyZW50bHkgc2V0Ci0gYFRyYW5zZmVySW5Qcm9ncmVzc2AgaWYgYSAyLXN0ZXAgdHJhbnNmZXIgaXMgaW4gcHJvZ3Jlc3MgKGNhbmNlbCBpdCBmaXJzdCkAAAAScmVub3VuY2Vfb3duZXJzaGlwAAAAAAAAAAAAAAAAAAAAAAClRXh0ZW5kcyB0aGUgaW5zdGFuY2UgVFRMLgoKIyBBcmd1bWVudHMKCiogYHRocmVzaG9sZGAgLSBUaGUgdGhyZXNob2xkIHRvIGV4dGVuZCB0aGUgVFRMIChpZiBjdXJyZW50IFRUTCBpcyBiZWxvdyB0aGlzLCBleHRlbmQpLgoqIGBleHRlbmRfdG9gIC0gVGhlIFRUTCB0byBleHRlbmQgdG8uAAAAAAAAE2V4dGVuZF9pbnN0YW5jZV90dGwAAAAAAgAAAAAAAAAJdGhyZXNob2xkAAAAAAAABAAAAAAAAAAJZXh0ZW5kX3RvAAAAAAAABAAAAAAAAAAAAAABj1NldHMgVFRMIGNvbmZpZ3MgZm9yIGluc3RhbmNlIGFuZCBwZXJzaXN0ZW50IHN0b3JhZ2UuCgotIGBOb25lYCB2YWx1ZXMgcmVtb3ZlIHRoZSBjb3JyZXNwb25kaW5nIGNvbmZpZyAoZGlzYWJsZXMgYXV0by1leHRlbnNpb24gZm9yIHRoYXQgdHlwZSkKLSBWYWxpZGF0ZXMgdGhhdCBgdGhyZXNob2xkIDw9IGV4dGVuZF90byA8PSBNQVhfVFRMYAoKIyBBcmd1bWVudHMKLSBgaW5zdGFuY2VgIC0gVFRMIGNvbmZpZyBmb3IgaW5zdGFuY2Ugc3RvcmFnZQotIGBwZXJzaXN0ZW50YCAtIFRUTCBjb25maWcgZm9yIHBlcnNpc3RlbnQgc3RvcmFnZQoKIyBQYW5pY3MKLSBgVHRsQ29uZmlnRnJvemVuYCBpZiBjb25maWdzIGFyZSBmcm96ZW4KLSBgSW52YWxpZFR0bENvbmZpZ2AgaWYgdmFsaWRhdGlvbiBmYWlscwAAAAAPc2V0X3R0bF9jb25maWdzAAAAAAIAAAAAAAAACGluc3RhbmNlAAAD6AAAB9AAAAAJVHRsQ29uZmlnAAAAAAAAAAAAAApwZXJzaXN0ZW50AAAAAAPoAAAH0AAAAAlUdGxDb25maWcAAAAAAAAAAAAAAAAAAEhSZXR1cm5zIHRoZSBjdXJyZW50IFRUTCBjb25maWdzIGFzIChpbnN0YW5jZV9jb25maWcsIHBlcnNpc3RlbnRfY29uZmlnKS4AAAALdHRsX2NvbmZpZ3MAAAAAAAAAAAEAAAPtAAAAAgAAA+gAAAfQAAAACVR0bENvbmZpZwAAAAAAA+gAAAfQAAAACVR0bENvbmZpZwAAAAAAAAAAAADhUGVybWFuZW50bHkgZnJlZXplcyBUVEwgY29uZmlncywgcHJldmVudGluZyBhbnkgZnV0dXJlIG1vZGlmaWNhdGlvbnMu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b21wb3NlIG1lc3NhZ2Ugbm90IGZvdW5kIGZvciB0aGUgZ2l2ZW4gR1VJRCBhbmQgaW5kZXgAAAAAAA9Db21wb3NlTm90Rm91bmQAAAAAAwAAADpEZWZhdWx0IHJlY2VpdmUgbGlicmFyeSBpcyBub3Qgc2V0IGZvciB0aGUgc291cmNlIGVuZHBvaW50AAAAAAAcRGVmYXVsdFJlY2VpdmVMaWJVbmF2YWlsYWJsZQAAAAQAAAA8RGVmYXVsdCBzZW5kIGxpYnJhcnkgaXMgbm90IHNldCBmb3IgdGhlIGRlc3RpbmF0aW9uIGVuZHBvaW50AAAAGURlZmF1bHRTZW5kTGliVW5hdmFpbGFibGUAAAAAAAAFAAAAL1N1cHBsaWVkIG5hdGl2ZSB0b2tlbiBmZWUgaXMgbGVzcyB0aGFuIHJlcXVpcmVkAAAAABVJbnN1ZmZpY2llbnROYXRpdmVGZWUAAAAAAAAGAAAALFN1cHBsaWVkIFpSTyB0b2tlbiBmZWUgaXMgbGVzcyB0aGFuIHJlcXVpcmVkAAAAEkluc3VmZmljaWVudFpyb0ZlZQAAAAAABwAAACtUaW1lb3V0IGV4cGlyeSBpcyBpbnZhbGlkIChhbHJlYWR5IGV4cGlyZWQpAAAAAA1JbnZhbGlkRXhwaXJ5AAAAAAAACAAAACBGZWUgYW1vdW50IGlzIGludmFsaWQgKG5lZ2F0aXZlKQAAABBJbnZhbGlkRmVlQW1vdW50AAAACQAAACtDb21wb3NlIGluZGV4IGV4Y2VlZHMgbWF4aW11bSBhbGxvd2VkIHZhbHVlAAAAAAxJbnZhbGlkSW5kZXgAAAAKAAAALE5vbmNlIGlzIGludmFsaWQgZm9yIHRoZSByZXF1ZXN0ZWQgb3BlcmF0aW9uAAAADEludmFsaWROb25jZQAAAAsAAAAwUGF5bG9hZCBoYXNoIGlzIGludmFsaWQgKGVtcHR5IGhhc2ggbm90IGFsbG93ZWQpAAAAEkludmFsaWRQYXlsb2FkSGFzaAAAAAAADAAAAEFSZWNlaXZlIGxpYnJhcnkgaXMgbm90IHZhbGlkIGZvciB0aGUgcmVjZWl2ZXIgYW5kIHNvdXJjZSBlbmRwb2ludAAAAAAAABVJbnZhbGlkUmVjZWl2ZUxpYnJhcnkAAAAAAAANAAAAMU9wZXJhdGlvbiByZXF1aXJlcyBhIG5vbi1kZWZhdWx0IChjdXN0b20pIGxpYnJhcnkAAAAAAAART25seU5vbkRlZmF1bHRMaWIAAAAAAAAOAAAAJ0xpYnJhcnkgbXVzdCBzdXBwb3J0IHJlY2VpdmluZyBtZXNzYWdlcwAAAAAOT25seVJlY2VpdmVMaWIAAAAAAA8AAAAsTGlicmFyeSBtdXN0IGJlIHJlZ2lzdGVyZWQgd2l0aCB0aGUgZW5kcG9pbnQAAAART25seVJlZ2lzdGVyZWRMaWIAAAAAAAAQAAAAJUxpYnJhcnkgbXVzdCBzdXBwb3J0IHNlbmRpbmcgbWVzc2FnZXMAAAAAAAALT25seVNlbmRMaWIAAAAAEQAAADlNZXNzYWdpbmcgcGF0aCBjYW5ub3QgYmUgaW5pdGlhbGl6ZWQgZm9yIHRoZSBnaXZlbiBvcmlnaW4AAAAAAAAUUGF0aE5vdEluaXRpYWxpemFibGUAAAASAAAAL01lc3NhZ2UgY2Fubm90IGJlIHZlcmlmaWVkIGZvciB0aGUgZ2l2ZW4gb3JpZ2luAAAAABFQYXRoTm90VmVyaWZpYWJsZQAAAAAAABMAAAArUGF5bG9hZCBoYXNoIGRvZXMgbm90IG1hdGNoIHRoZSBzdG9yZWQgaGFzaAAAAAATUGF5bG9hZEhhc2hOb3RGb3VuZAAAAAAUAAAAJ05ldyB2YWx1ZSBpcyB0aGUgc2FtZSBhcyBleGlzdGluZyB2YWx1ZQAAAAAJU2FtZVZhbHVlAAAAAAAAFQAAAC9DYWxsZXIgaXMgbm90IGF1dGhvcml6ZWQgKG5vdCBPQXBwIG9yIGRlbGVnYXRlKQAAAAAMVW5hdXRob3JpemVkAAAAFgAAACtFbmRwb2ludCBJRCBpcyBub3Qgc3VwcG9ydGVkIGJ5IHRoZSBsaWJyYXJ5AAAAAA5VbnN1cHBvcnRlZEVpZAAAAAAAFwAAADlaUk8gZmVlIG11c3QgYmUgZ3JlYXRlciB0aGFuIHplcm8gd2hlbiBwYXlfaW5fenJvIGlzIHRydWUAAAAAAAAKWmVyb1pyb0ZlZQAAAAAAGAAAABxaUk8gdG9rZW4gYWRkcmVzcyBpcyBub3Qgc2V0AAAADlpyb1VuYXZhaWxhYmxlAAAAAAAZAAAAAQAAAC1QYXJhbWV0ZXJzIGZvciBzZW5kaW5nIGEgY3Jvc3MtY2hhaW4gbWVzc2FnZS4AAAAAAAAAAAAAD01lc3NhZ2luZ1BhcmFtcwAAAAAFAAAAK0Rlc3RpbmF0aW9uIGVuZHBvaW50IElEIChjaGFpbiBpZGVudGlmaWVyKS4AAAAAB2RzdF9laWQAAAAABAAAABxUaGUgbWVzc2FnZSBwYXlsb2FkIHRvIHNlbmQuAAAAB21lc3NhZ2UAAAAADgAAACFFbmNvZGVkIGV4ZWN1dG9yIGFuZCBEVk4gb3B0aW9ucy4AAAAAAAAHb3B0aW9ucwAAAAAOAAAAOVdoZXRoZXIgdG8gcGF5IGZlZXMgaW4gWlJPIHRva2VuIGluc3RlYWQgb2YgbmF0aXZlIHRva2VuLgAAAAAAAApwYXlfaW5fenJvAAAAAAABAAAANVJlY2VpdmVyIGFkZHJlc3Mgb24gdGhlIGRlc3RpbmF0aW9uIGNoYWluICgzMiBieXRlcykuAAAAAAAACHJlY2VpdmVyAAAD7gAAACAAAAABAAAATVNvdXJjZSBtZXNzYWdlIGluZm9ybWF0aW9uIGlkZW50aWZ5aW5nIHdoZXJlIGEgY3Jvc3MtY2hhaW4gbWVzc2FnZSBjYW1lIGZyb20uAAAAAAAAAAAAAAZPcmlnaW4AAAAAAAMAAAAXTm9uY2UgZm9yIHRoaXMgcGF0aHdheS4AAAAABW5vbmNlAAAAAAAABgAAAC5TZW5kZXIgYWRkcmVzcyBvbiB0aGUgc291cmNlIGNoYWluICgzMiBieXRlcykuAAAAAAAGc2VuZGVyAAAAAAPuAAAAIAAAACZTb3VyY2UgZW5kcG9pbnQgSUQgKGNoYWluIGlkZW50aWZpZXIpLgAAAAAAB3NyY19laWQAAAAABAAAAAEAAAAoRmVlIHN0cnVjdHVyZSBmb3IgY3Jvc3MtY2hhaW4gbWVzc2FnaW5nLgAAAAAAAAAMTWVzc2FnaW5nRmVlAAAAAgAAAB9GZWUgcGFpZCBpbiBuYXRpdmUgdG9rZW4gKFhMTSkuAAAAAApuYXRpdmVfZmVlAAAAAAALAAAAKEZlZSBwYWlkIGluIFpSTyB0b2tlbiAoTGF5ZXJaZXJvIHRva2VuKS4AAAAHenJvX2ZlZQAAAAALAAAAAQAAAEJSZWNlaXB0IHJldHVybmVkIGFmdGVyIHN1Y2Nlc3NmdWxseSBzZW5kaW5nIGEgY3Jvc3MtY2hhaW4gbWVzc2FnZS4AAAAAAAAAAAAQTWVzc2FnaW5nUmVjZWlwdAAAAAMAAAApVGhlIGZlZXMgY2hhcmdlZCBmb3Igc2VuZGluZyB0aGUgbWVzc2FnZS4AAAAAAAADZmVlAAAAB9AAAAAMTWVzc2FnaW5nRmVlAAAAK0dsb2JhbGx5IHVuaXF1ZSBpZGVudGlmaWVyIGZvciB0aGUgbWVzc2FnZS4AAAAABGd1aWQAAAPuAAAAIAAAACRUaGUgb3V0Ym91bmQgbm9uY2UgZm9yIHRoaXMgcGF0aHdheS4AAAAFbm9uY2UAAAAAAAAGAAAAAgAAADhUeXBlIG9mIG1lc3NhZ2UgbGlicmFyeSBpbmRpY2F0aW5nIHN1cHBvcnRlZCBvcGVyYXRpb25zLgAAAAAAAAAOTWVzc2FnZUxpYlR5cGUAAAAAAAMAAAAAAAAAH1N1cHBvcnRzIG9ubHkgc2VuZGluZyBtZXNzYWdlcy4AAAAABFNlbmQAAAAAAAAAIVN1cHBvcnRzIG9ubHkgcmVjZWl2aW5nIG1lc3NhZ2VzLgAAAAAAAAdSZWNlaXZlAAAAAAAAAAAtU3VwcG9ydHMgYm90aCBzZW5kaW5nIGFuZCByZWNlaXZpbmcgbWVzc2FnZXMuAAAAAAAADlNlbmRBbmRSZWNlaXZlAAAAAAABAAAAt1ZlcnNpb24gaW5mb3JtYXRpb24gZm9yIGEgbWVzc2FnZSBsaWJyYXJ5LgoKTm90ZTogYG1pbm9yYCBhbmQgYGVuZHBvaW50X3ZlcnNpb25gIHVzZSBgdTMyYCBpbnN0ZWFkIG9mIGB1OGAgYmVjYXVzZSBTdGVsbGFyIGRvZXMgbm90CnN1cHBvcnQgYHU4YCB0eXBlcyBpbiBjb250cmFjdCBpbnRlcmZhY2UgZnVuY3Rpb25zLgAAAAAAAAAAEU1lc3NhZ2VMaWJWZXJzaW9uAAAAAAAAAwAAADNFbmRwb2ludCB2ZXJzaW9uIChzaG91bGQgbm90IGV4Y2VlZCB1ODo6TUFYID0gMjU1KS4AAAAAEGVuZHBvaW50X3ZlcnNpb24AAAAEAAAAFU1ham9yIHZlcnNpb24gbnVtYmVyLgAAAAAAAAVtYWpvcgAAAAAAAAYAAAA3TWlub3IgdmVyc2lvbiBudW1iZXIgKHNob3VsZCBub3QgZXhjZWVkIHU4OjpNQVggPSAyNTUpLgAAAAAFbWlub3IAAAAAAAAEAAAAAQAAADZUaW1lb3V0IGNvbmZpZ3VyYXRpb24gZm9yIHJlY2VpdmUgbGlicmFyeSB0cmFuc2l0aW9ucy4AAAAAAAAAAAAHVGltZW91dAAAAAACAAAAM1VuaXggdGltZXN0YW1wIGluIHNlY29uZHMgd2hlbiB0aGUgdGltZW91dCBleHBpcmVzLgAAAAAGZXhwaXJ5AAAAAAAGAAAAQ1RoZSBvbGQgbGlicmFyeSBhZGRyZXNzIHRoYXQgcmVtYWlucyB2YWxpZCBkdXJpbmcgdGhlIGdyYWNlIHBlcmlvZC4AAAAAA2xpYgAAAAATAAAAAQAAADVQYXJhbWV0ZXJzIGZvciBzZXR0aW5nIG1lc3NhZ2UgbGlicmFyeSBjb25maWd1cmF0aW9uLgAAAAAAAAAAAAAOU2V0Q29uZmlnUGFyYW0AAAAAAAMAAAAfWERSLWVuY29kZWQgY29uZmlndXJhdGlvbiBkYXRhLgAAAAAGY29uZmlnAAAAAAAOAAAAMFRoZSB0eXBlIG9mIGNvbmZpZ3VyYXRpb24gKGUuZy4sIGV4ZWN1dG9yLCBVTE4pLgAAAAtjb25maWdfdHlwZQAAAAAEAAAAJ1RoZSBlbmRwb2ludCBJRCB0aGlzIGNvbmZpZyBhcHBsaWVzIHRvLgAAAAADZWlkAAAAAAQAAAABAAAAMVJlc29sdmVkIGxpYnJhcnkgaW5mb3JtYXRpb24gd2l0aCBkZWZhdWx0IHN0YXR1cy4AAAAAAAAAAAAAD1Jlc29sdmVkTGlicmFyeQAAAAACAAAARFdoZXRoZXIgdGhpcyBpcyB0aGUgZGVmYXVsdCBsaWJyYXJ5ICh0cnVlKSBvciBPQXBwLXNwZWNpZmljIChmYWxzZSkuAAAACmlzX2RlZmF1bHQAAAAAAAEAAAAdVGhlIHJlc29sdmVkIGxpYnJhcnkgYWRkcmVzcy4AAAAAAAADbGliAAAAABMAAAABAAAASE91dGJvdW5kIHBhY2tldCBjb250YWluaW5nIGFsbCBpbmZvcm1hdGlvbiBmb3IgY3Jvc3MtY2hhaW4gdHJhbnNtaXNzaW9uLgAAAAAAAAAOT3V0Ym91bmRQYWNrZXQAAAAAAAcAAAAYRGVzdGluYXRpb24gZW5kcG9pbnQgSUQuAAAAB2RzdF9laWQAAAAABAAAACxHbG9iYWxseSB1bmlxdWUgaWRlbnRpZmllciBmb3IgdGhpcyBtZXNzYWdlLgAAAARndWlkAAAD7gAAACAAAAAUVGhlIG1lc3NhZ2UgcGF5bG9hZC4AAAAHbWVzc2FnZQAAAAAOAAAAIE91dGJvdW5kIG5vbmNlIGZvciB0aGlzIHBhdGh3YXkuAAAABW5vbmNlAAAAAAAABgAAADFSZWNlaXZlciBhZGRyZXNzIG9uIGRlc3RpbmF0aW9uIGNoYWluICgzMiBieXRlcykuAAAAAAAACHJlY2VpdmVyAAAD7gAAACAAAAAfU2VuZGVyIGFkZHJlc3Mgb24gc291cmNlIGNoYWluLgAAAAAGc2VuZGVyAAAAAAATAAAAE1NvdXJjZSBlbmRwb2ludCBJRC4AAAAAB3NyY19laWQAAAAABAAAAAEAAAArQSBmZWUgcmVjaXBpZW50IHdpdGggdGhlIGFtb3VudCB0byBiZSBwYWlkLgAAAAAAAAAADEZlZVJlY2lwaWVudAAAAAIAAAAVQW1vdW50IG9mIGZlZSB0byBwYXkuAAAAAAAABmFtb3VudAAAAAAACwAAAB9UaGUgYWRkcmVzcyB0byBzZW5kIHRoZSBmZWUgdG8uAAAAAAJ0bwAAAAAAEwAAAAEAAAA8UmVzdWx0IG9mIHNlbmQgb3BlcmF0aW9uIGNvbnRhaW5pbmcgZmVlcyBhbmQgZW5jb2RlZCBwYWNrZXQuAAAAAAAAAA1GZWVzQW5kUGFja2V0AAAAAAAAAwAAACpUaGUgZW5jb2RlZCBwYWNrZXQgcmVhZHkgZm9yIHRyYW5zbWlzc2lvbi4AAAAAAA5lbmNvZGVkX3BhY2tldAAAAAAADgAAAD9MaXN0IG9mIG5hdGl2ZSB0b2tlbiBmZWUgcmVjaXBpZW50cyAoZXhlY3V0b3IsIERWTnMsIHRyZWFzdXJ5KS4AAAAAFW5hdGl2ZV9mZWVfcmVjaXBpZW50cwAAAAAAA+oAAAfQAAAADEZlZVJlY2lwaWVudAAAACxMaXN0IG9mIFpSTyB0b2tlbiBmZWUgcmVjaXBpZW50cyAodHJlYXN1cnkpLgAAABJ6cm9fZmVlX3JlY2lwaWVudHMAAAAAA+oAAAfQAAAADEZlZVJlY2lwaWVudAAAAAIAAAAAAAAAAAAAAA9PQXBwQ29yZVN0b3JhZ2UAAAAAAgAAAAAAAAAAAAAACEVuZHBvaW50AAAAAQAAAAAAAAAEUGVlcgAAAAEAAAAEAAAABQAAAAAAAAAAAAAAB1BlZXJTZXQAAAAAAQAAAAhwZWVyX3NldAAAAAIAAAAAAAAAA2VpZAAAAAAEAAAAAAAAAAAAAAAEcGVlcgAAA+gAAAPuAAAAIAAAAAAAAAACAAAAAQAAAAAAAAAAAAAAE0VuZm9yY2VkT3B0aW9uUGFyYW0AAAAAAwAAAAAAAAADZWlkAAAAAAQAAAAAAAAACG1zZ190eXBlAAAABAAAAAAAAAAHb3B0aW9ucwAAAAPoAAAADgAAAAIAAAAAAAAAAAAAABdPQXBwT3B0aW9uc1R5cGUzU3RvcmFnZQAAAAABAAAAAQAAAAAAAAAPRW5mb3JjZWRPcHRpb25zAAAAAAIAAAAEAAAABAAAAAUAAAAAAAAAAAAAABFFbmZvcmNlZE9wdGlvblNldAAAAAAAAAEAAAATZW5mb3JjZWRfb3B0aW9uX3NldAAAAAABAAAAAAAAABBlbmZvcmNlZF9vcHRpb25zAAAD6gAAB9AAAAATRW5mb3JjZWRPcHRpb25QYXJhbQAAAAAAAAAAAgAAAAIAAAKqUmVwcmVzZW50cyBhIGZlZSBwYXllciBhZGRyZXNzIHdpdGggZXhwbGljaXQgYXV0aG9yaXphdGlvbiBzdGF0ZS4KClRoaXMgZW51bSBmb3JjZXMgY2FsbGVycyBvZiBgX19sel9zZW5kYCB0byBleHBsaWNpdGx5IGRlY2xhcmUgd2hldGhlcgpgcmVxdWlyZV9hdXRoKClgIGhhcyBhbHJlYWR5IGJlZW4gY2FsbGVkIGZvciB0aGUgZmVlIHBheWVyIGFkZHJlc3MuClRoaXMgcHJldmVudHMgdGhlIGNvbW1vbiBtaXN0YWtlIG9mIGZvcmdldHRpbmcgdG8gYXV0aG9yaXplIHRoZSBmZWUgcGF5ZXIuCgojIFZhcmlhbnRzCi0gYFVudmVyaWZpZWRgIOKAlCBTYWZlIGRlZmF1bHQuIGBfX2x6X3NlbmRgIHdpbGwgY2FsbCBgcmVxdWlyZV9hdXRoKClgIG9uIHRoZSBhZGRyZXNzLgpVc2UgdGhpcyB3aGVuIHRoZSBjYWxsZXIgaGFzICoqbm90KiogYWxyZWFkeSBhdXRob3JpemVkIHRoZSBmZWUgcGF5ZXIuCi0gYFZlcmlmaWVkYCDigJQgQ2FsbGVyIGFzc2VydHMgdGhhdCBgcmVxdWlyZV9hdXRoKClgIGhhcyBhbHJlYWR5IGJlZW4gY2FsbGVkLgpVc2UgdGhpcyB0byBhdm9pZCBhIGR1cGxpY2F0ZSBgcmVxdWlyZV9hdXRoKClgIG5vZGUgaW4gdGhlIFNvcm9iYW4gYXV0aCB0cmVlCihlLmcuLCB3aGVuIHRoZSBzYW1lIGFkZHJlc3Mgd2FzIGFscmVhZHkgYXV0aG9yaXplZCBhcyB0aGUgbWVzc2FnZSBzZW5kZXIpLgAAAAAAAAAAAAhGZWVQYXllcgAAAAIAAAABAAAAqlRoZSBmZWUgcGF5ZXIgaGFzICoqbm90KiogYmVlbiBhdXRob3JpemVkIHlldC4KYF9fbHpfc2VuZGAgd2lsbCBjYWxsIGBmZWVfcGF5ZXIucmVxdWlyZV9hdXRoKClgIGJlZm9yZSB0cmFuc2ZlcnJpbmcgZmVlcy4KVGhpcyBpcyB0aGUgc2FmZSBkZWZhdWx0IOKAlCB1c2UgdGhpcyBpZiB1bnN1cmUuAAAAAAAKVW52ZXJpZmllZAAAAAAAAQAAABMAAAABAAABb1RoZSBmZWUgcGF5ZXIgaGFzICoqYWxyZWFkeSoqIGJlZW4gYXV0aG9yaXplZCBieSB0aGUgY2FsbGVyIHZpYSBgcmVxdWlyZV9hdXRoKClgLgpgX19sel9zZW5kYCB3aWxsIHNraXAgdGhlIGF1dGggY2hlY2sgdG8gYXZvaWQgY3JlYXRpbmcgYSBkdXBsaWNhdGUgYXV0aCBub2RlCmluIHRoZSBTb3JvYmFuIGF1dGhvcml6YXRpb24gdHJlZS4KCiMgU2FmZXR5Ck9ubHkgdXNlIHRoaXMgdmFyaWFudCBpZiB5b3UgaGF2ZSBhbHJlYWR5IGNhbGxlZCBgcmVxdWlyZV9hdXRoKClgIG9uIHRoaXMgYWRkcmVzcwppbiB0aGUgY3VycmVudCBjb250cmFjdCBpbnZvY2F0aW9uLiBNaXN1c2UgbWF5IGFsbG93IHVuYXV0aG9yaXplZCBmZWUgZGVkdWN0aW9ucy4AAAAACFZlcmlmaWVkAAAAAQAAABMAAAAEAAAAFE9BcHBFcnJvcjogMjAwMC0yMDk5AAAAAAAAAAlPQXBwRXJyb3IAAAAAAAAEAAAAAAAAAA5JbnZhbGlkT3B0aW9ucwAAAAAH0AAAAAAAAAAGTm9QZWVyAAAAAAfRAAAAAAAAAAhPbmx5UGVlcgAAB9IAAAAAAAAAE1pyb1Rva2VuVW5hdmFpbGFibGUAAAAH0wAAAAIAAAAAAAAAAAAAAA1PRlRGZWVTdG9yYWdlAAAAAAAAAwAAAAAAAAAAAAAADURlZmF1bHRGZWVCcHMAAAAAAAABAAAAAAAAAAZGZWVCcHMAAAAAAAEAAAAEAAAAAAAAAAAAAAARRmVlRGVwb3NpdEFkZHJlc3MAAAAAAAAEAAAAAAAAAAAAAAALT0ZURmVlRXJyb3IAAAAAAwAAAAAAAAANSW52YWxpZEZlZUJwcwAAAAAADBwAAAAAAAAAGEludmFsaWRGZWVEZXBvc2l0QWRkcmVzcwAADB0AAAAAAAAACVNhbWVWYWx1ZQAAAAAADB4AAAAFAAAAAAAAAAAAAAAQRGVmYXVsdEZlZUJwc1NldAAAAAEAAAATZGVmYXVsdF9mZWVfYnBzX3NldAAAAAABAAAAS1RoZSBkZWZhdWx0IGZlZSByYXRlIGluIGJhc2lzIHBvaW50cywgb3IgTm9uZSBpZiB0aGUgZGVmYXVsdCBmZWUgaXMgcmVtb3ZlZAAAAAAHZmVlX2JwcwAAAAPoAAAABAAAAAAAAAACAAAABQAAAAAAAAAAAAAACUZlZUJwc1NldAAAAAAAAAEAAAALZmVlX2Jwc19zZXQAAAAAAgAAAAAAAAAHZHN0X2VpZAAAAAAEAAAAAAAAADtUaGUgZmVlIHJhdGUgaW4gYmFzaXMgcG9pbnRzLCBvciBOb25lIGlmIHRoZSBmZWUgaXMgcmVtb3ZlZAAAAAAHZmVlX2JwcwAAAAPoAAAABAAAAAAAAAACAAAABQAAAAAAAAAAAAAAFEZlZURlcG9zaXRBZGRyZXNzU2V0AAAAAQAAABdmZWVfZGVwb3NpdF9hZGRyZXNzX3NldAAAAAABAAAASVRoZSBhZGRyZXNzIHRvIGRlcG9zaXQgZmVlcyB0bywgb3IgTm9uZSB0byByZW1vdmUgdGhlIGZlZSBkZXBvc2l0IGFkZHJlc3MAAAAAAAATZmVlX2RlcG9zaXRfYWRkcmVzcwAAAAPoAAAAEwAAAAAAAAACAAAAAgAAAAAAAAAAAAAAEk9GVFBhdXNhYmxlU3RvcmFnZQAAAAAAAQAAAAAAAAAAAAAABlBhdXNlZAAAAAAABAAAAAAAAAAAAAAAEE9GVFBhdXNhYmxlRXJyb3IAAAACAAAAAAAAAAZQYXVzZWQAAAAADCYAAAAAAAAAFFBhdXNlU3RhdHVzVW5jaGFuZ2VkAAAMJwAAAAUAAAAAAAAAAAAAAAlQYXVzZWRTZXQAAAAAAAABAAAACnBhdXNlZF9zZXQAAAAAAAEAAAAAAAAABnBhdXNlZAAAAAAAAQAAAAAAAAACAAAAAgAAAAAAAAAAAAAACURpcmVjdGlvbgAAAAAAAAIAAAAAAAAAAAAAAAdJbmJvdW5kAAAAAAAAAAAAAAAACE91dGJvdW5kAAAAAgAAAAAAAAAAAAAABE1vZGUAAAACAAAAAAAAADNOZXQgcmF0ZSBsaW1pdDogcmVsZWFzZXMgZGVjcmVtZW50IGluLWZsaWdodCBhbW91bnQAAAAAA05ldAAAAAAAAAAAOUdyb3NzIHJhdGUgbGltaXQ6IHJlbGVhc2VzIGRvIG5vdCBhZmZlY3QgaW4tZmxpZ2h0IGFtb3VudAAAAAAAAAVHcm9zcwAAAAAAAAEAAAA5Q29uZmlndXJhdGlvbiBmb3IgcmF0ZSBsaW1pdGluZywgdXNlZCBhcyBpbnB1dCBwYXJhbWV0ZXIuAAAAAAAAAAAAAA9SYXRlTGltaXRDb25maWcAAAAAAwAAAAAAAAAFbGltaXQAAAAAAAALAAAAAAAAAARtb2RlAAAH0AAAAARNb2RlAAAAAAAAAA53aW5kb3dfc2Vjb25kcwAAAAAABgAAAAQAAAAAAAAAAAAAAA5SYXRlTGltaXRFcnJvcgAAAAAABQAAAAAAAAARRXhjZWVkZWRSYXRlTGltaXQAAAAAAAwwAAAAAAAAAA1JbnZhbGlkQW1vdW50AAAAAAAMMQAAAAAAAAAQSW52YWxpZFRpbWVzdGFtcAAADDIAAAAAAAAADUludmFsaWRDb25maWcAAAAAAAwzAAAAAAAAAAlTYW1lVmFsdWUAAAAAAAw0AAAABQAAAAAAAAAAAAAADFJhdGVMaW1pdFNldAAAAAEAAAAOcmF0ZV9saW1pdF9zZXQAAAAAAAMAAAAAAAAACWRpcmVjdGlvbgAAAAAAB9AAAAAJRGlyZWN0aW9uAAAAAAAAAAAAAAAAAAADZWlkAAAAAAQAAAAAAAAAQlRoZSByYXRlIGxpbWl0IGNvbmZpZ3VyYXRpb24sIG9yIE5vbmUgaWYgdGhlIHJhdGUgbGltaXQgaXMgcmVtb3ZlZAAAAAAABmNvbmZpZwAAAAAD6AAAB9AAAAAPUmF0ZUxpbWl0Q29uZmlnAAAAAAAAAAACAAAAAgAAABdUaGUgT0ZUIG9wZXJhdGlvbiB0eXBlLgAAAAAAAAAAB09mdFR5cGUAAAAAAgAAAAAAAAAnTG9jayB0b2tlbnMgb24gc2VuZCwgdW5sb2NrIG9uIHJlY2VpdmUuAAAAAApMb2NrVW5sb2NrAAAAAAABAAAAZUJ1cm4gdG9rZW5zIG9uIHNlbmQsIG1pbnQgb24gcmVjZWl2ZS4KVGhlIGFkZHJlc3MgaXMgdGhlIE1pbnRhYmxlIGNvbnRyYWN0IHVzZWQgZm9yIG1pbnRpbmcgb24gY3JlZGl0AAAAAAAACE1pbnRCdXJuAAAAAQAAABMAAAAFAAAAAAAAAAAAAAAHT0ZUU2VudAAAAAABAAAACG9mdF9zZW50AAAABQAAAAAAAAAEZ3VpZAAAA+4AAAAgAAAAAQAAAAAAAAAHZHN0X2VpZAAAAAAEAAAAAQAAAAAAAAAEZnJvbQAAABMAAAABAAAAAAAAAA5hbW91bnRfc2VudF9sZAAAAAAACwAAAAAAAAAAAAAAEmFtb3VudF9yZWNlaXZlZF9sZAAAAAAACwAAAAAAAAACAAAABQAAAAAAAAAAAAAAC09GVFJlY2VpdmVkAAAAAAEAAAAMb2Z0X3JlY2VpdmVkAAAABAAAAAAAAAAEZ3VpZAAAA+4AAAAgAAAAAQAAAAAAAAAHc3JjX2VpZAAAAAAEAAAAAQAAAAAAAAACdG8AAAAAABMAAAABAAAAAAAAABJhbW91bnRfcmVjZWl2ZWRfbGQAAAAAAAsAAAAAAAAAAgAAAAUAAAAAAAAAAAAAAA9Nc2dJbnNwZWN0b3JTZXQAAAAAAQAAABFtc2dfaW5zcGVjdG9yX3NldAAAAAAAAAEAAAAAAAAACWluc3BlY3RvcgAAAAAAA+gAAAATAAAAAAAAAAIAAAACAAAAAAAAAAAAAAAKT0ZUU3RvcmFnZQAAAAAAAwAAAAAAAAAAAAAADERlY2ltYWxzRGlmZgAAAAAAAAAAAAAABVRva2VuAAAAAAAAAAAAAAAAAAAMTXNnSW5zcGVjdG9yAAAABAAAABNPRlRFcnJvcjogMzAwMC0zMDk5AAAAAAAAAAAIT0ZURXJyb3IAAAAGAAAAAAAAAA5JbnZhbGlkQWRkcmVzcwAAAAALuAAAAAAAAAANSW52YWxpZEFtb3VudAAAAAAAC7kAAAAAAAAAFEludmFsaWRMb2NhbERlY2ltYWxzAAALugAAAAAAAAAOTm90SW5pdGlhbGl6ZWQAAAAAC7sAAAAAAAAACE92ZXJmbG93AAALvAAAAAAAAAAQU2xpcHBhZ2VFeGNlZWRlZAAAC70AAAABAAAALVBhcmFtZXRlcnMgZm9yIHNlbmRpbmcgT0ZUIHRva2VucyBjcm9zcy1jaGFpbgAAAAAAAAAAAAAJU2VuZFBhcmFtAAAAAAAABwAAACRUaGUgYW1vdW50IHRvIHNlbmQgaW4gbG9jYWwgZGVjaW1hbHMAAAAJYW1vdW50X2xkAAAAAAAACwAAADhDb21wb3NlIG1lc3NhZ2UgdG8gZXhlY3V0ZSBvbiB0aGUgZGVzdGluYXRpb24gKE9wdGlvbmFsKQAAAAtjb21wb3NlX21zZwAAAAAOAAAAG1RoZSBkZXN0aW5hdGlvbiBlbmRwb2ludCBJRAAAAAAHZHN0X2VpZAAAAAAEAAAAN0FkZGl0aW9uYWwgb3B0aW9ucyBmb3IgdGhlIExheWVyWmVybyBtZXNzYWdlIChPcHRpb25hbCkAAAAADWV4dHJhX29wdGlvbnMAAAAAAAAOAAAARVRoZSBtaW5pbXVtIGFtb3VudCB0byByZWNlaXZlIGluIGxvY2FsIGRlY2ltYWxzIChzbGlwcGFnZSBwcm90ZWN0aW9uKQAAAAAAAA1taW5fYW1vdW50X2xkAAAAAAAACwAAACpPRlQgY29tbWFuZCBmb3IgY3VzdG9tIGJlaGF2aW9yIChPcHRpb25hbCkAAAAAAAdvZnRfY21kAAAAAA4AAAA5VGhlIHJlY2lwaWVudCBhZGRyZXNzIG9uIHRoZSBkZXN0aW5hdGlvbiBjaGFpbiAoMzIgYnl0ZXMpAAAAAAAAAnRvAAAAAAPuAAAAIAAAAAEAAAAiVHJhbnNmZXIgbGltaXRzIGZvciBPRlQgb3BlcmF0aW9ucwAAAAAAAAAAAAhPRlRMaW1pdAAAAAIAAAAsVGhlIG1heGltdW0gYW1vdW50IHRvIHNlbmQgaW4gbG9jYWwgZGVjaW1hbHMAAAANbWF4X2Ftb3VudF9sZAAAAAAAAAsAAAAsVGhlIG1pbmltdW0gYW1vdW50IHRvIHNlbmQgaW4gbG9jYWwgZGVjaW1hbHMAAAANbWluX2Ftb3VudF9sZAAAAAAAAAsAAAABAAAAP1JlY2VpcHQgY29udGFpbmluZyBhbW91bnRzIHNlbnQgYW5kIHJlY2VpdmVkIGluIGFuIE9GVCB0cmFuc2ZlcgAAAAAAAAAACk9GVFJlY2VpcHQAAAAAAAIAAAAzVGhlIGFtb3VudCByZWNlaXZlZCBpbiBsb2NhbCBkZWNpbWFscyBvbiB0aGUgcmVtb3RlAAAAABJhbW91bnRfcmVjZWl2ZWRfbGQAAAAAAAsAAAAhVGhlIGFtb3VudCBzZW50IGluIGxvY2FsIGRlY2ltYWxzAAAAAAAADmFtb3VudF9zZW50X2xkAAAAAAALAAAAAQAAAC5EZXRhaWxzIGFib3V0IGZlZXMgY2hhcmdlZCBpbiBhbiBPRlQgb3BlcmF0aW9uAAAAAAAAAAAADE9GVEZlZURldGFpbAAAAAIAAAAaVGhlIGRlc2NyaXB0aW9uIG9mIHRoZSBmZWUAAAAAAAtkZXNjcmlwdGlvbgAAAAAOAAAAf1RoZSBhbW91bnQgb2YgdGhlIGZlZSBpbiBsb2NhbCBkZWNpbWFscy4gUG9zaXRpdmUgdmFsdWVzIHJlcHJlc2VudCBmZWVzIGNoYXJnZWQsCndoaWxlIG5lZ2F0aXZlIHZhbHVlcyByZXByZXNlbnQgcmV3YXJkcyBnaXZlbi4AAAAADWZlZV9hbW91bnRfbGQAAAAAAAALAAAABAAAABxCdWZmZXJSZWFkZXJFcnJvcjogMTAwMC0xMDA5AAAAAAAAABFCdWZmZXJSZWFkZXJFcnJvcgAAAAAAAAIAAAAAAAAADUludmFsaWRMZW5ndGgAAAAAAAPoAAAAAAAAABVJbnZhbGlkQWRkcmVzc1BheWxvYWQAAAAAAAPpAAAABAAAABxCdWZmZXJXcml0ZXJFcnJvcjogMTAxMC0xMDE5AAAAAAAAABFCdWZmZXJXcml0ZXJFcnJvcgAAAAAAAAEAAAAAAAAAFUludmFsaWRBZGRyZXNzUGF5bG9hZAAAAAAAA/IAAAAEAAAAH1R0bENvbmZpZ3VyYWJsZUVycm9yOiAxMDIwLTEwMjkAAAAAAAAAABRUdGxDb25maWd1cmFibGVFcnJvcgAAAAMAAAAAAAAAEEludmFsaWRUdGxDb25maWcAAAP8AAAAAAAAAA9UdGxDb25maWdGcm96ZW4AAAAD/QAAAAAAAAAWVHRsQ29uZmlnQWxyZWFkeUZyb3plbgAAAAAD/gAAAAQAAAAXT3duYWJsZUVycm9yOiAxMDMwLTEwMzkAAAAAAAAAAAxPd25hYmxlRXJyb3IAAAAHAAAAAAAAABFJbnZhbGlkQXV0aG9yaXplcgAAAAAABAYAAAAAAAAAE0ludmFsaWRQZW5kaW5nT3duZXIAAAAEBwAAAAAAAAAKSW52YWxpZFR0bAAAAAAECAAAAAAAAAARTm9QZW5kaW5nVHJhbnNmZXIAAAAAAAQJAAAAAAAAAA9Pd25lckFscmVhZHlTZXQAAAAECgAAAAAAAAALT3duZXJOb3RTZXQAAAAECwAAAAAAAAASVHJhbnNmZXJJblByb2dyZXNzAAAAAAQMAAAABAAAABhCeXRlc0V4dEVycm9yOiAxMDQwLTEwNDkAAAAAAAAADUJ5dGVzRXh0RXJyb3IAAAAAAAABAAAAAAAAAA5MZW5ndGhNaXNtYXRjaAAAAAAEEAAAAAQAAAAbVXBncmFkZWFibGVFcnJvcjogMTA1MC0xMDU5AAAAAAAAAAAQVXBncmFkZWFibGVFcnJvcgAAAAIAAAAAAAAAFEludmFsaWRNaWdyYXRpb25EYXRhAAAEGgAAAAAAAAATTWlncmF0aW9uTm90QWxsb3dlZAAAAAQbAAAABAAAABhNdWx0aVNpZ0Vycm9yOiAxMDYwLTEwNjkAAAAAAAAADU11bHRpU2lnRXJyb3IAAAAAAAAJAAAAAAAAABJBbHJlYWR5SW5pdGlhbGl6ZWQAAAAABCQAAAAAAAAAEUludmFsaWRBdXRob3JpemVyAAAAAAAEJQAAAAAAAAANSW52YWxpZFNpZ25lcgAAAAAABCYAAAAAAAAADlNpZ25hdHVyZUVycm9yAAAAAAQnAAAAAAAAABNTaWduZXJBbHJlYWR5RXhpc3RzAAAABCgAAAAAAAAADlNpZ25lck5vdEZvdW5kAAAAAAQpAAAAAAAAAB1Ub3RhbFNpZ25lcnNMZXNzVGhhblRocmVzaG9sZAAAAAAABCoAAAAAAAAAD1Vuc29ydGVkU2lnbmVycwAAAAQrAAAAAAAAAA1aZXJvVGhyZXNob2xkAAAAAAAELAAAAAUAAAAwRXZlbnQgZW1pdHRlZCB3aGVuIGEgc2lnbmVyIGlzIGFkZGVkIG9yIHJlbW92ZWQuAAAAAAAAAAlTaWduZXJTZXQAAAAAAAABAAAACnNpZ25lcl9zZXQAAAAAAAIAAAAAAAAABnNpZ25lcgAAAAAD7gAAABQAAAABAAAAAAAAAAZhY3RpdmUAAAAAAAEAAAAAAAAAAgAAAAUAAAA2RXZlbnQgZW1pdHRlZCB3aGVuIHRoZSBzaWduYXR1cmUgdGhyZXNob2xkIGlzIGNoYW5nZWQuAAAAAAAAAAAADFRocmVzaG9sZFNldAAAAAEAAAANdGhyZXNob2xkX3NldAAAAAAAAAEAAAAAAAAACXRocmVzaG9sZAAAAAAAAAQAAAAAAAAAAgAAAAIAAAAAAAAAAAAAAA9NdWx0aVNpZ1N0b3JhZ2UAAAAAAgAAAAAAAAAAAAAAB1NpZ25lcnMAAAAAAAAAAAAAAAAJVGhyZXNob2xkAAAAAAAABQAAAFdFdmVudCBlbWl0dGVkIHdoZW4gb3duZXJzaGlwIGlzIHRyYW5zZmVycmVkIChib3RoIHNpbmdsZS1zdGVwIGFuZCB0d28tc3RlcCBjb21wbGV0aW9uKS4AAAAAAAAAABRPd25lcnNoaXBUcmFuc2ZlcnJlZAAAAAEAAAAVb3duZXJzaGlwX3RyYW5zZmVycmVkAAAAAAAAAgAAAAAAAAAJb2xkX293bmVyAAAAAAAAEwAAAAAAAAAAAAAACW5ld19vd25lcgAAAAAAABMAAAAAAAAAAgAAAAUAAAA7RXZlbnQgZW1pdHRlZCB3aGVuIGEgMi1zdGVwIG93bmVyc2hpcCB0cmFuc2ZlciBpcyBwcm9wb3NlZC4AAAAAAAAAABVPd25lcnNoaXBUcmFuc2ZlcnJpbmcAAAAAAAABAAAAFm93bmVyc2hpcF90cmFuc2ZlcnJpbmcAAAAAAAMAAAAAAAAACW9sZF9vd25lcgAAAAAAABMAAAAAAAAAAAAAAAluZXdfb3duZXIAAAAAAAATAAAAAAAAAAAAAAADdHRsAAAAAAQAAAAAAAAAAgAAAAUAAAA8RXZlbnQgZW1pdHRlZCB3aGVuIGEgMi1zdGVwIG93bmVyc2hpcCB0cmFuc2ZlciBpcyBjYW5jZWxsZWQuAAAAAAAAABpPd25lcnNoaXBUcmFuc2ZlckNhbmNlbGxlZAAAAAAAAQAAABxvd25lcnNoaXBfdHJhbnNmZXJfY2FuY2VsbGVkAAAAAgAAAAAAAAAFb3duZXIAAAAAAAATAAAAAAAAAAAAAAAXY2FuY2VsbGVkX3BlbmRpbmdfb3duZXIAAAAAEwAAAAAAAAACAAAABQAAACpFdmVudCBlbWl0dGVkIHdoZW4gb3duZXJzaGlwIGlzIHJlbm91bmNlZC4AAAAAAAAAAAAST3duZXJzaGlwUmVub3VuY2VkAAAAAAABAAAAE293bmVyc2hpcF9yZW5vdW5jZWQAAAAAAQAAAAAAAAAJb2xkX293bmVyAAAAAAAAEwAAAAAAAAACAAAAAgAAAAAAAAAAAAAADk93bmFibGVTdG9yYWdlAAAAAAACAAAAAAAAAAAAAAAFT3duZXIAAAAAAAAAAAAAAAAAAAxQZW5kaW5nT3duZXIAAAABAAAASVRUTCBjb25maWd1cmF0aW9uOiB0aHJlc2hvbGQgKHdoZW4gdG8gZXh0ZW5kKSBhbmQgZXh0ZW5kX3RvICh0YXJnZXQgVFRMKS4AAAAAAAAAAAAACVR0bENvbmZpZwAAAAAAAAIAAAAoVGFyZ2V0IFRUTCBhZnRlciBleHRlbnNpb24gKGluIGxlZGdlcnMpLgAAAAlleHRlbmRfdG8AAAAAAAAEAAAAM1RUTCB0aHJlc2hvbGQgdGhhdCB0cmlnZ2VycyBleHRlbnNpb24gKGluIGxlZGdlcnMpLgAAAAAJdGhyZXNob2xkAAAAAAAABAAAAAUAAAAnRXZlbnQgZW1pdHRlZCB3aGVuIFRUTCBjb25maWdzIGFyZSBzZXQuAAAAAAAAAAANVHRsQ29uZmlnc1NldAAAAAAAAAEAAAAPdHRsX2NvbmZpZ3Nfc2V0AAAAAAIAAAAAAAAACGluc3RhbmNlAAAD6AAAB9AAAAAJVHRsQ29uZmlnAAAAAAAAAAAAAAAAAAAKcGVyc2lzdGVudAAAAAAD6AAAB9AAAAAJVHRsQ29uZmlnAAAAAAAAAAAAAAIAAAAFAAAAKkV2ZW50IGVtaXR0ZWQgd2hlbiBUVEwgY29uZmlncyBhcmUgZnJvemVuLgAAAAAAAAAAABBUdGxDb25maWdzRnJvemVuAAAAAQAAABJ0dGxfY29uZmlnc19mcm96ZW4AAAAAAAAAAAACAAAAAgAAAAAAAAAAAAAAEFR0bENvbmZpZ1N0b3JhZ2UAAAADAAAAAAAAAAAAAAAGRnJvemVuAAAAAAAAAAAAAAAAAAhJbnN0YW5jZQAAAAAAAAAAAAAAClBlcnNpc3RlbnQAAAAAAAIAAAAAAAAAAAAAABJVcGdyYWRlYWJsZVN0b3JhZ2UAAAAAAAEAAAAAAAAAAAAAAAlNaWdyYXRpbmcAAAAAiwEOY29udHJhY3RtZXRhdjAAAAAAAAAABmJpbnZlcgAAAAAABTAuMC4xAAAAAAAAAAAAAAVyc3ZlcgAAAAAAAAYxLjkwLjAAAAAAAAAAAAAIcnNzZGt2ZXIAAAAvMjUuMS4xIzk0YzJhM2IzYTVkZWQ2YjljZjljZWYwYzIwN2JmODgwNGYzZWIyOTQAAB4RY29udHJhY3RlbnZtZXRhdjAAAAAAAAAAGQAAAAAAUw5jb250cmFjdG1ldGF2MAAAAAAAAAAGY2xpdmVyAAAAAAAvMjUuMC4wI2E2NDkyNWU5MzkxYzNkM2IzZWY4ZTUzZGM2MGMyM2RiOWU2YTgyZTQA";
11
+ export declare const WASM_BASE64 = "AGFzbQEAAAABigEZYAJ+fgF+YAF+AX5gA35+fgF+YAR+fn5+AX5gAAF+YAABf2AAAGABfwF+YAJ+fgF/YAF/AGABfgBgAn9+AGADf35+AGACfn4AYAJ+fwF/YAJ+fwBgA39/fwBgAX4Bf2ADfn9+AGADfn5/AGACf38BfmAEf39/fwF+YAN+fn4AYAN/fn8AYAJ/fwAClwEZAWwBMQAAAWEBMAABAXYBMwABAXYBNgAAAXgBMQAAAWwBXwACAWwBMgAAAWwBNwADAXYBZwAAAWkBOAABAWkBNwABAWIBagAAAWkBNgAAAWQBXwACAW0BOQACAXgBMAAAAXgBMwAEAXgBOAAEAWwBMAAAAWwBOAAAAXgBNQABAW0BYQADAXYBXwAEAXYBZAAAAXYBMgAAA2loBQYHCAYJCgsLDAwNDgQJDwYJBwkEEAsIAggRBAoSEw8UBxUGAhYAAAcJCQEAAQABABcABAANBBQWAgILAAIAGBgKBAYEBAQBDQAGAQUMBAQAGAALBwQJCRgEBAYQDAsQGBgYGBAYBw8FAwEAEQYhBH8BQYCAwAALfwBBp4DAAAt/AEHOhMAAC38AQdCEwAALB4YEIAZtZW1vcnkCAApncmFudF9yb2xlADELcmV2b2tlX3JvbGUAPQ1yZW5vdW5jZV9yb2xlAD8Oc2V0X3JvbGVfYWRtaW4AQBFyZW1vdmVfcm9sZV9hZG1pbgBECGhhc19yb2xlAEUOZ2V0X3JvbGVfYWRtaW4ARhVnZXRfcm9sZV9tZW1iZXJfY291bnQASA9nZXRfcm9sZV9tZW1iZXIASRJnZXRfZXhpc3Rpbmdfcm9sZXMATAlzZXRfYWRtaW4ATQ5zZXRfYXV0aG9yaXplZABSCGNsYXdiYWNrAFMEbWludABWDV9fY29uc3RydWN0b3IAVw51bmRlcmx5aW5nX3NhYwBbCmF1dGhvcml6ZXIAXQVvd25lcgBeDXBlbmRpbmdfb3duZXIAXxJ0cmFuc2Zlcl9vd25lcnNoaXAAYBpwcm9wb3NlX293bmVyc2hpcF90cmFuc2ZlcgBiEGFjY2VwdF9vd25lcnNoaXAAZxJyZW5vdW5jZV9vd25lcnNoaXAAaBNleHRlbmRfaW5zdGFuY2VfdHRsAGkPc2V0X3R0bF9jb25maWdzAGsLdHRsX2NvbmZpZ3MAbhJmcmVlemVfdHRsX2NvbmZpZ3MAchVpc190dGxfY29uZmlnc19mcm96ZW4AcwFfAwEKX19kYXRhX2VuZAMCC19faGVhcF9iYXNlAwMK8VJoTQIBfwF+EJqAgIAAQQAhAAJAQQAQm4CAgAAiAUICEJyAgIAARQ0AQQEhAAJAAkAgAUICEICAgIAAp0H/AXEOAgECAAsAC0EAIQALIAALSAEBfyOAgICAAEEQayIAJICAgIAAIABBBGoQ74CAgAACQCAAKAIEQQFHDQAgACgCCCAAKAIMEOqAgIAACyAAQRBqJICAgIAAC8IBAgF/AX4jgICAgABBEGsiASSAgICAAAJAAkACQAJAAkACQCAAQf8BcQ4DAAECAAsgAUG2hMCAAEEGEK6AgIAAIAEoAgANAyABIAEpAwgQr4CAgAAMAgsgAUG8hMCAAEEIEK6AgIAAIAEoAgANAiABIAEpAwgQr4CAgAAMAQsgAUHEhMCAAEEKEK6AgIAAIAEoAgANASABIAEpAwgQr4CAgAALIAEpAwghAiABKQMAUA0BCwALIAFBEGokgICAgAAgAgsPACAAIAEQkoCAgABCAVELTQEBfyOAgICAAEEQayIAJICAgIAAIAAQnoCAgAACQCAAKAIADQBCg4CAgOCFARCfgICAAAALIAApAwgQgYCAgAAaIABBEGokgICAgAALEAAQmoCAgAAgABCngICAAAsLACAAEJSAgIAAGgsSABCagICAACAAIAEQoYCAgAALkgEBAn8jgICAgABBIGsiAiSAgICAACACQQQ2AgggAiABNwMQAkACQAJAIAJBCGoQwYCAgAAiAUIBEJyAgIAARQ0AIAFCARCAgICAACIBp0H/AXEiA0EORg0BIANBygBGDQEACyAAQgA3AwAMAQsgAEIBNwMAIAAgATcDCCACQQhqEMKAgIAACyACQSBqJICAgIAAC00BAn8jgICAgABBEGsiAySAgICAABCagICAACADQQhqIAIgARCjgICAACADKAIMIQQgACADKAIINgIAIAAgBDYCBCADQRBqJICAgIAAC28BA38jgICAgABBIGsiAySAgICAACADIAI3AxggAyABNwMQIANBAjYCCCADIANBCGoQ+oCAgAAgAygCBCEEAkAgAygCACIFRQ0AIANBCGoQwoCAgAALIAAgBDYCBCAAIAU2AgAgA0EgaiSAgICAAAuHAQEBfyOAgICAAEEgayICJICAgIAAIAJBEGogABCggICAAAJAAkAgAigCEEEBRw0AIAJBCGogASACKQMYEKKAgIAAIAIoAggNAQsgAkEQahCegICAACABIAJBGGpBACACKAIQGxClgICAAA0AQoOAgIDghwEQn4CAgAAACyACQSBqJICAgIAACxkAAkAgAQ0AQQAPCyAAIAEpAwAQsICAgAALewIBfwF+I4CAgIAAQRBrIgAkgICAgAAgABCngICAACAAKQMIIQEgACkDAEGLCBCogICAACAAEJ6AgIAAAkAgASAAQQhqQQAgACgCABsQpYCAgAANAEKDgICA4IABEJ+AgIAAAAsgARCBgICAABogAEEQaiSAgICAACABCxAAEJqAgIAAIAAQrICAgAALKQACQCAAp0EBcUUNAA8LIAFB+ndqrUIghkKDgICA4IABfBCfgICAAAALQgEBfyOAgICAAEEQayIAJICAgIAAIAAQqoCAgAACQCAAKQMAUA0AQoOAgIDAgQEQn4CAgAAACyAAQRBqJICAgIAAC1MBAn4QmoCAgABCACEBAkACQEEBEKuAgIAAIgJCABCcgICAAEUNACACQgAQgICAgAAiAUL/AYNCzQBSDQEgACABNwMIQgEhAQsgACABNwMADwsAC5IBAgF/AX4jgICAgABBEGsiASSAgICAAAJAAkACQAJAIABBAXFFDQAgAUGVgsCAAEEMEK6AgIAAIAEoAgANAiABIAEpAwgQr4CAgAAMAQsgAUGQgsCAAEEFEK6AgIAAIAEoAgANASABIAEpAwgQr4CAgAALIAEpAwghAiABKQMAUA0BCwALIAFBEGokgICAgAAgAgtNAQJ+QgAhAQJAAkBBABCrgICAACICQgIQnICAgABFDQAgAkICEICAgIAAIgFC/wGDQs0AUg0BIAAgATcDCEIBIQELIAAgATcDAA8LAAtgAgF/AX4jgICAgABBEGsiACSAgICAACAAQZ+AwIAAQQgQroCAgAACQAJAIAAoAgANACAAIAApAwgQr4CAgAAgACgCAEEBRw0BCwALIAApAwghASAAQRBqJICAgIAAIAELUQIBfwF+I4CAgIAAQRBrIgMkgICAgAAgAyABIAIQ9YCAgABCASEEAkAgAygCAA0AIAAgAykDCDcDCEIAIQQLIAAgBDcDACADQRBqJICAgIAAC0QBAX8jgICAgABBEGsiAiSAgICAACACIAE3AwggAkEIakEBENCAgIAAIQEgAEIANwMAIAAgATcDCCACQRBqJICAgIAACw0AIAAgARCPgICAAFAL4AICA38BfiOAgICAAEEgayIDJICAgIAAAkACQAJAIABC/wGDQs0AUg0AAkAgAadB/wFxIgRBDkYNACAEQcoARw0BCyACQv8Bg0LNAFINABCagICAACACEIGAgIAAGiABIAIQpICAgAACQCABIAAQsoCAgAANACABELOAgIAAIgQhBQJAIAQNABC0gICAACIGEIKAgIAAQoCAgICAIFoNAyAGIAEQg4CAgAAQtYCAgABBACEFCyABIAUgABC2gICAACABIAAgBBC3gICAACAEQQFqIgRFDQMgASAEELiAgIAAIANBoYLAgABBDBC5gICAADcDGCADIAA3AxAgAyABNwMAIAMgA0EYajYCCCADELqAgIAAIQEgAyACNwMAIAFBtILAgABBASADQQEQu4CAgAAQhICAgAAaCyADQSBqJICAgIAAQgIPCwALQoOAgICghwEQn4CAgAAACxC8gICAAAALXQECfyOAgICAAEEgayICJICAgIAAIAIgATcDGCACIAA3AxAgAkECNgIIAkAgAkEIahDBgICAAEIBEJyAgIAAIgNFDQAgAkEIahDCgICAAAsgAkEgaiSAgICAACADC2QBA38jgICAgABBIGsiASSAgICAACABQQM2AgggASAANwMQIAEgAUEIahD6gICAACABKAIEIQICQCABKAIAIgNFDQAgAUEIahDCgICAAAsgAUEgaiSAgICAACACQQAgA0EBcRsLeQIBfwF+I4CAgIAAQSBrIgAkgICAgAAgAEEANgIIAkACQAJAIABBCGoQwYCAgAAiAUIBEJyAgIAARQ0AIAFCARCAgICAACIBQv8Bg0LLAFINAiAAQQhqEMKAgIAADAELEJaAgIAAIQELIABBIGokgICAgAAgAQ8LAAtIAQF/I4CAgIAAQSBrIgEkgICAgAAgAUEANgIIIAFBCGoQwYCAgAAgAEIBEIWAgIAAGiABQQhqEMKAgIAAIAFBIGokgICAgAALVgEBfyOAgICAAEEgayIDJICAgIAAIAMgATYCDCADIAA3AxAgA0EBNgIIIANBCGoQwYCAgAAgAkIBEIWAgIAAGiADQQhqEMKAgIAAIANBIGokgICAgAALTQEBfyOAgICAAEEgayIDJICAgIAAIAMgATcDGCADIAA3AxAgA0ECNgIIIANBCGogAhD7gICAACADQQhqEMKAgIAAIANBIGokgICAgAALRgEBfyOAgICAAEEgayICJICAgIAAIAJBAzYCCCACIAA3AxAgAkEIaiABEPuAgIAAIAJBCGoQwoCAgAAgAkEgaiSAgICAAAtFAgF/AX4jgICAgABBEGsiAiSAgICAACACIAAgARD1gICAAAJAIAIoAgBBAUcNAAALIAIpAwghAyACQRBqJICAgIAAIAMLqQECAX8BfiOAgICAAEEwayIBJICAgIAAIAEgACkDEDcDECABIAApAwA3AwggASAAKAIIKQMANwMAQQAhAAN+AkAgAEEYRw0AQQAhAAJAA0AgAEEYRg0BIAFBGGogAGogASAAaikDADcDACAAQQhqIQAMAAsLIAFBGGpBAxDQgICAACECIAFBMGokgICAgAAgAg8LIAFBGGogAGpCAjcDACAAQQhqIQAMAAsLLgACQCABIANGDQAACyAArUIghkIEhCACrUIghkIEhCABrUIghkIEhBCOgICAAAsJABD0gICAAAALYQEBfwJAIABC/wGDQs0AUg0AAkAgAadB/wFxIgNBDkYNACADQcoARw0BCyACQv8Bg0LNAFINABCagICAACACEIGAgIAAGiABIAIQpICAgAAgACABIAIQvoCAgABCAg8LAAv7AwIDfwJ+I4CAgIAAQTBrIgMkgICAgAACQAJAAkACQCABIAAQsoCAgABFDQAgARCzgICAACIERQ0BIANBCGogASAAEKOAgIAAIAMoAgwhBSADKAIIQb0IEP6AgIAAIAEgBRCAgYCAACADIAA3AyAgAyABNwMYIANBAjYCECADQRBqEMGAgIAAQgEQhoCAgAAaIAUgBEF/aiIERw0CDAMLQoOAgIDQhwEQn4CAgAAAC0KDgICAsIcBEJ+AgIAAAAsgA0EQaiABIAQQyoCAgAAgAykDECADKQMYEMuAgIAAIQYgASAEEICBgIAAIAEgBSAGELaAgIAAIAEgBiAFELeAgIAACyABIAQQuICAgAACQAJAIAQNAAJAAkAQtICAgAAiBiABEJeAgIAAIgdCAlINAEEAIQQMAQsgB0L/AYNCBFINAiAHQiCIpyEFQQEhBAsgBEG8CBD+gICAAAJAIAUgBhCCgICAAEIgiKdPDQAgBiAFrUIghkIEhBCYgICAACEGCyAGELWAgIAACyADQbyCwIAAQQwQuYCAgAA3AyggAyAANwMgIAMgATcDECADIANBKGo2AhggA0EQahC6gICAACEBIAMgAjcDECABQbSCwIAAQQEgA0EQakEBELuAgIAAEISAgIAAGiADQTBqJICAgIAADwsQvICAgAAAC0sBAX8CQAJAIACnQf8BcSICQQ5GDQAgAkHKAEcNAQsgAUL/AYNCzQBSDQAQmoCAgAAgARCBgICAABogASAAIAEQvoCAgABCAg8LAAvfAQICfwJ+I4CAgIAAQTBrIgIkgICAgAACQAJAIACnQf8BcSIDQQ5GDQAgA0HKAEcNAQsCQCABp0H/AXEiA0EORg0AIANBygBHDQELEJ2AgIAAEJqAgIAAIAJBCGogABChgICAACACKQMIIQQgAikDECEFIAJBBDYCCCACIAA3AxAgAkEIahDBgICAACABQgEQhYCAgAAaIAJBCGoQwoCAgAAgAiABNwMgIAJCATcDGCACIAU3AxAgAiAENwMIIAIgADcDKCACQQhqEMOAgIAAIAJBMGokgICAgABCAg8LAAuXAwIBfwJ+I4CAgIAAQTBrIgEkgICAgAACQAJAAkACQAJAAkACQAJAAkACQCAAKAIADgUAAQIEBQALIAFBCGpBjIPAgABBDRCugICAACABKAIIDQcgAUEIaiABKQMQEK+AgIAADAULIAFBIGpBmYPAgABBEhCugICAACABKAIgDQYgASABKQMoNwMIIAEgACkDCDcDECABIAA1AgRCIIZCBIQ3AxggAUEgaiABQQhqEPmAgIAADAELIAFBIGpBq4PAgABBEhCugICAACABKAIgDQUgASABKQMoNwMIIAEgACkDEDcDGCABIAApAwg3AxAgAUEgaiABQQhqEPmAgIAACyABKQMoIQIgASkDICEDDAMLIAFBCGpBvYPAgABBERCugICAACABKAIIDQMgAUEIaiABKQMQIAApAwgQ9oCAgAAMAQsgAUEIakHOg8CAAEEJEK6AgIAAIAEoAggNAiABQQhqIAEpAxAgACkDCBD2gICAAAsgASkDECECIAEpAwghAwsgA1ANAQsACyABQTBqJICAgIAAIAILaQIBfwJ+I4CAgIAAQRBrIgEkgICAgAAgAUEEahDwgICAAAJAIAEoAgRBAUcNACABNQIMIQIgATUCCCEDIAAQwYCAgABCASADQiCGQgSEIAJCIIZCBIQQh4CAgAAaCyABQRBqJICAgIAAC/kBAwF/An4BfyOAgICAAEEgayIBJICAgIAAIAApAyAhAkHIgsCAAEESELmAgIAAIQMgASACNwMIIAEgAzcDAEEAIQQDQAJAIARBEEcNAEEAIQQCQANAIARBEEYNASABQRBqIARqIAEgBGopAwA3AwAgBEEIaiEEDAALCyABQRBqQQIQ0ICAgAAhAiAAKQMQIAApAxgQx4CAgAAhAyABIAApAwAgACkDCBDHgICAADcDGCABIAM3AxAgAkH8gsCAAEECIAFBEGpBAhC7gICAABCEgICAABogAUEgaiSAgICAAA8LIAFBEGogBGpCAjcDACAEQQhqIQQMAAsLwQEBAn8jgICAgABBwABrIgEkgICAgAACQAJAAkAgAKdB/wFxIgJBDkYNACACQcoARw0BCxCdgICAABCagICAACABQQhqIAAQoYCAgAAgASgCCEUNASABQQQ2AhggASAANwMgIAFBGGoQwYCAgABCARCGgICAABogASAANwM4IAFCADcDKCABIAEpAxA3AyAgAUIBNwMYIAFBGGoQw4CAgAAgAUHAAGokgICAgABCAg8LAAtCg4CAgICHARCfgICAAAALdwECfyOAgICAAEEQayICJICAgIAAAkAgAEL/AYNCzQBSDQACQCABp0H/AXEiA0EORg0AIANBygBHDQELIAJBCGogACABEKKAgIAAIAIoAgghAyACNQIMIQAgAkEQaiSAgICAACAAQiCGQgSEQgIgA0EBcRsPCwALWAECfyOAgICAAEEQayIBJICAgIAAAkAgAKdB/wFxIgJBDkYNACACQcoARg0AAAsgASAAEKCAgIAAIAEpAwAgASkDCBDHgICAACEAIAFBEGokgICAgAAgAAsNACABQgIgAKdBAXEbCzMBAX8CQCAAp0H/AXEiAUEORg0AIAFBygBGDQAACxCagICAACAAELOAgIAArUIghkIEhAtzAQJ/I4CAgIAAQRBrIgIkgICAgAACQAJAIACnQf8BcSIDQQ5GDQAgA0HKAEcNAQsgAUL/AYNCBFINABCagICAACACIAAgAUIgiKcQyoCAgAAgAikDACACKQMIEMuAgIAAIQAgAkEQaiSAgICAACAADwsAC48BAQF/I4CAgIAAQSBrIgMkgICAgAAgAyACNgIMIAMgATcDECADQQE2AggCQAJAAkAgA0EIahDBgICAACIBQgEQnICAgABFDQAgAUIBEICAgIAAIgFC/wGDQs0AUQ0BAAsgAEIANwMADAELIABCATcDACAAIAE3AwggA0EIahDCgICAAAsgA0EgaiSAgICAAAsgAAJAIACnQQFxRQ0AIAEPC0KDgICAkIcBEJ+AgIAAAAsOABCagICAABC0gICAAAuSAQEBfyOAgICAAEEQayICJICAgIAAAkAgAEL/AYNCzQBSDQAgAUL/AYNCzQBSDQBBgIDAgABBCRC5gICAACABEM6AgIAAIAEQgYCAgAAaEJqAgIAAEM+AgIAAIQEgAiAANwMIIAFCjuauueqM5NU4IAJBCGpBARDQgICAABDRgICAACACQRBqJICAgIAAQgIPCwALIAACQCAAIAEQsoCAgAANAEKDgICA4IcBEJ+AgIAAAAsLQwEBfhCagICAAAJAAkAQrYCAgAAiAEICEJyAgIAARQ0AIABCAhCAgICAACIAQv8Bg0LNAFENAQALENyAgIAAAAsgAAsaACAArUIghkIEhCABrUIghkIEhBCIgICAAAshAAJAIAAgASACEI2AgIAAQv8Bg0ICUQ0AELyAgIAAAAsLlAIBAn8jgICAgABBIGsiAySAgICAAAJAIABC/wGDQs0AUg0AQQEgAadB/wFxIgRBAEdBAXQgBEEBRhsiBEECRg0AIAJC/wGDQs0AUg0AQYmAwIAAQQgQuYCAgAAgAhDOgICAACACEIGAgIAAGhCagICAABDPgICAACECQaeAwIAAQQ4QuYCAgAAhASADIAStNwMIIAMgADcDAEEAIQQDQAJAIARBEEcNAEEAIQQCQANAIARBEEYNASADQRBqIARqIAMgBGopAwA3AwAgBEEIaiEEDAALCyACIAEgA0EQakECENCAgIAAENGAgIAAIANBIGokgICAgABCAg8LIANBEGogBGpCAjcDACAEQQhqIQQMAAsLAAuVAgMBfwF+AX8jgICAgABBMGsiAySAgICAAAJAIABC/wGDQs0AUg0AIAMgARDUgICAACADKAIAQQFGDQAgAkL/AYNCzQBSDQAgAykDGCEBIAMpAxAhBEGRgMCAAEEIELmAgIAAIAIQzoCAgAAgAhCBgICAABoQmoCAgAAQz4CAgAAhAiADIAQgARDVgICAADcDKCADIAA3AyBBACEFA0ACQCAFQRBHDQBBACEFAkADQCAFQRBGDQEgAyAFaiADQSBqIAVqKQMANwMAIAVBCGohBQwACwsgAkKO4KjzybfG0QAgA0ECENCAgIAAENGAgIAAIANBMGokgICAgABCAg8LIAMgBWpCAjcDACAFQQhqIQUMAAsLAAt9AgF/AX4CQAJAAkACQCABp0H/AXEiAkHFAEYNACACQQtHDQIgACABQj+HNwMYIAAgAUIIhzcDEAwBCyABEImAgIAAIQMgARCKgICAACEBIAAgAzcDGCAAIAE3AxALQgAhAQwBCyAAQoOQgICAATcDCEIBIQELIAAgATcDAAtFAAJAIABCgICAgICAgMAAfEL//////////wBWDQAgACAAhSABIABCP4eFhEIAUg0AIABCCIZCC4QPCyABIAAQjICAgAALkQIDAX8BfgF/I4CAgIAAQTBrIgMkgICAgAACQCAAQv8Bg0LNAFINACADIAEQ1ICAgAAgAygCAEEBRg0AIAJC/wGDQs0AUg0AIAMpAxghASADKQMQIQRBmYDAgABBBhC5gICAACACEM6AgIAAIAIQgYCAgAAaEJqAgIAAEM+AgIAAIQIgAyAEIAEQ1YCAgAA3AyggAyAANwMgQQAhBQNAAkAgBUEQRw0AQQAhBQJAA0AgBUEQRg0BIAMgBWogA0EgaiAFaikDADcDACAFQQhqIQUMAAsLIAJCjvKz1wwgA0ECENCAgIAAENGAgIAAIANBMGokgICAgABCAg8LIAMgBWpCAjcDACAFQQhqIQUMAAsLAAt6AAJAAkAgAEL/AYNCzQBSDQAgAUL/AYNCzQBSDQBBgMseQYDSHxDYgICAAEGAyx5BgNIfENmAgIAAQQAQq4CAgABCAhCcgICAAA0BIAEQ2oCAgAAQrYCAgAAgAEICEIWAgIAAGkICDwsAC0KDgICAoIEBEJ+AgIAAAAsOAEEBIAAgARD9gICAAAsOAEECIAAgARD9gICAAAsOAEEAIABCAhDmgICAAAsIABDPgICAAAsJABC8gICAAAALPgIBfwF+I4CAgIAAQRBrIgAkgICAgAAgABCegICAACAAKQMAIAApAwgQx4CAgAAhASAAQRBqJICAgIAAIAELPgIBfwF+I4CAgIAAQRBrIgAkgICAgAAgABCngICAACAAKQMAIAApAwgQx4CAgAAhASAAQRBqJICAgIAAIAELPgIBfwF+I4CAgIAAQRBrIgAkgICAgAAgABCqgICAACAAKQMAIAApAwgQx4CAgAAhASAAQRBqJICAgIAAIAELPAEBfgJAIABC/wGDQs0AUQ0AAAsQmoCAgAAQpoCAgAAhARCpgICAACAAENqAgIAAIAEgABDhgICAAEICC2ECAX8BfiOAgICAAEEQayICJICAgIAAQb6AwIAAQRUQuYCAgAAQ5ICAgAAhAyACIAA3AwggAiABNwMAIANB6IDAgABBAiACQQIQu4CAgAAQhICAgAAaIAJBEGokgICAgAAL/AICAX8CfiOAgICAAEEgayICJICAgIAAAkACQAJAIABC/wGDQs0AUg0AIAFC/wGDQgRSDQAQmoCAgAAQpoCAgAAhAwJAAkAgAUL/////D1YNACACQQhqEKqAgIAAIAIpAxAhASACKQMIQYkIEKiAgIAAIAEgABCwgICAAEUNAxDjgICAAEGsgcCAAEEcELmAgIAAEOSAgIAAIQAgAiADNwMQIAIgATcDCCAAQeSBwIAAQQIgAkEIakECELuAgIAAEISAgIAAGgwBCxDlgICAACABQiCIp0kNA0EBIABCABDmgICAAEEBEKuAgIAAQgAgAUKEgICAcIMiASABEIeAgIAAGkH4gMCAAEEWELmAgIAAEOSAgIAAIQQgAiABNwMYIAIgAzcDECACIAA3AwggBEGUgcCAAEEDIAJBCGpBAxC7gICAABCEgICAABoLIAJBIGokgICAgABCAg8LAAtCg4CAgPCAARCfgICAAAALQoOAgICAgQEQn4CAgAAACxMAQQEQq4CAgABCABCGgICAABoLYwMBfwF+AX8jgICAgABBEGsiASSAgICAACABIAA3AwBCAiECQQEhAwJAA0AgA0UNASADQX9qIQMgACECDAALCyABIAI3AwggAUEIakEBENCAgIAAIQAgAUEQaiSAgICAACAACzMBAn4QkICAgAAhAAJAEJGAgIAAQiCIIgEgAEIgiCIAVA0AIAGnIACnaw8LELyAgIAAAAsVACAAEKuAgIAAIAEgAhCFgICAABoLiAECAX8CfiOAgICAAEEQayIAJICAgIAAEJqAgIAAIAAQqoCAgAAgACkDCCEBIAApAwBBiQgQqICAgAAgARCBgICAABogABCsgICAAAJAIAAoAgANABDcgICAAAALIAApAwghAhDjgICAACABENqAgIAAIAIgARDhgICAACAAQRBqJICAgIAAQgILhAECAX8CfiOAgICAAEEQayIAJICAgIAAEJqAgIAAEKaAgIAAIQEQqYCAgABBABCrgICAAEICEIaAgIAAGkH0gcCAAEETELmAgIAAEOSAgIAAIQIgACABNwMIIAJBiILAgABBASAAQQhqQQEQu4CAgAAQhICAgAAaIABBEGokgICAgABCAgsxAAJAIABC/wGDQgRSDQAgAUL/AYNCBFINACAAQiCIpyABQiCIpxDqgICAAEICDwsACxsAIACtQiCGQgSEIAGtQiCGQgSEEJOAgIAAGgu8BAEFfyOAgICAAEHQAGsiAiSAgICAACACQShqIAAQ7ICAgAACQCACKAIoQQJGDQAgAkEIakEIaiACQShqQQhqIgMoAgA2AgAgAiACKQIoNwMIIAJBKGogARDsgICAACACKAIoQQJGDQAgAkEYakEIaiADKAIANgIAIAIgAikCKDcDGBCdgICAABCagICAAAJAAkACQBCZgICAAA0AEOWAgIAAIgNBgPuAAyADQYD7gANJGyEEIAIgAkEYajYCLCACIAJBCGo2AihBACEDA0AgA0EIRg0DAkAgAkEoaiADaigCACIFKAIAQQFxRQ0AIAUoAggiBiAESw0DIAUoAgQgBksNAwsgA0EEaiEDDAALC0KDgICA0P8AEJ+AgIAAAAtCg4CAgMD/ABCfgICAAAALAkACQCACKAIIQQFHDQAgAigCDCACKAIQENiAgIAADAELQQEQm4CAgABCAhCGgICAABoLAkACQCACKAIYQQFHDQAgAigCHCACKAIgENmAgIAADAELQQIQm4CAgABCAhCGgICAABoLIAJBKGpBCGogAkEIakEIaigCADYCACACQTxqIAJBGGpBCGooAgA2AgAgAiACKQMINwMoIAIgAikDGDcCNEHwg8CAAEEPELmAgIAAEOSAgIAAIQAgAkEoahDtgICAACEBIAIgAkE0ahDtgICAADcDSCACIAE3A0AgAEGUhMCAAEECIAJBwABqQQIQu4CAgAAQhICAgAAaIAJB0ABqJICAgIAAQgIPCwALaAEBfyOAgICAAEEQayICJICAgIAAAkACQCABQgJRDQAgAkEEaiABEPeAgIAAAkAgAigCBEUNACAAQQI2AgAMAgsgACACKQIINwIEIABBATYCAAwBCyAAQQA2AgALIAJBEGokgICAgAALQwIBfwF+I4CAgIAAQRBrIgEkgICAgAAgASAAEPGAgIAAAkAgASgCAEEBRw0AAAsgASkDCCECIAFBEGokgICAgAAgAgugAQICfwF+I4CAgIAAQcAAayIAJICAgIAAEJqAgIAAIABBCGoQ74CAgAAgAEEUaiIBEPCAgIAAIABBMGogAEEIahDxgICAAAJAAkAgACgCMA0AIAApAzghAiAAQTBqIAEQ8YCAgAAgACgCMEEBRw0BCwALIAAgACkDODcDKCAAIAI3AyAgAEEgakECENCAgIAAIQIgAEHAAGokgICAgAAgAgsMACAAQQEQ/ICAgAALDAAgAEECEPyAgIAACzAAAkAgASgCAEEBRw0AIAAgASgCBCABKAIIEPiAgIAADwsgAEIANwMAIABCAjcDCAuIAQEBfyOAgICAAEEQayIAJICAgIAAEJ2AgIAAEJqAgIAAAkAQmYCAgABFDQBCg4CAgOD/ABCfgICAAAALQQAQm4CAgABCAUICEIWAgIAAGkGkhMCAAEESELmAgIAAEOSAgIAAQQRBACAAQQhqQQAQu4CAgAAQhICAgAAaIABBEGokgICAgABCAgsJABCZgICAAK0LAwAAC9sBAgF+BH8CQAJAIAJBCUsNAEIAIQMgAiEEIAEhBQNAAkAgBA0AIANCCIZCDoQhAwwDC0EBIQYCQCAFLQAAIgdB3wBGDQACQCAHQVBqQf8BcUEKSQ0AAkAgB0G/f2pB/wFxQRpJDQAgB0Gff2pB/wFxQRlLDQQgB0FFaiEGDAILIAdBS2ohBgwBCyAHQVJqIQYLIANCBoYgBq1C/wGDhCEDIARBf2ohBCAFQQFqIQUMAAsLIAGtQiCGQgSEIAKtQiCGQgSEEIuAgIAAIQMLIABCADcDACAAIAM3AwgLSAEBfyOAgICAAEEQayIDJICAgIAAIAMgAjcDCCADIAE3AwAgA0ECENCAgIAAIQIgAEIANwMAIAAgAjcDCCADQRBqJICAgIAAC74BAgJ/AX4jgICAgABBEGsiAiSAgICAAEEAIQMCQANAIANBEEYNASACIANqQgI3AwAgA0EIaiEDDAALC0EBIQMCQCABQv8Bg0LMAFINACABQeCDwIAArUIghkIEhCACrUIghkIEhEKEgICAIBCVgICAABogAikDACIBQv8Bg0IEUg0AIAIpAwgiBEL/AYNCBFINACAAIAFCIIinNgIIIAAgBEIgiD4CBEEAIQMLIAAgAzYCACACQRBqJICAgIAAC2ACAX8BfiOAgICAAEEQayIDJICAgIAAIAMgAa1CIIZCBIQ3AwggAyACrUIghkIEhDcDAEHgg8CAAEECIANBAhC7gICAACEEIABCADcDACAAIAQ3AwggA0EQaiSAgICAAAtdAgF/AX4jgICAgABBIGsiAiSAgICAACACIAEpAxA3AxggAiABKQMINwMQIAIgASkDADcDCCACQQhqQQMQ0ICAgAAhAyAAQgA3AwAgACADNwMIIAJBIGokgICAgAALWgIBfgF/AkACQAJAIAEQwYCAgAAiAkIBEJyAgIAADQBBACEBDAELIAJCARCAgICAACICQv8Bg0IEUg0BIAJCIIinIQNBASEBCyAAIAM2AgQgACABNgIADwsACxwAIAAQwYCAgAAgAa1CIIZCBIRCARCFgICAABoLdwICfwF+I4CAgIAAQRBrIgIkgICAgABBACEDAkACQCABEJuAgIAAIgRCAhCcgICAAEUNACACQQRqIARCAhCAgICAABD3gICAAEEBIQMgAigCBEEBRg0BIAAgAikCCDcCBAsgACADNgIAIAJBEGokgICAgAAPCwALVgIBfwF+I4CAgIAAQRBrIgMkgICAgAAgABCbgICAACEEIAMgASACEPiAgIAAAkAgAygCAEEBRw0AAAsgBCADKQMIQgIQhYCAgAAaIANBEGokgICAgAALHQACQCAAQQFxRQ0ADwsgARD/gICAABCfgICAAAALFQAgAEHHd2qtQiCGQoOAgICQhwF8C0kBAX8jgICAgABBIGsiAiSAgICAACACIAE2AgwgAiAANwMQIAJBATYCCCACQQhqEMGAgIAAQgEQhoCAgAAaIAJBIGokgICAgAALC9gEAQBBgIDAAAvOBEFETUlOX01HUkJMS0xJU1RSQ0xBV0JBQ0tNSU5URVJTYWNUb2tlbnNldF9hdXRob3JpemVkdGhyZXNob2xkb3duZXJzaGlwX3RyYW5zZmVycmVkbmV3X293bmVyb2xkX293bmVyAAAAUwAQAAkAAABcABAACQAAAG93bmVyc2hpcF90cmFuc2ZlcnJpbmd0dGwAAABTABAACQAAAFwAEAAJAAAAjgAQAAMAAABvd25lcnNoaXBfdHJhbnNmZXJfY2FuY2VsbGVkY2FuY2VsbGVkX3BlbmRpbmdfb3duZXJvd25lcsgAEAAXAAAA3wAQAAUAAABvd25lcnNoaXBfcmVub3VuY2VkAFwAEAAJAAAAT3duZXJQZW5kaW5nT3duZXJyb2xlX2dyYW50ZWRjYWxsZXIALQEQAAYAAAByb2xlX3Jldm9rZWRyb2xlX2FkbWluX2NoYW5nZWRuZXdfYWRtaW5fcm9sZXByZXZpb3VzX2FkbWluX3JvbGUAWgEQAA4AAABoARAAEwAAAEV4aXN0aW5nUm9sZXNSb2xlSW5kZXhUb0FjY291bnRSb2xlQWNjb3VudFRvSW5kZXhSb2xlQWNjb3VudHNDb3VudFJvbGVBZG1pbmV4dGVuZF90b9cBEAAJAAAANQAQAAkAAAB0dGxfY29uZmlnc19zZXRpbnN0YW5jZXBlcnNpc3RlbnQAAAD/ARAACAAAAAcCEAAKAAAAdHRsX2NvbmZpZ3NfZnJvemVuRnJvemVuSW5zdGFuY2VQZXJzaXN0ZW50AONWDmNvbnRyYWN0c3BlY3YwAAAAAAAAAQxHcmFudHMgYSByb2xlIHRvIGFuIGFjY291bnQuIENhbGxlciBtdXN0IGJlIG93bmVyIG9yIGhhdmUgdGhlIHJvbGUncyBhZG1pbiByb2xlLgoKIyBBcmd1bWVudHMKKiBgYWNjb3VudGAgLSBUaGUgYWNjb3VudCB0byBncmFudCB0aGUgcm9sZSB0by4KKiBgcm9sZWAgLSBUaGUgcm9sZSB0byBncmFudC4KKiBgY2FsbGVyYCAtIFRoZSBhY2NvdW50IHRoYXQgaXMgZ3JhbnRpbmcgdGhlIHJvbGUuIE11c3QgYmUgb3duZXIgb3IgaGF2ZSB0aGUgcm9sZSdzIGFkbWluIHJvbGUuAAAACmdyYW50X3JvbGUAAAAAAAMAAAAAAAAAB2FjY291bnQAAAAAEwAAAAAAAAAEcm9sZQAAABEAAAAAAAAABmNhbGxlcgAAAAAAEwAAAAAAAAAAAAABE1Jldm9rZXMgYSByb2xlIGZyb20gYW4gYWNjb3VudC4gQ2FsbGVyIG11c3QgYmUgb3duZXIgb3IgaGF2ZSB0aGUgcm9sZSdzIGFkbWluIHJvbGUuCgojIEFyZ3VtZW50cwoqIGBhY2NvdW50YCAtIFRoZSBhY2NvdW50IHRvIHJldm9rZSB0aGUgcm9sZSBmcm9tLgoqIGByb2xlYCAtIFRoZSByb2xlIHRvIHJldm9rZS4KKiBgY2FsbGVyYCAtIFRoZSBhY2NvdW50IHRoYXQgaXMgcmV2b2tpbmcgdGhlIHJvbGUuIE11c3QgYmUgb3duZXIgb3IgaGF2ZSB0aGUgcm9sZSdzIGFkbWluIHJvbGUuAAAAAAtyZXZva2Vfcm9sZQAAAAADAAAAAAAAAAdhY2NvdW50AAAAABMAAAAAAAAABHJvbGUAAAARAAAAAAAAAAZjYWxsZXIAAAAAABMAAAAAAAAAAAAAAO1BbGxvd3MgYW4gYWNjb3VudCB0byByZW5vdW5jZSBhIHJvbGUgYXNzaWduZWQgdG8gaXRzZWxmLgpVc2VycyBjYW4gb25seSByZW5vdW5jZSByb2xlcyBmb3IgdGhlaXIgb3duIGFjY291bnQuCgojIEFyZ3VtZW50cwoqIGByb2xlYCAtIFRoZSByb2xlIHRvIHJlbm91bmNlLgoqIGBjYWxsZXJgIC0gVGhlIGFjY291bnQgdGhhdCBpcyByZW5vdW5jaW5nIHRoZSByb2xlLiBNdXN0IGJlIHRoZSBhY2NvdW50IGl0c2VsZi4AAAAAAAANcmVub3VuY2Vfcm9sZQAAAAAAAAIAAAAAAAAABHJvbGUAAAARAAAAAAAAAAZjYWxsZXIAAAAAABMAAAAAAAAAAAAAAVdTZXRzIGBhZG1pbl9yb2xlYCBhcyB0aGUgYWRtaW4gcm9sZSBvZiBgcm9sZWAuIENhbGxlciBtdXN0IGJlIHRoZSBhdXRob3JpemVyLgoKIyBBcmd1bWVudHMKKiBgcm9sZWAgLSBUaGUgcm9sZSB0byBzZXQgdGhlIGFkbWluIGZvci4KKiBgYWRtaW5fcm9sZWAgLSBUaGUgYWRtaW4gcm9sZSB0byBzZXQgZm9yIHRoZSByb2xlLgoKIyBOb3RlcwoKVGhlIGFkbWluIHJvbGUgY2FuIGJlIGFueSBgU3ltYm9sYCwgaW5jbHVkaW5nIG9uZSB3aXRoIG5vIG1lbWJlcnMuIElmIHRoZSBhZG1pbgpyb2xlIGhhcyBubyBtZW1iZXJzLCBvbmx5IHRoZSBhdXRob3JpemVyIGNhbiBncmFudC9yZXZva2UgdGhlIHJvbGUuAAAAAA5zZXRfcm9sZV9hZG1pbgAAAAAAAgAAAAAAAAAEcm9sZQAAABEAAAAAAAAACmFkbWluX3JvbGUAAAAAABEAAAAAAAAAAAAAANhSZW1vdmVzIHRoZSBhZG1pbiByb2xlIGZvciBhIHNwZWNpZmllZCByb2xlLiBDYWxsZXIgbXVzdCBiZSB0aGUgYXV0aG9yaXplci4KCiMgQXJndW1lbnRzCiogYHJvbGVgIC0gVGhlIHJvbGUgdG8gcmVtb3ZlIHRoZSBhZG1pbiBmb3IuCgojIEVycm9ycwoqIGBSYmFjRXJyb3I6OkFkbWluUm9sZU5vdEZvdW5kYCAtIElmIG5vIGFkbWluIHJvbGUgaXMgc2V0IGZvciB0aGUgcm9sZS4AAAARcmVtb3ZlX3JvbGVfYWRtaW4AAAAAAAABAAAAAAAAAARyb2xlAAAAEQAAAAAAAAAAAAAA9lJldHVybnMgYFNvbWUoaW5kZXgpYCBpZiB0aGUgYWNjb3VudCBoYXMgdGhlIHNwZWNpZmllZCByb2xlLCB3aGVyZSBgaW5kZXhgCmlzIHRoZSBpbmRleCBvZiB0aGUgYWNjb3VudCBpbiB0aGUgcm9sZS4gUmV0dXJucyBgTm9uZWAgaWYgbm90LgoKIyBBcmd1bWVudHMKKiBgYWNjb3VudGAgLSBUaGUgYWNjb3VudCB0byBjaGVjayB0aGUgcm9sZSBmb3IuCiogYHJvbGVgIC0gVGhlIHJvbGUgdG8gY2hlY2sgdGhlIGFjY291bnQgZm9yLgAAAAAACGhhc19yb2xlAAAAAgAAAAAAAAAHYWNjb3VudAAAAAATAAAAAAAAAARyb2xlAAAAEQAAAAEAAAPoAAAABAAAAAAAAAB2UmV0dXJucyB0aGUgYWRtaW4gcm9sZSBmb3IgYSBzcGVjaWZpYyByb2xlLCBvciBOb25lIGlmIG5vdCBzZXQuCgojIEFyZ3VtZW50cwoqIGByb2xlYCAtIFRoZSByb2xlIHRvIGdldCB0aGUgYWRtaW4gZm9yLgAAAAAADmdldF9yb2xlX2FkbWluAAAAAAABAAAAAAAAAARyb2xlAAAAEQAAAAEAAAPoAAAAEQAAAAAAAAB6UmV0dXJucyB0aGUgbnVtYmVyIG9mIGFjY291bnRzIHRoYXQgaGF2ZSB0aGUgc3BlY2lmaWVkIHJvbGUuCgojIEFyZ3VtZW50cwoqIGByb2xlYCAtIFRoZSByb2xlIHRvIGdldCB0aGUgbWVtYmVyIGNvdW50IGZvci4AAAAAABVnZXRfcm9sZV9tZW1iZXJfY291bnQAAAAAAAABAAAAAAAAAARyb2xlAAAAEQAAAAEAAAAEAAAAAAAAAOlSZXR1cm5zIHRoZSBhY2NvdW50IGF0IHRoZSBzcGVjaWZpZWQgaW5kZXggZm9yIGEgZ2l2ZW4gcm9sZS4KCiMgQXJndW1lbnRzCiogYHJvbGVgIC0gVGhlIHJvbGUgdG8gZ2V0IHRoZSBtZW1iZXIgZm9yLgoqIGBpbmRleGAgLSBUaGUgaW5kZXggb2YgdGhlIG1lbWJlciB0byBnZXQuCgojIEVycm9ycwoqIGBSYmFjRXJyb3I6OkluZGV4T3V0T2ZCb3VuZHNgIGlmIHRoZSBpbmRleCBpcyBvdXQgb2YgYm91bmRzLgAAAAAAAA9nZXRfcm9sZV9tZW1iZXIAAAAAAgAAAAAAAAAEcm9sZQAAABEAAAAAAAAABWluZGV4AAAAAAAABAAAAAEAAAATAAAAAAAAAPJSZXR1cm5zIGFsbCByb2xlcyB0aGF0IGN1cnJlbnRseSBoYXZlIGF0IGxlYXN0IG9uZSBtZW1iZXIuCkRlZmF1bHRzIHRvIGVtcHR5IHZlY3RvciBpZiBubyByb2xlcyBleGlzdC4KCiMgTm90ZXMKClRoaXMgZnVuY3Rpb24gcmV0dXJucyBhbGwgcm9sZXMgdGhhdCBjdXJyZW50bHkgaGF2ZSBhdCBsZWFzdCBvbmUgbWVtYmVyLgpUaGUgbWF4aW11bSBudW1iZXIgb2Ygcm9sZXMgaXMgbGltaXRlZCBieSBbYE1BWF9ST0xFU2BdLgAAAAAAEmdldF9leGlzdGluZ19yb2xlcwAAAAAAAAAAAAEAAAPqAAAAEQAAAAAAAAAAAAAACXNldF9hZG1pbgAAAAAAAAIAAAAAAAAACW5ld19hZG1pbgAAAAAAABMAAAAAAAAACG9wZXJhdG9yAAAAEwAAAAAAAAAAAAAAAAAAAA5zZXRfYXV0aG9yaXplZAAAAAAAAwAAAAAAAAACaWQAAAAAABMAAAAAAAAACWF1dGhvcml6ZQAAAAAAAAEAAAAAAAAACG9wZXJhdG9yAAAAEwAAAAAAAAAAAAAAAAAAAAhjbGF3YmFjawAAAAMAAAAAAAAABGZyb20AAAATAAAAAAAAAAZhbW91bnQAAAAAAAsAAAAAAAAACG9wZXJhdG9yAAAAEwAAAAAAAAAAAAAAAAAAAARtaW50AAAAAwAAAAAAAAACdG8AAAAAABMAAAAAAAAABmFtb3VudAAAAAAACwAAAAAAAAAIb3BlcmF0b3IAAAATAAAAAAAAAAAAAAC3Q29uc3RydWN0cyB0aGUgU0FDIG1hbmFnZXIgY29udHJhY3QuCgojIEFyZ3VtZW50cwoqIGBzYWNfdG9rZW5gIC0gVGhlIHVuZGVybHlpbmcgU3RlbGxhciBBc3NldCBDb250cmFjdCBhZGRyZXNzCiogYG93bmVyYCAtIFRoZSBpbml0aWFsIG93bmVyIGFkZHJlc3MgKGZvciBUVEwgbWFuYWdlbWVudCwgcm9sZSBncmFudHMpAAAAAA1fX2NvbnN0cnVjdG9yAAAAAAAAAgAAAAAAAAAJc2FjX3Rva2VuAAAAAAAAEwAAAAAAAAAFb3duZXIAAAAAAAATAAAAAAAAAAAAAAA8UmV0dXJucyB0aGUgdW5kZXJseWluZyBTQUMgKFN0ZWxsYXIgQXNzZXQgQ29udHJhY3QpIGFkZHJlc3MuAAAADnVuZGVybHlpbmdfc2FjAAAAAAAAAAAAAQAAABMAAAAAAAAAAAAAAAphdXRob3JpemVyAAAAAAAAAAAAAQAAA+gAAAATAAAAAAAAAD5SZXR1cm5zIHRoZSBjdXJyZW50IG93bmVyIGFkZHJlc3MsIG9yIE5vbmUgaWYgbm8gb3duZXIgaXMgc2V0LgAAAAAABW93bmVyAAAAAAAAAAAAAAEAAAPoAAAAEwAAAAAAAABZUmV0dXJucyB0aGUgcGVuZGluZyBvd25lciBhZGRyZXNzIGZvciAyLXN0ZXAgdHJhbnNmZXIsIG9yIE5vbmUgaWYgbm8gdHJhbnNmZXIgaXMgcGVuZGluZy4AAAAAAAANcGVuZGluZ19vd25lcgAAAAAAAAAAAAABAAAD6AAAABMAAAAAAAABK1RyYW5zZmVycyBvd25lcnNoaXAgaW1tZWRpYXRlbHkgdG8gYSBuZXcgYWRkcmVzcy4KClVzZSB3aXRoIGNhdXRpb24gLSBpZiB5b3UgdHJhbnNmZXIgdG8gYSB3cm9uZyBhZGRyZXNzLCBvd25lcnNoaXAgaXMgbG9zdCBmb3JldmVyLgpDb25zaWRlciB1c2luZyBgcHJvcG9zZV9vd25lcnNoaXBfdHJhbnNmZXJgIGluc3RlYWQuCgojIFBhbmljcwotIGBPd25lck5vdFNldGAgaWYgbm8gb3duZXIgaXMgY3VycmVudGx5IHNldAotIGBUcmFuc2ZlckluUHJvZ3Jlc3NgIGlmIGEgMi1zdGVwIHRyYW5zZmVyIGlzIGluIHByb2dyZXNzAAAAABJ0cmFuc2Zlcl9vd25lcnNoaXAAAAAAAAEAAAAAAAAACW5ld19vd25lcgAAAAAAABMAAAAAAAAAAAAAAlxQcm9wb3NlcyBhbiBvd25lcnNoaXAgdHJhbnNmZXIgdG8gYSBuZXcgYWRkcmVzcy4KClRoZSBuZXcgb3duZXIgbXVzdCBjYWxsIGBhY2NlcHRfb3duZXJzaGlwKClgIHdpdGhpbiBgdHRsYCBsZWRnZXJzCnRvIGNvbXBsZXRlIHRoZSB0cmFuc2Zlci4gVGhlIHBlbmRpbmcgdHJhbnNmZXIgd2lsbCBhdXRvbWF0aWNhbGx5IGV4cGlyZSBhZnRlci4KCiMgQXJndW1lbnRzCi0gYG5ld19vd25lcmAgLSBUaGUgcHJvcG9zZWQgbmV3IG93bmVyCi0gYHR0bGAgLSBOdW1iZXIgb2YgbGVkZ2VycyB0aGUgbmV3IG93bmVyIGhhcyB0byBhY2NlcHQuClVzZSBgMGAgdG8gY2FuY2VsIGEgcGVuZGluZyB0cmFuc2ZlciAobmV3X293bmVyIG11c3QgbWF0Y2ggcGVuZGluZykuCgojIFBhbmljcwotIGBPd25lck5vdFNldGAgaWYgbm8gb3duZXIgaXMgY3VycmVudGx5IHNldAotIGBOb1BlbmRpbmdUcmFuc2ZlcmAgd2hlbiBjYW5jZWxsaW5nIGFuZCBubyBwZW5kaW5nIHRyYW5zZmVyIGV4aXN0cwotIGBJbnZhbGlkVHRsYCBpZiB0dGwgZXhjZWVkcyBtYXggVFRMCi0gYEludmFsaWRQZW5kaW5nT3duZXJgIHdoZW4gY2FuY2VsbGluZyB3aXRoIHdyb25nIG5ld19vd25lciBhZGRyZXNzAAAAGnByb3Bvc2Vfb3duZXJzaGlwX3RyYW5zZmVyAAAAAAACAAAAAAAAAAluZXdfb3duZXIAAAAAAAATAAAAAAAAAAN0dGwAAAAABAAAAAAAAAAAAAAAuUFjY2VwdHMgYSBwZW5kaW5nIDItc3RlcCBvd25lcnNoaXAgdHJhbnNmZXIuCgpNdXN0IGJlIGNhbGxlZCBieSB0aGUgcGVuZGluZyBvd25lciBiZWZvcmUgdGhlIFRUTCBleHBpcmVzLgoKIyBQYW5pY3MKLSBgTm9QZW5kaW5nVHJhbnNmZXJgIGlmIHRoZXJlIGlzIG5vIHBlbmRpbmcgdHJhbnNmZXIgKG9yIGl0IGV4cGlyZWQpAAAAAAAAEGFjY2VwdF9vd25lcnNoaXAAAAAAAAAAAAAAAAAAAACkUGVybWFuZW50bHkgcmVub3VuY2VzIG93bmVyc2hpcC4KCiMgUGFuaWNzCi0gYE93bmVyTm90U2V0YCBpZiBubyBvd25lciBpcyBjdXJyZW50bHkgc2V0Ci0gYFRyYW5zZmVySW5Qcm9ncmVzc2AgaWYgYSAyLXN0ZXAgdHJhbnNmZXIgaXMgaW4gcHJvZ3Jlc3MgKGNhbmNlbCBpdCBmaXJzdCkAAAAScmVub3VuY2Vfb3duZXJzaGlwAAAAAAAAAAAAAAAAAAAAAAClRXh0ZW5kcyB0aGUgaW5zdGFuY2UgVFRMLgoKIyBBcmd1bWVudHMKCiogYHRocmVzaG9sZGAgLSBUaGUgdGhyZXNob2xkIHRvIGV4dGVuZCB0aGUgVFRMIChpZiBjdXJyZW50IFRUTCBpcyBiZWxvdyB0aGlzLCBleHRlbmQpLgoqIGBleHRlbmRfdG9gIC0gVGhlIFRUTCB0byBleHRlbmQgdG8uAAAAAAAAE2V4dGVuZF9pbnN0YW5jZV90dGwAAAAAAgAAAAAAAAAJdGhyZXNob2xkAAAAAAAABAAAAAAAAAAJZXh0ZW5kX3RvAAAAAAAABAAAAAAAAAAAAAABj1NldHMgVFRMIGNvbmZpZ3MgZm9yIGluc3RhbmNlIGFuZCBwZXJzaXN0ZW50IHN0b3JhZ2UuCgotIGBOb25lYCB2YWx1ZXMgcmVtb3ZlIHRoZSBjb3JyZXNwb25kaW5nIGNvbmZpZyAoZGlzYWJsZXMgYXV0by1leHRlbnNpb24gZm9yIHRoYXQgdHlwZSkKLSBWYWxpZGF0ZXMgdGhhdCBgdGhyZXNob2xkIDw9IGV4dGVuZF90byA8PSBNQVhfVFRMYAoKIyBBcmd1bWVudHMKLSBgaW5zdGFuY2VgIC0gVFRMIGNvbmZpZyBmb3IgaW5zdGFuY2Ugc3RvcmFnZQotIGBwZXJzaXN0ZW50YCAtIFRUTCBjb25maWcgZm9yIHBlcnNpc3RlbnQgc3RvcmFnZQoKIyBQYW5pY3MKLSBgVHRsQ29uZmlnRnJvemVuYCBpZiBjb25maWdzIGFyZSBmcm96ZW4KLSBgSW52YWxpZFR0bENvbmZpZ2AgaWYgdmFsaWRhdGlvbiBmYWlscwAAAAAPc2V0X3R0bF9jb25maWdzAAAAAAIAAAAAAAAACGluc3RhbmNlAAAD6AAAB9AAAAAJVHRsQ29uZmlnAAAAAAAAAAAAAApwZXJzaXN0ZW50AAAAAAPoAAAH0AAAAAlUdGxDb25maWcAAAAAAAAAAAAAAAAAAEhSZXR1cm5zIHRoZSBjdXJyZW50IFRUTCBjb25maWdzIGFzIChpbnN0YW5jZV9jb25maWcsIHBlcnNpc3RlbnRfY29uZmlnKS4AAAALdHRsX2NvbmZpZ3MAAAAAAAAAAAEAAAPtAAAAAgAAA+gAAAfQAAAACVR0bENvbmZpZwAAAAAAA+gAAAfQAAAACVR0bENvbmZpZwAAAAAAAAAAAADhUGVybWFuZW50bHkgZnJlZXplcyBUVEwgY29uZmlncywgcHJldmVudGluZyBhbnkgZnV0dXJlIG1vZGlmaWNhdGlvbnMuCgpUaGlzIGlzIGlycmV2ZXJzaWJsZSBhbmQgcHJvdmlkZXMgaW1tdXRhYmlsaXR5IGd1YXJhbnRlZXMgdG8gdXNlcnMuCkVtaXRzIGBUdGxDb25maWdzRnJvemVuYCBldmVudC4KCiMgUGFuaWNzCi0gYFR0bENvbmZpZ0FscmVhZHlGcm96ZW5gIGlmIGFscmVhZHkgZnJvemVuAAAAAAAAEmZyZWV6ZV90dGxfY29uZmlncwAAAAAAAAAAAAAAAAAAAAAAJ1JldHVybnMgd2hldGhlciBUVEwgY29uZmlncyBhcmUgZnJvemVuLgAAAAAVaXNfdHRsX2NvbmZpZ3NfZnJvemVuAAAAAAAAAAAAAAEAAAABAAAAAgAAAAAAAAAAAAAAEVNBQ01hbmFnZXJTdG9yYWdlAAAAAAAAAQAAAAAAAAAAAAAACFNhY1Rva2VuAAAABAAAABxCdWZmZXJSZWFkZXJFcnJvcjogMTAwMC0xMDA5AAAAAAAAABFCdWZmZXJSZWFkZXJFcnJvcgAAAAAAAAIAAAAAAAAADUludmFsaWRMZW5ndGgAAAAAAAPoAAAAAAAAABVJbnZhbGlkQWRkcmVzc1BheWxvYWQAAAAAAAPpAAAABAAAABxCdWZmZXJXcml0ZXJFcnJvcjogMTAxMC0xMDE5AAAAAAAAABFCdWZmZXJXcml0ZXJFcnJvcgAAAAAAAAEAAAAAAAAAFUludmFsaWRBZGRyZXNzUGF5bG9hZAAAAAAAA/IAAAAEAAAAH1R0bENvbmZpZ3VyYWJsZUVycm9yOiAxMDIwLTEwMjkAAAAAAAAAABRUdGxDb25maWd1cmFibGVFcnJvcgAAAAMAAAAAAAAAEEludmFsaWRUdGxDb25maWcAAAP8AAAAAAAAAA9UdGxDb25maWdGcm96ZW4AAAAD/QAAAAAAAAAWVHRsQ29uZmlnQWxyZWFkeUZyb3plbgAAAAAD/gAAAAQAAAAXT3duYWJsZUVycm9yOiAxMDMwLTEwMzkAAAAAAAAAAAxPd25hYmxlRXJyb3IAAAAHAAAAAAAAABFJbnZhbGlkQXV0aG9yaXplcgAAAAAABAYAAAAAAAAAE0ludmFsaWRQZW5kaW5nT3duZXIAAAAEBwAAAAAAAAAKSW52YWxpZFR0bAAAAAAECAAAAAAAAAARTm9QZW5kaW5nVHJhbnNmZXIAAAAAAAQJAAAAAAAAAA9Pd25lckFscmVhZHlTZXQAAAAECgAAAAAAAAALT3duZXJOb3RTZXQAAAAECwAAAAAAAAASVHJhbnNmZXJJblByb2dyZXNzAAAAAAQMAAAABAAAABhCeXRlc0V4dEVycm9yOiAxMDQwLTEwNDkAAAAAAAAADUJ5dGVzRXh0RXJyb3IAAAAAAAABAAAAAAAAAA5MZW5ndGhNaXNtYXRjaAAAAAAEEAAAAAQAAAAbVXBncmFkZWFibGVFcnJvcjogMTA1MC0xMDU5AAAAAAAAAAAQVXBncmFkZWFibGVFcnJvcgAAAAIAAAAAAAAAFEludmFsaWRNaWdyYXRpb25EYXRhAAAEGgAAAAAAAAATTWlncmF0aW9uTm90QWxsb3dlZAAAAAQbAAAABAAAABhNdWx0aVNpZ0Vycm9yOiAxMDYwLTEwNjkAAAAAAAAADU11bHRpU2lnRXJyb3IAAAAAAAAJAAAAAAAAABJBbHJlYWR5SW5pdGlhbGl6ZWQAAAAABCQAAAAAAAAAEUludmFsaWRBdXRob3JpemVyAAAAAAAEJQAAAAAAAAANSW52YWxpZFNpZ25lcgAAAAAABCYAAAAAAAAADlNpZ25hdHVyZUVycm9yAAAAAAQnAAAAAAAAABNTaWduZXJBbHJlYWR5RXhpc3RzAAAABCgAAAAAAAAADlNpZ25lck5vdEZvdW5kAAAAAAQpAAAAAAAAAB1Ub3RhbFNpZ25lcnNMZXNzVGhhblRocmVzaG9sZAAAAAAABCoAAAAAAAAAD1Vuc29ydGVkU2lnbmVycwAAAAQrAAAAAAAAAA1aZXJvVGhyZXNob2xkAAAAAAAELAAAAAQAAAAUQXV0aEVycm9yOiAxMDcwLTEwNzkAAAAAAAAACUF1dGhFcnJvcgAAAAAAAAEAAAAAAAAAEkF1dGhvcml6ZXJOb3RGb3VuZAAAAAAELgAAAAQAAAAUUmJhY0Vycm9yOiAxMDgwLTEwODkAAAAAAAAACVJiYWNFcnJvcgAAAAAAAAcAAAAAAAAAEUFkbWluUm9sZU5vdEZvdW5kAAAAAAAEOAAAAAAAAAAQSW5kZXhPdXRPZkJvdW5kcwAABDkAAAAAAAAAEE1heFJvbGVzRXhjZWVkZWQAAAQ6AAAAAAAAAAtSb2xlSXNFbXB0eQAAAAQ7AAAAAAAAAAxSb2xlTm90Rm91bmQAAAQ8AAAAAAAAAAtSb2xlTm90SGVsZAAAAAQ9AAAAAAAAAAxVbmF1dGhvcml6ZWQAAAQ+AAAABQAAADBFdmVudCBlbWl0dGVkIHdoZW4gYSBzaWduZXIgaXMgYWRkZWQgb3IgcmVtb3ZlZC4AAAAAAAAACVNpZ25lclNldAAAAAAAAAEAAAAKc2lnbmVyX3NldAAAAAAAAgAAAAAAAAAGc2lnbmVyAAAAAAPuAAAAFAAAAAEAAAAAAAAABmFjdGl2ZQAAAAAAAQAAAAAAAAACAAAABQAAADZFdmVudCBlbWl0dGVkIHdoZW4gdGhlIHNpZ25hdHVyZSB0aHJlc2hvbGQgaXMgY2hhbmdlZC4AAAAAAAAAAAAMVGhyZXNob2xkU2V0AAAAAQAAAA10aHJlc2hvbGRfc2V0AAAAAAAAAQAAAAAAAAAJdGhyZXNob2xkAAAAAAAABAAAAAAAAAACAAAAAgAAAAAAAAAAAAAAD011bHRpU2lnU3RvcmFnZQAAAAACAAAAAAAAAAAAAAAHU2lnbmVycwAAAAAAAAAAAAAAAAlUaHJlc2hvbGQAAAAAAAAFAAAAV0V2ZW50IGVtaXR0ZWQgd2hlbiBvd25lcnNoaXAgaXMgdHJhbnNmZXJyZWQgKGJvdGggc2luZ2xlLXN0ZXAgYW5kIHR3by1zdGVwIGNvbXBsZXRpb24pLgAAAAAAAAAAFE93bmVyc2hpcFRyYW5zZmVycmVkAAAAAQAAABVvd25lcnNoaXBfdHJhbnNmZXJyZWQAAAAAAAACAAAAAAAAAAlvbGRfb3duZXIAAAAAAAATAAAAAAAAAAAAAAAJbmV3X293bmVyAAAAAAAAEwAAAAAAAAACAAAABQAAADtFdmVudCBlbWl0dGVkIHdoZW4gYSAyLXN0ZXAgb3duZXJzaGlwIHRyYW5zZmVyIGlzIHByb3Bvc2VkLgAAAAAAAAAAFU93bmVyc2hpcFRyYW5zZmVycmluZwAAAAAAAAEAAAAWb3duZXJzaGlwX3RyYW5zZmVycmluZwAAAAAAAwAAAAAAAAAJb2xkX293bmVyAAAAAAAAEwAAAAAAAAAAAAAACW5ld19vd25lcgAAAAAAABMAAAAAAAAAAAAAAAN0dGwAAAAABAAAAAAAAAACAAAABQAAADxFdmVudCBlbWl0dGVkIHdoZW4gYSAyLXN0ZXAgb3duZXJzaGlwIHRyYW5zZmVyIGlzIGNhbmNlbGxlZC4AAAAAAAAAGk93bmVyc2hpcFRyYW5zZmVyQ2FuY2VsbGVkAAAAAAABAAAAHG93bmVyc2hpcF90cmFuc2Zlcl9jYW5jZWxsZWQAAAACAAAAAAAAAAVvd25lcgAAAAAAABMAAAAAAAAAAAAAABdjYW5jZWxsZWRfcGVuZGluZ19vd25lcgAAAAATAAAAAAAAAAIAAAAF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";
12
12
  /**
13
13
  * Pre-computed WASM hash (SHA-256)
14
14
  * Use this when the WASM is already uploaded on-chain
15
15
  */
16
- export declare const WASM_HASH = "58e728063a91a34a0a9ec7ef6acb934f01b87c349e4e481a05d9cc710a07a75f";
16
+ export declare const WASM_HASH = "5d91c1f0a5adf949d96bc6e53a72c38928ec7397a3b5d0ad6c6bf97b188af2dd";
17
17
  /**
18
18
  * Get the WASM bytecode as a Buffer
19
19
  * Use this to upload the WASM to the network
20
20
  */
21
21
  export declare function getWasmBuffer(): Buffer;
22
- /**
23
- * General SacManagerError: 3220-3249
24
- */
25
- export declare const SacManagerError: {
26
- /**
27
- * The address is already a minter
28
- */
29
- 1: {
30
- message: string;
31
- };
32
- /**
33
- * Minter address not in the minters list (e.g. when deactivating)
34
- */
35
- 2: {
36
- message: string;
37
- };
38
- /**
39
- * Caller is not authorized for this operation
40
- */
41
- 3: {
42
- message: string;
43
- };
44
- };
45
- export type SacManagerStorage = {
22
+ export type SACManagerStorage = {
46
23
  tag: "SacToken";
47
24
  values: void;
48
- } | {
49
- tag: "Minters";
50
- values: void;
51
- };
52
- export declare const EndpointError: {
53
- /**
54
- * Library is already registered with the endpoint
55
- */
56
- 1: {
57
- message: string;
58
- };
59
- /**
60
- * Compose message already exists for this GUID and index
61
- */
62
- 2: {
63
- message: string;
64
- };
65
- /**
66
- * Compose message not found for the given GUID and index
67
- */
68
- 3: {
69
- message: string;
70
- };
71
- /**
72
- * Default receive library is not set for the source endpoint
73
- */
74
- 4: {
75
- message: string;
76
- };
77
- /**
78
- * Default send library is not set for the destination endpoint
79
- */
80
- 5: {
81
- message: string;
82
- };
83
- /**
84
- * Supplied native token fee is less than required
85
- */
86
- 6: {
87
- message: string;
88
- };
89
- /**
90
- * Supplied ZRO token fee is less than required
91
- */
92
- 7: {
93
- message: string;
94
- };
95
- /**
96
- * Timeout expiry is invalid (already expired)
97
- */
98
- 8: {
99
- message: string;
100
- };
101
- /**
102
- * Fee amount is invalid (negative)
103
- */
104
- 9: {
105
- message: string;
106
- };
107
- /**
108
- * Compose index exceeds maximum allowed value
109
- */
110
- 10: {
111
- message: string;
112
- };
113
- /**
114
- * Nonce is invalid for the requested operation
115
- */
116
- 11: {
117
- message: string;
118
- };
119
- /**
120
- * Payload hash is invalid (empty hash not allowed)
121
- */
122
- 12: {
123
- message: string;
124
- };
125
- /**
126
- * Receive library is not valid for the receiver and source endpoint
127
- */
128
- 13: {
129
- message: string;
130
- };
131
- /**
132
- * Operation requires a non-default (custom) library
133
- */
134
- 14: {
135
- message: string;
136
- };
137
- /**
138
- * Library must support receiving messages
139
- */
140
- 15: {
141
- message: string;
142
- };
143
- /**
144
- * Library must be registered with the endpoint
145
- */
146
- 16: {
147
- message: string;
148
- };
149
- /**
150
- * Library must support sending messages
151
- */
152
- 17: {
153
- message: string;
154
- };
155
- /**
156
- * Messaging path cannot be initialized for the given origin
157
- */
158
- 18: {
159
- message: string;
160
- };
161
- /**
162
- * Message cannot be verified for the given origin
163
- */
164
- 19: {
165
- message: string;
166
- };
167
- /**
168
- * Payload hash does not match the stored hash
169
- */
170
- 20: {
171
- message: string;
172
- };
173
- /**
174
- * New value is the same as existing value
175
- */
176
- 21: {
177
- message: string;
178
- };
179
- /**
180
- * Caller is not authorized (not OApp or delegate)
181
- */
182
- 22: {
183
- message: string;
184
- };
185
- /**
186
- * Endpoint ID is not supported by the library
187
- */
188
- 23: {
189
- message: string;
190
- };
191
- /**
192
- * ZRO fee must be greater than zero when pay_in_zro is true
193
- */
194
- 24: {
195
- message: string;
196
- };
197
- /**
198
- * ZRO token address is not set
199
- */
200
- 25: {
201
- message: string;
202
- };
203
- };
204
- /**
205
- * Parameters for sending a cross-chain message.
206
- */
207
- export interface MessagingParams {
208
- /**
209
- * Destination endpoint ID (chain identifier).
210
- */
211
- dst_eid: u32;
212
- /**
213
- * The message payload to send.
214
- */
215
- message: Buffer;
216
- /**
217
- * Encoded executor and DVN options.
218
- */
219
- options: Buffer;
220
- /**
221
- * Whether to pay fees in ZRO token instead of native token.
222
- */
223
- pay_in_zro: boolean;
224
- /**
225
- * Receiver address on the destination chain (32 bytes).
226
- */
227
- receiver: Buffer;
228
- }
229
- /**
230
- * Source message information identifying where a cross-chain message came from.
231
- */
232
- export interface Origin {
233
- /**
234
- * Nonce for this pathway.
235
- */
236
- nonce: u64;
237
- /**
238
- * Sender address on the source chain (32 bytes).
239
- */
240
- sender: Buffer;
241
- /**
242
- * Source endpoint ID (chain identifier).
243
- */
244
- src_eid: u32;
245
- }
246
- /**
247
- * Fee structure for cross-chain messaging.
248
- */
249
- export interface MessagingFee {
250
- /**
251
- * Fee paid in native token (XLM).
252
- */
253
- native_fee: i128;
254
- /**
255
- * Fee paid in ZRO token (LayerZero token).
256
- */
257
- zro_fee: i128;
258
- }
259
- /**
260
- * Receipt returned after successfully sending a cross-chain message.
261
- */
262
- export interface MessagingReceipt {
263
- /**
264
- * The fees charged for sending the message.
265
- */
266
- fee: MessagingFee;
267
- /**
268
- * Globally unique identifier for the message.
269
- */
270
- guid: Buffer;
271
- /**
272
- * The outbound nonce for this pathway.
273
- */
274
- nonce: u64;
275
- }
276
- /**
277
- * Type of message library indicating supported operations.
278
- */
279
- export type MessageLibType = {
280
- tag: "Send";
281
- values: void;
282
- } | {
283
- tag: "Receive";
284
- values: void;
285
- } | {
286
- tag: "SendAndReceive";
287
- values: void;
288
- };
289
- /**
290
- * Version information for a message library.
291
- *
292
- * Note: `minor` and `endpoint_version` use `u32` instead of `u8` because Stellar does not
293
- * support `u8` types in contract interface functions.
294
- */
295
- export interface MessageLibVersion {
296
- /**
297
- * Endpoint version (should not exceed u8::MAX = 255).
298
- */
299
- endpoint_version: u32;
300
- /**
301
- * Major version number.
302
- */
303
- major: u64;
304
- /**
305
- * Minor version number (should not exceed u8::MAX = 255).
306
- */
307
- minor: u32;
308
- }
309
- /**
310
- * Timeout configuration for receive library transitions.
311
- */
312
- export interface Timeout {
313
- /**
314
- * Unix timestamp in seconds when the timeout expires.
315
- */
316
- expiry: u64;
317
- /**
318
- * The old library address that remains valid during the grace period.
319
- */
320
- lib: string;
321
- }
322
- /**
323
- * Parameters for setting message library configuration.
324
- */
325
- export interface SetConfigParam {
326
- /**
327
- * XDR-encoded configuration data.
328
- */
329
- config: Buffer;
330
- /**
331
- * The type of configuration (e.g., executor, ULN).
332
- */
333
- config_type: u32;
334
- /**
335
- * The endpoint ID this config applies to.
336
- */
337
- eid: u32;
338
- }
339
- /**
340
- * Resolved library information with default status.
341
- */
342
- export interface ResolvedLibrary {
343
- /**
344
- * Whether this is the default library (true) or OApp-specific (false).
345
- */
346
- is_default: boolean;
347
- /**
348
- * The resolved library address.
349
- */
350
- lib: string;
351
- }
352
- /**
353
- * Outbound packet containing all information for cross-chain transmission.
354
- */
355
- export interface OutboundPacket {
356
- /**
357
- * Destination endpoint ID.
358
- */
359
- dst_eid: u32;
360
- /**
361
- * Globally unique identifier for this message.
362
- */
363
- guid: Buffer;
364
- /**
365
- * The message payload.
366
- */
367
- message: Buffer;
368
- /**
369
- * Outbound nonce for this pathway.
370
- */
371
- nonce: u64;
372
- /**
373
- * Receiver address on destination chain (32 bytes).
374
- */
375
- receiver: Buffer;
376
- /**
377
- * Sender address on source chain.
378
- */
379
- sender: string;
380
- /**
381
- * Source endpoint ID.
382
- */
383
- src_eid: u32;
384
- }
385
- /**
386
- * A fee recipient with the amount to be paid.
387
- */
388
- export interface FeeRecipient {
389
- /**
390
- * Amount of fee to pay.
391
- */
392
- amount: i128;
393
- /**
394
- * The address to send the fee to.
395
- */
396
- to: string;
397
- }
398
- /**
399
- * Result of send operation containing fees and encoded packet.
400
- */
401
- export interface FeesAndPacket {
402
- /**
403
- * The encoded packet ready for transmission.
404
- */
405
- encoded_packet: Buffer;
406
- /**
407
- * List of native token fee recipients (executor, DVNs, treasury).
408
- */
409
- native_fee_recipients: Array<FeeRecipient>;
410
- /**
411
- * List of ZRO token fee recipients (treasury).
412
- */
413
- zro_fee_recipients: Array<FeeRecipient>;
414
- }
415
- export type OAppCoreStorage = {
416
- tag: "Endpoint";
417
- values: void;
418
- } | {
419
- tag: "Peer";
420
- values: readonly [u32];
421
- };
422
- export interface EnforcedOptionParam {
423
- eid: u32;
424
- msg_type: u32;
425
- options: Option<Buffer>;
426
- }
427
- export type OAppOptionsType3Storage = {
428
- tag: "EnforcedOptions";
429
- values: readonly [u32, u32];
430
- };
431
- /**
432
- * Represents a fee payer address with explicit authorization state.
433
- *
434
- * This enum forces callers of `__lz_send` to explicitly declare whether
435
- * `require_auth()` has already been called for the fee payer address.
436
- * This prevents the common mistake of forgetting to authorize the fee payer.
437
- *
438
- * # Variants
439
- * - `Unverified` — Safe default. `__lz_send` will call `require_auth()` on the address.
440
- * Use this when the caller has **not** already authorized the fee payer.
441
- * - `Verified` — Caller asserts that `require_auth()` has already been called.
442
- * Use this to avoid a duplicate `require_auth()` node in the Soroban auth tree
443
- * (e.g., when the same address was already authorized as the message sender).
444
- */
445
- export type FeePayer = {
446
- tag: "Unverified";
447
- values: readonly [string];
448
- } | {
449
- tag: "Verified";
450
- values: readonly [string];
451
- };
452
- /**
453
- * OAppError: 2000-2099
454
- */
455
- export declare const OAppError: {
456
- 2000: {
457
- message: string;
458
- };
459
- 2001: {
460
- message: string;
461
- };
462
- 2002: {
463
- message: string;
464
- };
465
- 2003: {
466
- message: string;
467
- };
468
- };
469
- export type OFTFeeStorage = {
470
- tag: "DefaultFeeBps";
471
- values: void;
472
- } | {
473
- tag: "FeeBps";
474
- values: readonly [u32];
475
- } | {
476
- tag: "FeeDepositAddress";
477
- values: void;
478
- };
479
- export declare const OFTFeeError: {
480
- 3100: {
481
- message: string;
482
- };
483
- 3101: {
484
- message: string;
485
- };
486
- 3102: {
487
- message: string;
488
- };
489
- };
490
- export type OFTPausableStorage = {
491
- tag: "Paused";
492
- values: void;
493
- };
494
- export declare const OFTPausableError: {
495
- 3110: {
496
- message: string;
497
- };
498
- 3111: {
499
- message: string;
500
- };
501
- };
502
- export type Direction = {
503
- tag: "Inbound";
504
- values: void;
505
- } | {
506
- tag: "Outbound";
507
- values: void;
508
- };
509
- export type Mode = {
510
- tag: "Net";
511
- values: void;
512
- } | {
513
- tag: "Gross";
514
- values: void;
515
- };
516
- /**
517
- * Configuration for rate limiting, used as input parameter.
518
- */
519
- export interface RateLimitConfig {
520
- limit: i128;
521
- mode: Mode;
522
- window_seconds: u64;
523
- }
524
- export declare const RateLimitError: {
525
- 3120: {
526
- message: string;
527
- };
528
- 3121: {
529
- message: string;
530
- };
531
- 3122: {
532
- message: string;
533
- };
534
- 3123: {
535
- message: string;
536
- };
537
- 3124: {
538
- message: string;
539
- };
540
- };
541
- /**
542
- * The OFT operation type.
543
- */
544
- export type OftType = {
545
- tag: "LockUnlock";
546
- values: void;
547
- } | {
548
- tag: "MintBurn";
549
- values: readonly [string];
550
25
  };
551
- export type OFTStorage = {
552
- tag: "DecimalsDiff";
553
- values: void;
554
- } | {
555
- tag: "Token";
556
- values: void;
557
- } | {
558
- tag: "MsgInspector";
559
- values: void;
560
- };
561
- /**
562
- * OFTError: 3000-3099
563
- */
564
- export declare const OFTError: {
565
- 3000: {
566
- message: string;
567
- };
568
- 3001: {
569
- message: string;
570
- };
571
- 3002: {
572
- message: string;
573
- };
574
- 3003: {
575
- message: string;
576
- };
577
- 3004: {
578
- message: string;
579
- };
580
- 3005: {
581
- message: string;
582
- };
583
- };
584
- /**
585
- * Parameters for sending OFT tokens cross-chain
586
- */
587
- export interface SendParam {
588
- /**
589
- * The amount to send in local decimals
590
- */
591
- amount_ld: i128;
592
- /**
593
- * Compose message to execute on the destination (Optional)
594
- */
595
- compose_msg: Buffer;
596
- /**
597
- * The destination endpoint ID
598
- */
599
- dst_eid: u32;
600
- /**
601
- * Additional options for the LayerZero message (Optional)
602
- */
603
- extra_options: Buffer;
604
- /**
605
- * The minimum amount to receive in local decimals (slippage protection)
606
- */
607
- min_amount_ld: i128;
608
- /**
609
- * OFT command for custom behavior (Optional)
610
- */
611
- oft_cmd: Buffer;
612
- /**
613
- * The recipient address on the destination chain (32 bytes)
614
- */
615
- to: Buffer;
616
- }
617
- /**
618
- * Transfer limits for OFT operations
619
- */
620
- export interface OFTLimit {
621
- /**
622
- * The maximum amount to send in local decimals
623
- */
624
- max_amount_ld: i128;
625
- /**
626
- * The minimum amount to send in local decimals
627
- */
628
- min_amount_ld: i128;
629
- }
630
- /**
631
- * Receipt containing amounts sent and received in an OFT transfer
632
- */
633
- export interface OFTReceipt {
634
- /**
635
- * The amount received in local decimals on the remote
636
- */
637
- amount_received_ld: i128;
638
- /**
639
- * The amount sent in local decimals
640
- */
641
- amount_sent_ld: i128;
642
- }
643
- /**
644
- * Details about fees charged in an OFT operation
645
- */
646
- export interface OFTFeeDetail {
647
- /**
648
- * The description of the fee
649
- */
650
- description: Buffer;
651
- /**
652
- * The amount of the fee in local decimals. Positive values represent fees charged,
653
- * while negative values represent rewards given.
654
- */
655
- fee_amount_ld: i128;
656
- }
657
26
  /**
658
27
  * BufferReaderError: 1000-1009
659
28
  */
@@ -764,6 +133,40 @@ export declare const MultiSigError: {
764
133
  message: string;
765
134
  };
766
135
  };
136
+ /**
137
+ * AuthError: 1070-1079
138
+ */
139
+ export declare const AuthError: {
140
+ 1070: {
141
+ message: string;
142
+ };
143
+ };
144
+ /**
145
+ * RbacError: 1080-1089
146
+ */
147
+ export declare const RbacError: {
148
+ 1080: {
149
+ message: string;
150
+ };
151
+ 1081: {
152
+ message: string;
153
+ };
154
+ 1082: {
155
+ message: string;
156
+ };
157
+ 1083: {
158
+ message: string;
159
+ };
160
+ 1084: {
161
+ message: string;
162
+ };
163
+ 1085: {
164
+ message: string;
165
+ };
166
+ 1086: {
167
+ message: string;
168
+ };
169
+ };
767
170
  export type MultiSigStorage = {
768
171
  tag: "Signers";
769
172
  values: void;
@@ -778,6 +181,22 @@ export type OwnableStorage = {
778
181
  tag: "PendingOwner";
779
182
  values: void;
780
183
  };
184
+ export type RbacStorage = {
185
+ tag: "ExistingRoles";
186
+ values: void;
187
+ } | {
188
+ tag: "RoleIndexToAccount";
189
+ values: readonly [string, u32];
190
+ } | {
191
+ tag: "RoleAccountToIndex";
192
+ values: readonly [string, string];
193
+ } | {
194
+ tag: "RoleAccountsCount";
195
+ values: readonly [string];
196
+ } | {
197
+ tag: "RoleAdmin";
198
+ values: readonly [string];
199
+ };
781
200
  /**
782
201
  * TTL configuration: threshold (when to extend) and extend_to (target TTL).
783
202
  */
@@ -807,74 +226,175 @@ export type UpgradeableStorage = {
807
226
  };
808
227
  export interface Client {
809
228
  /**
810
- * 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.
811
- */
812
- mint: ({ to, amount, operation }: {
813
- to: string;
814
- amount: i128;
815
- operation: string;
229
+ * Construct and simulate a grant_role 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.
230
+ * Grants a role to an account. Caller must be owner or have the role's admin role.
231
+ *
232
+ * # Arguments
233
+ * * `account` - The account to grant the role to.
234
+ * * `role` - The role to grant.
235
+ * * `caller` - The account that is granting the role. Must be owner or have the role's admin role.
236
+ */
237
+ grant_role: ({ account, role, caller }: {
238
+ account: string;
239
+ role: string;
240
+ caller: string;
816
241
  }, txnOptions?: MethodOptions) => Promise<AssembledTransaction<null>>;
817
242
  /**
818
- * 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.
819
- * Delegates to the underlying SAC to clawback `amount` from `from` account.
820
- */
821
- clawback: ({ from, amount }: {
822
- from: string;
823
- amount: i128;
243
+ * Construct and simulate a revoke_role 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.
244
+ * Revokes a role from an account. Caller must be owner or have the role's admin role.
245
+ *
246
+ * # Arguments
247
+ * * `account` - The account to revoke the role from.
248
+ * * `role` - The role to revoke.
249
+ * * `caller` - The account that is revoking the role. Must be owner or have the role's admin role.
250
+ */
251
+ revoke_role: ({ account, role, caller }: {
252
+ account: string;
253
+ role: string;
254
+ caller: string;
824
255
  }, txnOptions?: MethodOptions) => Promise<AssembledTransaction<null>>;
825
256
  /**
826
- * 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.
827
- * Delegates to the underlying SAC `set_admin` to release the admin role from the current contract to `to`.
257
+ * Construct and simulate a renounce_role 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.
258
+ * Allows an account to renounce a role assigned to itself.
259
+ * Users can only renounce roles for their own account.
260
+ *
261
+ * # Arguments
262
+ * * `role` - The role to renounce.
263
+ * * `caller` - The account that is renouncing the role. Must be the account itself.
828
264
  */
829
- release_sac_admin: ({ to }: {
830
- to: string;
265
+ renounce_role: ({ role, caller }: {
266
+ role: string;
267
+ caller: string;
831
268
  }, txnOptions?: MethodOptions) => Promise<AssembledTransaction<null>>;
832
269
  /**
833
- * 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.
834
- * Delegates to the underlying SAC `set_authorized` to set whether `id` is authorized to use its balance.
270
+ * Construct and simulate a set_role_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.
271
+ * Sets `admin_role` as the admin role of `role`. Caller must be the authorizer.
272
+ *
273
+ * # Arguments
274
+ * * `role` - The role to set the admin for.
275
+ * * `admin_role` - The admin role to set for the role.
276
+ *
277
+ * # Notes
278
+ *
279
+ * The admin role can be any `Symbol`, including one with no members. If the admin
280
+ * role has no members, only the authorizer can grant/revoke the role.
835
281
  */
836
- set_authorized: ({ id, authorize }: {
837
- id: string;
838
- authorize: boolean;
282
+ set_role_admin: ({ role, admin_role }: {
283
+ role: string;
284
+ admin_role: string;
839
285
  }, txnOptions?: MethodOptions) => Promise<AssembledTransaction<null>>;
840
286
  /**
841
- * Construct and simulate a set_minter 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.
842
- * Adds (`active = true`) or removes (`active = false`) a minter.
287
+ * Construct and simulate a remove_role_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.
288
+ * Removes the admin role for a specified role. Caller must be the authorizer.
289
+ *
290
+ * # Arguments
291
+ * * `role` - The role to remove the admin for.
292
+ *
293
+ * # Errors
294
+ * * `RbacError::AdminRoleNotFound` - If no admin role is set for the role.
843
295
  */
844
- set_minter: ({ minter, active }: {
845
- minter: string;
846
- active: boolean;
296
+ remove_role_admin: ({ role }: {
297
+ role: string;
847
298
  }, txnOptions?: MethodOptions) => Promise<AssembledTransaction<null>>;
848
299
  /**
849
- * 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.
850
- * Returns the underlying SAC (Stellar Asset Contract) address.
300
+ * Construct and simulate a has_role 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.
301
+ * Returns `Some(index)` if the account has the specified role, where `index`
302
+ * is the index of the account in the role. Returns `None` if not.
303
+ *
304
+ * # Arguments
305
+ * * `account` - The account to check the role for.
306
+ * * `role` - The role to check the account for.
851
307
  */
852
- underlying_sac: (options?: MethodOptions) => Promise<AssembledTransaction<string>>;
308
+ has_role: ({ account, role }: {
309
+ account: string;
310
+ role: string;
311
+ }, txnOptions?: MethodOptions) => Promise<AssembledTransaction<Option<u32>>>;
312
+ /**
313
+ * Construct and simulate a get_role_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.
314
+ * Returns the admin role for a specific role, or None if not set.
315
+ *
316
+ * # Arguments
317
+ * * `role` - The role to get the admin for.
318
+ */
319
+ get_role_admin: ({ role }: {
320
+ role: string;
321
+ }, txnOptions?: MethodOptions) => Promise<AssembledTransaction<Option<string>>>;
853
322
  /**
854
- * Construct and simulate a minters 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.
855
- * Returns the list of addresses authorized to call mint.
323
+ * Construct and simulate a get_role_member_count 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.
324
+ * Returns the number of accounts that have the specified role.
325
+ *
326
+ * # Arguments
327
+ * * `role` - The role to get the member count for.
856
328
  */
857
- minters: (options?: MethodOptions) => Promise<AssembledTransaction<Array<string>>>;
329
+ get_role_member_count: ({ role }: {
330
+ role: string;
331
+ }, txnOptions?: MethodOptions) => Promise<AssembledTransaction<u32>>;
858
332
  /**
859
- * 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.
860
- * Upgrades the contract to new WASM bytecode.
861
- * Sets a migration flag that must be cleared by calling `migrate`.
333
+ * Construct and simulate a get_role_member 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.
334
+ * Returns the account at the specified index for a given role.
335
+ *
336
+ * # Arguments
337
+ * * `role` - The role to get the member for.
338
+ * * `index` - The index of the member to get.
339
+ *
340
+ * # Errors
341
+ * * `RbacError::IndexOutOfBounds` if the index is out of bounds.
862
342
  */
863
- upgrade: ({ new_wasm_hash }: {
864
- new_wasm_hash: Buffer;
343
+ get_role_member: ({ role, index }: {
344
+ role: string;
345
+ index: u32;
346
+ }, txnOptions?: MethodOptions) => Promise<AssembledTransaction<string>>;
347
+ /**
348
+ * Construct and simulate a get_existing_roles 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.
349
+ * Returns all roles that currently have at least one member.
350
+ * Defaults to empty vector if no roles exist.
351
+ *
352
+ * # Notes
353
+ *
354
+ * This function returns all roles that currently have at least one member.
355
+ * The maximum number of roles is limited by [`MAX_ROLES`].
356
+ */
357
+ get_existing_roles: (options?: MethodOptions) => Promise<AssembledTransaction<Array<string>>>;
358
+ /**
359
+ * Construct and simulate a set_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.
360
+ */
361
+ set_admin: ({ new_admin, operator }: {
362
+ new_admin: string;
363
+ operator: string;
364
+ }, txnOptions?: MethodOptions) => Promise<AssembledTransaction<null>>;
365
+ /**
366
+ * 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.
367
+ */
368
+ set_authorized: ({ id, authorize, operator }: {
369
+ id: string;
370
+ authorize: boolean;
371
+ operator: string;
372
+ }, txnOptions?: MethodOptions) => Promise<AssembledTransaction<null>>;
373
+ /**
374
+ * 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.
375
+ */
376
+ clawback: ({ from, amount, operator }: {
377
+ from: string;
378
+ amount: i128;
379
+ operator: string;
865
380
  }, txnOptions?: MethodOptions) => Promise<AssembledTransaction<null>>;
866
381
  /**
867
- * 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.
868
- * Runs migration logic after an upgrade.
869
- * Parses XDR-encoded `migration_data` and calls `__migrate`. Clears the migration flag on success.
382
+ * 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.
870
383
  */
871
- migrate: ({ migration_data }: {
872
- migration_data: Buffer;
384
+ mint: ({ to, amount, operator }: {
385
+ to: string;
386
+ amount: i128;
387
+ operator: string;
873
388
  }, txnOptions?: MethodOptions) => Promise<AssembledTransaction<null>>;
389
+ /**
390
+ * 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.
391
+ * Returns the underlying SAC (Stellar Asset Contract) address.
392
+ */
393
+ underlying_sac: (options?: MethodOptions) => Promise<AssembledTransaction<string>>;
874
394
  /**
875
395
  * 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.
876
396
  */
877
- authorizer: (options?: MethodOptions) => Promise<AssembledTransaction<string>>;
397
+ authorizer: (options?: MethodOptions) => Promise<AssembledTransaction<Option<string>>>;
878
398
  /**
879
399
  * 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.
880
400
  * Returns the current owner address, or None if no owner is set.
@@ -1013,16 +533,22 @@ export declare class Client extends ContractClient {
1013
533
  }): Promise<AssembledTransaction<T>>;
1014
534
  constructor(options: ContractClientOptions);
1015
535
  readonly fromJSON: {
1016
- mint: (json: string) => AssembledTransaction<null>;
1017
- clawback: (json: string) => AssembledTransaction<null>;
1018
- release_sac_admin: (json: string) => AssembledTransaction<null>;
536
+ grant_role: (json: string) => AssembledTransaction<null>;
537
+ revoke_role: (json: string) => AssembledTransaction<null>;
538
+ renounce_role: (json: string) => AssembledTransaction<null>;
539
+ set_role_admin: (json: string) => AssembledTransaction<null>;
540
+ remove_role_admin: (json: string) => AssembledTransaction<null>;
541
+ has_role: (json: string) => AssembledTransaction<Option<number>>;
542
+ get_role_admin: (json: string) => AssembledTransaction<Option<string>>;
543
+ get_role_member_count: (json: string) => AssembledTransaction<number>;
544
+ get_role_member: (json: string) => AssembledTransaction<string>;
545
+ get_existing_roles: (json: string) => AssembledTransaction<string[]>;
546
+ set_admin: (json: string) => AssembledTransaction<null>;
1019
547
  set_authorized: (json: string) => AssembledTransaction<null>;
1020
- set_minter: (json: string) => AssembledTransaction<null>;
548
+ clawback: (json: string) => AssembledTransaction<null>;
549
+ mint: (json: string) => AssembledTransaction<null>;
1021
550
  underlying_sac: (json: string) => AssembledTransaction<string>;
1022
- minters: (json: string) => AssembledTransaction<string[]>;
1023
- upgrade: (json: string) => AssembledTransaction<null>;
1024
- migrate: (json: string) => AssembledTransaction<null>;
1025
- authorizer: (json: string) => AssembledTransaction<string>;
551
+ authorizer: (json: string) => AssembledTransaction<Option<string>>;
1026
552
  owner: (json: string) => AssembledTransaction<Option<string>>;
1027
553
  pending_owner: (json: string) => AssembledTransaction<Option<string>>;
1028
554
  transfer_ownership: (json: string) => AssembledTransaction<null>;