@bitgo-beta/sdk-coin-polyx 1.0.0-alpha.7 → 1.0.0-alpha.71

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 (82) hide show
  1. package/CHANGELOG.md +109 -0
  2. package/dist/src/index.d.ts +1 -0
  3. package/dist/src/index.d.ts.map +1 -1
  4. package/dist/src/index.js +2 -1
  5. package/dist/src/lib/baseBuilder.d.ts +24 -0
  6. package/dist/src/lib/baseBuilder.d.ts.map +1 -0
  7. package/dist/src/lib/baseBuilder.js +31 -0
  8. package/dist/src/lib/batchStakingBuilder.d.ts +79 -0
  9. package/dist/src/lib/batchStakingBuilder.d.ts.map +1 -0
  10. package/dist/src/lib/batchStakingBuilder.js +299 -0
  11. package/dist/src/lib/batchUnstakingBuilder.d.ts +39 -0
  12. package/dist/src/lib/batchUnstakingBuilder.d.ts.map +1 -0
  13. package/dist/src/lib/batchUnstakingBuilder.js +127 -0
  14. package/dist/src/lib/bondExtraBuilder.d.ts +37 -0
  15. package/dist/src/lib/bondExtraBuilder.d.ts.map +1 -0
  16. package/dist/src/lib/bondExtraBuilder.js +101 -0
  17. package/dist/src/lib/constants.d.ts +12 -0
  18. package/dist/src/lib/constants.d.ts.map +1 -0
  19. package/dist/src/lib/constants.js +15 -0
  20. package/dist/src/lib/iface.d.ts +124 -3
  21. package/dist/src/lib/iface.d.ts.map +1 -1
  22. package/dist/src/lib/iface.js +36 -1
  23. package/dist/src/lib/index.d.ts +15 -7
  24. package/dist/src/lib/index.d.ts.map +1 -1
  25. package/dist/src/lib/index.js +42 -36
  26. package/dist/src/lib/preApproveAssetBuilder.d.ts +33 -0
  27. package/dist/src/lib/preApproveAssetBuilder.d.ts.map +1 -0
  28. package/dist/src/lib/preApproveAssetBuilder.js +77 -0
  29. package/dist/src/lib/registerDidWithCDDBuilder.d.ts +34 -0
  30. package/dist/src/lib/registerDidWithCDDBuilder.d.ts.map +1 -0
  31. package/dist/src/lib/registerDidWithCDDBuilder.js +83 -0
  32. package/dist/src/lib/tokenTransferBuilder.d.ts +58 -0
  33. package/dist/src/lib/tokenTransferBuilder.d.ts.map +1 -0
  34. package/dist/src/lib/tokenTransferBuilder.js +152 -0
  35. package/dist/src/lib/transaction.d.ts +18 -4
  36. package/dist/src/lib/transaction.d.ts.map +1 -1
  37. package/dist/src/lib/transaction.js +136 -8
  38. package/dist/src/lib/transactionBuilderFactory.d.ts +27 -5
  39. package/dist/src/lib/transactionBuilderFactory.d.ts.map +1 -1
  40. package/dist/src/lib/transactionBuilderFactory.js +112 -8
  41. package/dist/src/lib/transferBuilder.d.ts +51 -3
  42. package/dist/src/lib/transferBuilder.d.ts.map +1 -1
  43. package/dist/src/lib/transferBuilder.js +109 -3
  44. package/dist/src/lib/txnSchema.d.ts +49 -0
  45. package/dist/src/lib/txnSchema.d.ts.map +1 -0
  46. package/dist/src/lib/txnSchema.js +129 -0
  47. package/dist/src/lib/unbondBuilder.d.ts +37 -0
  48. package/dist/src/lib/unbondBuilder.d.ts.map +1 -0
  49. package/dist/src/lib/unbondBuilder.js +98 -0
  50. package/dist/src/lib/utils.d.ts +15 -14
  51. package/dist/src/lib/utils.d.ts.map +1 -1
  52. package/dist/src/lib/utils.js +40 -23
  53. package/dist/src/lib/withdrawUnbondedBuilder.d.ts +35 -0
  54. package/dist/src/lib/withdrawUnbondedBuilder.d.ts.map +1 -0
  55. package/dist/src/lib/withdrawUnbondedBuilder.js +89 -0
  56. package/dist/src/polyx.d.ts +42 -9
  57. package/dist/src/polyx.d.ts.map +1 -1
  58. package/dist/src/polyx.js +252 -16
  59. package/dist/src/polyxToken.d.ts +20 -0
  60. package/dist/src/polyxToken.d.ts.map +1 -0
  61. package/dist/src/polyxToken.js +55 -0
  62. package/dist/src/register.d.ts.map +1 -1
  63. package/dist/src/register.js +5 -1
  64. package/dist/src/resources/index.d.ts +3 -0
  65. package/dist/src/resources/index.d.ts.map +1 -0
  66. package/dist/src/resources/index.js +19 -0
  67. package/dist/src/resources/mainnet.d.ts +13 -0
  68. package/dist/src/resources/mainnet.d.ts.map +1 -0
  69. package/dist/src/resources/mainnet.js +16 -0
  70. package/dist/src/resources/testnet.d.ts +13 -0
  71. package/dist/src/resources/testnet.d.ts.map +1 -0
  72. package/dist/src/resources/testnet.js +16 -0
  73. package/dist/src/tpolyx.d.ts +7 -0
  74. package/dist/src/tpolyx.d.ts.map +1 -1
  75. package/dist/src/tpolyx.js +11 -1
  76. package/package.json +15 -9
  77. package/dist/src/lib/keyPair.d.ts +0 -12
  78. package/dist/src/lib/keyPair.d.ts.map +0 -1
  79. package/dist/src/lib/keyPair.js +0 -24
  80. package/dist/src/lib/transactionBuilder.d.ts +0 -43
  81. package/dist/src/lib/transactionBuilder.d.ts.map +0 -1
  82. package/dist/src/lib/transactionBuilder.js +0 -78
package/CHANGELOG.md CHANGED
@@ -3,6 +3,115 @@
3
3
  All notable changes to this project will be documented in this file.
4
4
  See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
5
5
 
6
+ # [1.6.0](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-coin-polyx@1.5.6...@bitgo/sdk-coin-polyx@1.6.0) (2025-08-07)
7
+
8
+ ### Features
9
+
10
+ - add polyxToken skeleton ([c7be0ef](https://github.com/BitGo/BitGoJS/commit/c7be0efb003c720e9da732b627576336c7fc9e52))
11
+ - **sdk-coin-polyx:** add wrw support ([24ec106](https://github.com/BitGo/BitGoJS/commit/24ec106158e0f7330dc61c467b466904fb9e068b))
12
+
13
+ ## [1.5.6](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-coin-polyx@1.5.5...@bitgo/sdk-coin-polyx@1.5.6) (2025-07-31)
14
+
15
+ **Note:** Version bump only for package @bitgo/sdk-coin-polyx
16
+
17
+ ## [1.5.5](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-coin-polyx@1.5.4...@bitgo/sdk-coin-polyx@1.5.5) (2025-07-30)
18
+
19
+ **Note:** Version bump only for package @bitgo/sdk-coin-polyx
20
+
21
+ ## [1.5.4](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-coin-polyx@1.5.2...@bitgo/sdk-coin-polyx@1.5.4) (2025-07-25)
22
+
23
+ **Note:** Version bump only for package @bitgo/sdk-coin-polyx
24
+
25
+ ## [1.5.3](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-coin-polyx@1.5.2...@bitgo/sdk-coin-polyx@1.5.3) (2025-07-23)
26
+
27
+ **Note:** Version bump only for package @bitgo/sdk-coin-polyx
28
+
29
+ ## [1.5.2](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-coin-polyx@1.5.1...@bitgo/sdk-coin-polyx@1.5.2) (2025-07-15)
30
+
31
+ **Note:** Version bump only for package @bitgo/sdk-coin-polyx
32
+
33
+ ## [1.5.1](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-coin-polyx@1.5.0...@bitgo/sdk-coin-polyx@1.5.1) (2025-07-10)
34
+
35
+ ### Bug Fixes
36
+
37
+ - **sdk-coin-polyx:** add mainnet address format ([4d02932](https://github.com/BitGo/BitGoJS/commit/4d02932045d5d6f02a9127cb189a5e71dc803f38))
38
+
39
+ # [1.5.0](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-coin-polyx@1.4.2...@bitgo/sdk-coin-polyx@1.5.0) (2025-07-03)
40
+
41
+ ### Features
42
+
43
+ - **sdk-coin-polyx:** implement unbond builder ([4d449f7](https://github.com/BitGo/BitGoJS/commit/4d449f71685856a20b47cbf5eb561999b71986e5))
44
+
45
+ ## [1.4.2](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-coin-polyx@1.4.1...@bitgo/sdk-coin-polyx@1.4.2) (2025-06-25)
46
+
47
+ **Note:** Version bump only for package @bitgo/sdk-coin-polyx
48
+
49
+ ## [1.4.1](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-coin-polyx@1.4.0...@bitgo/sdk-coin-polyx@1.4.1) (2025-06-24)
50
+
51
+ ### Bug Fixes
52
+
53
+ - decoding logic to differentiate b/w stake and unstake batch ([2d82c4e](https://github.com/BitGo/BitGoJS/commit/2d82c4e572c94cb5b770301428c107da22f84448))
54
+ - **sdk-coin-polyx:** add address format for polyx and tpolyx ([7748439](https://github.com/BitGo/BitGoJS/commit/774843999a56b793775f119c0f3a4f6a49d40a73))
55
+
56
+ # [1.4.0](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-coin-polyx@1.3.1...@bitgo/sdk-coin-polyx@1.4.0) (2025-06-18)
57
+
58
+ ### Features
59
+
60
+ - add decoding support for polyx staking related txns ([f680b01](https://github.com/BitGo/BitGoJS/commit/f680b011c6c89b4c3c04ede21f089e8efc1c0ee8))
61
+
62
+ ## [1.3.1](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-coin-polyx@1.3.0...@bitgo/sdk-coin-polyx@1.3.1) (2025-06-10)
63
+
64
+ **Note:** Version bump only for package @bitgo/sdk-coin-polyx
65
+
66
+ # [1.3.0](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-coin-polyx@1.2.0...@bitgo/sdk-coin-polyx@1.3.0) (2025-06-05)
67
+
68
+ ### Features
69
+
70
+ - add batchStakingBuilder (bond and nominate) and bondExtraBuilder for polyx ([cd29662](https://github.com/BitGo/BitGoJS/commit/cd296620fb013ebd48ec89bb4bcf1bf0433ec7d4))
71
+ - add batchUnstakingBuilder and withdrawUnbondedBuilder ([d86c459](https://github.com/BitGo/BitGoJS/commit/d86c459f1c42c1d5cbf93b7ba408760b617bf328))
72
+ - **root:** support node 22 ([c4ad6af](https://github.com/BitGo/BitGoJS/commit/c4ad6af2e8896221417c303f0f6b84652b493216))
73
+
74
+ # [1.2.0](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-coin-polyx@1.1.2...@bitgo/sdk-coin-polyx@1.2.0) (2025-06-02)
75
+
76
+ ### Bug Fixes
77
+
78
+ - **sdk-coin-polyx:** fix to toJson method in polyx transaction ([8f8ef0b](https://github.com/BitGo/BitGoJS/commit/8f8ef0b8fa420dadb41989465b2380af73466ae0))
79
+
80
+ ### Features
81
+
82
+ - rename audit function naming and signature ([1a885ab](https://github.com/BitGo/BitGoJS/commit/1a885ab60d30ca8595e284a728f2ab9d3c09994e))
83
+
84
+ ## [1.1.2](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-coin-polyx@1.1.1...@bitgo/sdk-coin-polyx@1.1.2) (2025-05-28)
85
+
86
+ **Note:** Version bump only for package @bitgo/sdk-coin-polyx
87
+
88
+ ## [1.1.1](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-coin-polyx@1.1.0...@bitgo/sdk-coin-polyx@1.1.1) (2025-05-22)
89
+
90
+ ### Bug Fixes
91
+
92
+ - **sdk-coin-polyx:** all fixed ([f9c23bc](https://github.com/BitGo/BitGoJS/commit/f9c23bc9a8bc609be5f41a4ffd980138ecb63148))
93
+ - **sdk-coin-polyx:** fix cdd builder ([2461fbf](https://github.com/BitGo/BitGoJS/commit/2461fbfcc76f8f6e7f89302f5e3c4b99097cb97a))
94
+
95
+ # [1.1.0](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-coin-polyx@1.0.4...@bitgo/sdk-coin-polyx@1.1.0) (2025-05-20)
96
+
97
+ ### Features
98
+
99
+ - **sdk-coin-polyx:** add transaction builders ([31c96bb](https://github.com/BitGo/BitGoJS/commit/31c96bbbce60b93e13208e3eab06bd144cfe57e4))
100
+
101
+ ## [1.0.4](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-coin-polyx@1.0.3...@bitgo/sdk-coin-polyx@1.0.4) (2025-05-07)
102
+
103
+ ### Bug Fixes
104
+
105
+ - send statics coin to substrate class ([9ed860e](https://github.com/BitGo/BitGoJS/commit/9ed860ed288516959d5723e6119c7701588a41e7))
106
+
107
+ ## [1.0.3](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-coin-polyx@1.0.2...@bitgo/sdk-coin-polyx@1.0.3) (2025-04-29)
108
+
109
+ **Note:** Version bump only for package @bitgo/sdk-coin-polyx
110
+
111
+ ## [1.0.2](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-coin-polyx@1.0.1...@bitgo/sdk-coin-polyx@1.0.2) (2025-04-25)
112
+
113
+ **Note:** Version bump only for package @bitgo/sdk-coin-polyx
114
+
6
115
  ## 1.0.1 (2025-04-15)
7
116
 
8
117
  **Note:** Version bump only for package @bitgo/sdk-coin-polyx
@@ -2,4 +2,5 @@ export * from './lib';
2
2
  export * from './register';
3
3
  export * from './polyx';
4
4
  export * from './tpolyx';
5
+ export * from './polyxToken';
5
6
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,OAAO,CAAC;AACtB,cAAc,YAAY,CAAC;AAC3B,cAAc,SAAS,CAAC;AACxB,cAAc,UAAU,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,OAAO,CAAC;AACtB,cAAc,YAAY,CAAC;AAC3B,cAAc,SAAS,CAAC;AACxB,cAAc,UAAU,CAAC;AACzB,cAAc,cAAc,CAAC"}
package/dist/src/index.js CHANGED
@@ -18,4 +18,5 @@ __exportStar(require("./lib"), exports);
18
18
  __exportStar(require("./register"), exports);
19
19
  __exportStar(require("./polyx"), exports);
20
20
  __exportStar(require("./tpolyx"), exports);
21
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLHdDQUFzQjtBQUN0Qiw2Q0FBMkI7QUFDM0IsMENBQXdCO0FBQ3hCLDJDQUF5QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliJztcbmV4cG9ydCAqIGZyb20gJy4vcmVnaXN0ZXInO1xuZXhwb3J0ICogZnJvbSAnLi9wb2x5eCc7XG5leHBvcnQgKiBmcm9tICcuL3Rwb2x5eCc7XG4iXX0=
21
+ __exportStar(require("./polyxToken"), exports);
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLHdDQUFzQjtBQUN0Qiw2Q0FBMkI7QUFDM0IsMENBQXdCO0FBQ3hCLDJDQUF5QjtBQUN6QiwrQ0FBNkIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2xpYic7XG5leHBvcnQgKiBmcm9tICcuL3JlZ2lzdGVyJztcbmV4cG9ydCAqIGZyb20gJy4vcG9seXgnO1xuZXhwb3J0ICogZnJvbSAnLi90cG9seXgnO1xuZXhwb3J0ICogZnJvbSAnLi9wb2x5eFRva2VuJztcbiJdfQ==
@@ -0,0 +1,24 @@
1
+ import { TransactionBuilder } from '@bitgo-beta/abstract-substrate';
2
+ import { Transaction } from './transaction';
3
+ import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';
4
+ import { TransactionType } from '@bitgo-beta/sdk-core';
5
+ import { DecodedSignedTx, DecodedSigningPayload, UnsignedTransaction } from '@substrate/txwrapper-core';
6
+ import { TxMethod } from './iface';
7
+ /**
8
+ * Base builder class for Polyx transactions
9
+ * Extends the abstract-substrate TransactionBuilder with Polyx-specific functionality
10
+ */
11
+ export declare abstract class PolyxBaseBuilder<M = TxMethod, T extends Transaction = Transaction> extends TransactionBuilder<M, T> {
12
+ constructor(_coinConfig: Readonly<CoinConfig>);
13
+ /**
14
+ * Override the getAddressFormat method to return different values based on network type
15
+ * Returns 12 for mainnet and 42 for testnet
16
+ *
17
+ * @returns {number} The address format to use
18
+ */
19
+ protected getAddressFormat(): number;
20
+ protected abstract buildTransaction(): UnsignedTransaction;
21
+ protected abstract get transactionType(): TransactionType;
22
+ abstract validateDecodedTransaction(decodedTxn: DecodedSigningPayload | DecodedSignedTx, rawTransaction?: string): void;
23
+ }
24
+ //# sourceMappingURL=baseBuilder.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"baseBuilder.d.ts","sourceRoot":"","sources":["../../../src/lib/baseBuilder.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,gCAAgC,CAAC;AACpE,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,EAAE,eAAe,EAAE,qBAAqB,EAAE,mBAAmB,EAAE,MAAM,2BAA2B,CAAC;AACxG,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAGnC;;;GAGG;AACH,8BAAsB,gBAAgB,CAAC,CAAC,GAAG,QAAQ,EAAE,CAAC,SAAS,WAAW,GAAG,WAAW,CAAE,SAAQ,kBAAkB,CAClH,CAAC,EACD,CAAC,CACF;gBACa,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;IAM7C;;;;;OAKG;IACH,SAAS,CAAC,gBAAgB,IAAI,MAAM;IAKpC,SAAS,CAAC,QAAQ,CAAC,gBAAgB,IAAI,mBAAmB;IAC1D,SAAS,CAAC,QAAQ,KAAK,eAAe,IAAI,eAAe,CAAC;IAC1D,QAAQ,CAAC,0BAA0B,CACjC,UAAU,EAAE,qBAAqB,GAAG,eAAe,EACnD,cAAc,CAAC,EAAE,MAAM,GACtB,IAAI;CACR"}
@@ -0,0 +1,31 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.PolyxBaseBuilder = void 0;
7
+ const abstract_substrate_1 = require("@bitgo-beta/abstract-substrate");
8
+ const transaction_1 = require("./transaction");
9
+ const utils_1 = __importDefault(require("./utils"));
10
+ /**
11
+ * Base builder class for Polyx transactions
12
+ * Extends the abstract-substrate TransactionBuilder with Polyx-specific functionality
13
+ */
14
+ class PolyxBaseBuilder extends abstract_substrate_1.TransactionBuilder {
15
+ constructor(_coinConfig) {
16
+ super(_coinConfig);
17
+ // Override the transaction instance with our PolyX-specific Transaction
18
+ this._transaction = new transaction_1.Transaction(_coinConfig);
19
+ }
20
+ /**
21
+ * Override the getAddressFormat method to return different values based on network type
22
+ * Returns 12 for mainnet and 42 for testnet
23
+ *
24
+ * @returns {number} The address format to use
25
+ */
26
+ getAddressFormat() {
27
+ return utils_1.default.getAddressFormat(this._coinConfig.name);
28
+ }
29
+ }
30
+ exports.PolyxBaseBuilder = PolyxBaseBuilder;
31
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZUJ1aWxkZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL2Jhc2VCdWlsZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLHVFQUFvRTtBQUNwRSwrQ0FBNEM7QUFLNUMsb0RBQTRCO0FBRTVCOzs7R0FHRztBQUNILE1BQXNCLGdCQUFvRSxTQUFRLHVDQUdqRztJQUNDLFlBQVksV0FBaUM7UUFDM0MsS0FBSyxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQ25CLHdFQUF3RTtRQUN4RSxJQUFJLENBQUMsWUFBWSxHQUFHLElBQUkseUJBQVcsQ0FBQyxXQUFXLENBQU0sQ0FBQztJQUN4RCxDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDTyxnQkFBZ0I7UUFDeEIsT0FBTyxlQUFLLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN2RCxDQUFDO0NBU0Y7QUEzQkQsNENBMkJDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVHJhbnNhY3Rpb25CdWlsZGVyIH0gZnJvbSAnQGJpdGdvLWJldGEvYWJzdHJhY3Qtc3Vic3RyYXRlJztcbmltcG9ydCB7IFRyYW5zYWN0aW9uIH0gZnJvbSAnLi90cmFuc2FjdGlvbic7XG5pbXBvcnQgeyBCYXNlQ29pbiBhcyBDb2luQ29uZmlnIH0gZnJvbSAnQGJpdGdvLWJldGEvc3RhdGljcyc7XG5pbXBvcnQgeyBUcmFuc2FjdGlvblR5cGUgfSBmcm9tICdAYml0Z28tYmV0YS9zZGstY29yZSc7XG5pbXBvcnQgeyBEZWNvZGVkU2lnbmVkVHgsIERlY29kZWRTaWduaW5nUGF5bG9hZCwgVW5zaWduZWRUcmFuc2FjdGlvbiB9IGZyb20gJ0BzdWJzdHJhdGUvdHh3cmFwcGVyLWNvcmUnO1xuaW1wb3J0IHsgVHhNZXRob2QgfSBmcm9tICcuL2lmYWNlJztcbmltcG9ydCB1dGlscyBmcm9tICcuL3V0aWxzJztcblxuLyoqXG4gKiBCYXNlIGJ1aWxkZXIgY2xhc3MgZm9yIFBvbHl4IHRyYW5zYWN0aW9uc1xuICogRXh0ZW5kcyB0aGUgYWJzdHJhY3Qtc3Vic3RyYXRlIFRyYW5zYWN0aW9uQnVpbGRlciB3aXRoIFBvbHl4LXNwZWNpZmljIGZ1bmN0aW9uYWxpdHlcbiAqL1xuZXhwb3J0IGFic3RyYWN0IGNsYXNzIFBvbHl4QmFzZUJ1aWxkZXI8TSA9IFR4TWV0aG9kLCBUIGV4dGVuZHMgVHJhbnNhY3Rpb24gPSBUcmFuc2FjdGlvbj4gZXh0ZW5kcyBUcmFuc2FjdGlvbkJ1aWxkZXI8XG4gIE0sXG4gIFRcbj4ge1xuICBjb25zdHJ1Y3RvcihfY29pbkNvbmZpZzogUmVhZG9ubHk8Q29pbkNvbmZpZz4pIHtcbiAgICBzdXBlcihfY29pbkNvbmZpZyk7XG4gICAgLy8gT3ZlcnJpZGUgdGhlIHRyYW5zYWN0aW9uIGluc3RhbmNlIHdpdGggb3VyIFBvbHlYLXNwZWNpZmljIFRyYW5zYWN0aW9uXG4gICAgdGhpcy5fdHJhbnNhY3Rpb24gPSBuZXcgVHJhbnNhY3Rpb24oX2NvaW5Db25maWcpIGFzIFQ7XG4gIH1cblxuICAvKipcbiAgICogT3ZlcnJpZGUgdGhlIGdldEFkZHJlc3NGb3JtYXQgbWV0aG9kIHRvIHJldHVybiBkaWZmZXJlbnQgdmFsdWVzIGJhc2VkIG9uIG5ldHdvcmsgdHlwZVxuICAgKiBSZXR1cm5zIDEyIGZvciBtYWlubmV0IGFuZCA0MiBmb3IgdGVzdG5ldFxuICAgKlxuICAgKiBAcmV0dXJucyB7bnVtYmVyfSBUaGUgYWRkcmVzcyBmb3JtYXQgdG8gdXNlXG4gICAqL1xuICBwcm90ZWN0ZWQgZ2V0QWRkcmVzc0Zvcm1hdCgpOiBudW1iZXIge1xuICAgIHJldHVybiB1dGlscy5nZXRBZGRyZXNzRm9ybWF0KHRoaXMuX2NvaW5Db25maWcubmFtZSk7XG4gIH1cblxuICAvLyBUaGVzZSBtZXRob2RzIGFyZSBhYnN0cmFjdCBpbiB0aGUgcGFyZW50IGNsYXNzIGFuZCBtdXN0IGJlIGltcGxlbWVudGVkIGJ5IGNvbmNyZXRlIHN1YmNsYXNzZXNcbiAgcHJvdGVjdGVkIGFic3RyYWN0IGJ1aWxkVHJhbnNhY3Rpb24oKTogVW5zaWduZWRUcmFuc2FjdGlvbjtcbiAgcHJvdGVjdGVkIGFic3RyYWN0IGdldCB0cmFuc2FjdGlvblR5cGUoKTogVHJhbnNhY3Rpb25UeXBlO1xuICBhYnN0cmFjdCB2YWxpZGF0ZURlY29kZWRUcmFuc2FjdGlvbihcbiAgICBkZWNvZGVkVHhuOiBEZWNvZGVkU2lnbmluZ1BheWxvYWQgfCBEZWNvZGVkU2lnbmVkVHgsXG4gICAgcmF3VHJhbnNhY3Rpb24/OiBzdHJpbmdcbiAgKTogdm9pZDtcbn1cbiJdfQ==
@@ -0,0 +1,79 @@
1
+ import { Transaction } from './transaction';
2
+ import { PolyxBaseBuilder } from './baseBuilder';
3
+ import { DecodedSignedTx, DecodedSigningPayload, UnsignedTransaction } from '@substrate/txwrapper-core';
4
+ import { BaseCoin as CoinConfig } from '@bitgo-beta/statics';
5
+ import { BaseAddress, TransactionType } from '@bitgo-beta/sdk-core';
6
+ import { BondArgs, NominateArgs } from './iface';
7
+ export declare class BatchStakingBuilder extends PolyxBaseBuilder {
8
+ protected _amount: string;
9
+ protected _controller: string;
10
+ protected _payee: string | {
11
+ Account: string;
12
+ };
13
+ protected _validators: string[];
14
+ constructor(_coinConfig: Readonly<CoinConfig>);
15
+ protected get transactionType(): TransactionType;
16
+ /**
17
+ * Build a batch transaction that combines bond and nominate operations
18
+ * Both operations are required and always atomic (using batchAll)
19
+ */
20
+ protected buildTransaction(): UnsignedTransaction;
21
+ /**
22
+ * Set the staking amount for bond
23
+ */
24
+ amount(amount: string): this;
25
+ /**
26
+ * Get the staking amount
27
+ */
28
+ getAmount(): string;
29
+ /**
30
+ * Set the controller account for bond
31
+ */
32
+ controller(controller: BaseAddress): this;
33
+ /**
34
+ * Get the controller address
35
+ */
36
+ getController(): string;
37
+ /**
38
+ * Set the rewards destination for bond ('Staked', 'Stash','Controller', or { Account: string })
39
+ */
40
+ payee(payee: string | {
41
+ Account: string;
42
+ }): this;
43
+ /**
44
+ * Get the payee
45
+ */
46
+ getPayee(): string | {
47
+ Account: string;
48
+ };
49
+ /**
50
+ * Set the validators to nominate
51
+ */
52
+ validators(validators: string[]): this;
53
+ /**
54
+ * Get the validators to nominate
55
+ */
56
+ getValidators(): string[];
57
+ /** @inheritdoc */
58
+ validateDecodedTransaction(decodedTxn: DecodedSigningPayload | DecodedSignedTx): void;
59
+ /**
60
+ * Validate bond arguments
61
+ */
62
+ private validateBondArgs;
63
+ /**
64
+ * Validate nominate arguments
65
+ */
66
+ private validateNominateArgs;
67
+ /** @inheritdoc */
68
+ protected fromImplementation(rawTransaction: string): Transaction;
69
+ /** @inheritdoc */
70
+ validateTransaction(tx: Transaction): void;
71
+ /**
72
+ * Validate the builder fields
73
+ */
74
+ private validateFields;
75
+ testValidateFields(): void;
76
+ testValidateBondArgs(args: BondArgs): void;
77
+ testValidateNominateArgs(args: NominateArgs): void;
78
+ }
79
+ //# sourceMappingURL=batchStakingBuilder.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"batchStakingBuilder.d.ts","sourceRoot":"","sources":["../../../src/lib/batchStakingBuilder.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,EAAE,eAAe,EAAE,qBAAqB,EAAE,mBAAmB,EAAE,MAAM,2BAA2B,CAAC;AAExG,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,WAAW,EAA2B,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAG7F,OAAO,EAAa,QAAQ,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAmB5D,qBAAa,mBAAoB,SAAQ,gBAAgB;IAEvD,SAAS,CAAC,OAAO,EAAE,MAAM,CAAC;IAC1B,SAAS,CAAC,WAAW,EAAE,MAAM,CAAC;IAC9B,SAAS,CAAC,MAAM,EAAE,MAAM,GAAG;QAAE,OAAO,EAAE,MAAM,CAAA;KAAE,CAAC;IAG/C,SAAS,CAAC,WAAW,EAAE,MAAM,EAAE,CAAM;gBAEzB,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;IAK7C,SAAS,KAAK,eAAe,IAAI,eAAe,CAE/C;IAED;;;OAGG;IACH,SAAS,CAAC,gBAAgB,IAAI,mBAAmB;IA2CjD;;OAEG;IACH,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;IAM5B;;OAEG;IACH,SAAS,IAAI,MAAM;IAInB;;OAEG;IACH,UAAU,CAAC,UAAU,EAAE,WAAW,GAAG,IAAI;IAMzC;;OAEG;IACH,aAAa,IAAI,MAAM;IAIvB;;OAEG;IACH,KAAK,CAAC,KAAK,EAAE,MAAM,GAAG;QAAE,OAAO,EAAE,MAAM,CAAA;KAAE,GAAG,IAAI;IAShD;;OAEG;IACH,QAAQ,IAAI,MAAM,GAAG;QAAE,OAAO,EAAE,MAAM,CAAA;KAAE;IAIxC;;OAEG;IACH,UAAU,CAAC,UAAU,EAAE,MAAM,EAAE,GAAG,IAAI;IAQtC;;OAEG;IACH,aAAa,IAAI,MAAM,EAAE;IAIzB,kBAAkB;IAClB,0BAA0B,CAAC,UAAU,EAAE,qBAAqB,GAAG,eAAe,GAAG,IAAI;IA0CrF;;OAEG;IACH,OAAO,CAAC,gBAAgB;IA0CxB;;OAEG;IACH,OAAO,CAAC,oBAAoB;IAoB5B,kBAAkB;IAClB,SAAS,CAAC,kBAAkB,CAAC,cAAc,EAAE,MAAM,GAAG,WAAW;IA6DjE,kBAAkB;IAClB,mBAAmB,CAAC,EAAE,EAAE,WAAW,GAAG,IAAI;IAK1C;;OAEG;IACH,OAAO,CAAC,cAAc;IAkBtB,kBAAkB,IAAI,IAAI;IAInB,oBAAoB,CAAC,IAAI,EAAE,QAAQ,GAAG,IAAI;IAI1C,wBAAwB,CAAC,IAAI,EAAE,YAAY,GAAG,IAAI;CAG1D"}
@@ -0,0 +1,299 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.BatchStakingBuilder = void 0;
7
+ const baseBuilder_1 = require("./baseBuilder");
8
+ const txwrapper_polkadot_1 = require("@substrate/txwrapper-polkadot");
9
+ const sdk_core_1 = require("@bitgo-beta/sdk-core");
10
+ const txnSchema_1 = require("./txnSchema");
11
+ const utils_1 = __importDefault(require("./utils"));
12
+ const bignumber_js_1 = __importDefault(require("bignumber.js"));
13
+ class BatchStakingBuilder extends baseBuilder_1.PolyxBaseBuilder {
14
+ constructor(_coinConfig) {
15
+ super(_coinConfig);
16
+ // For nominate operation
17
+ this._validators = [];
18
+ this.material(utils_1.default.getMaterial(_coinConfig.network.type));
19
+ }
20
+ get transactionType() {
21
+ return sdk_core_1.TransactionType.Batch;
22
+ }
23
+ /**
24
+ * Build a batch transaction that combines bond and nominate operations
25
+ * Both operations are required and always atomic (using batchAll)
26
+ */
27
+ buildTransaction() {
28
+ // Ensure both bond and nominate operations are included
29
+ if (!this._amount || this._validators.length === 0) {
30
+ throw new sdk_core_1.InvalidTransactionError('Batch transaction must include both bond and nominate operations');
31
+ }
32
+ const baseTxInfo = this.createBaseTxInfo();
33
+ // Create the individual calls
34
+ const calls = [];
35
+ // Add bond call
36
+ const bondCall = txwrapper_polkadot_1.methods.staking.bond({
37
+ controller: this._controller || this._sender,
38
+ value: this._amount,
39
+ payee: this._payee || 'Staked',
40
+ }, baseTxInfo.baseTxInfo, baseTxInfo.options);
41
+ calls.push(bondCall.method);
42
+ // Add nominate call
43
+ const nominateCall = txwrapper_polkadot_1.methods.staking.nominate({
44
+ targets: this._validators,
45
+ }, baseTxInfo.baseTxInfo, baseTxInfo.options);
46
+ calls.push(nominateCall.method);
47
+ // Always use batchAll (atomic)
48
+ return txwrapper_polkadot_1.methods.utility.batchAll({
49
+ calls,
50
+ }, baseTxInfo.baseTxInfo, baseTxInfo.options);
51
+ }
52
+ /**
53
+ * Set the staking amount for bond
54
+ */
55
+ amount(amount) {
56
+ this.validateValue(new bignumber_js_1.default(amount));
57
+ this._amount = amount;
58
+ return this;
59
+ }
60
+ /**
61
+ * Get the staking amount
62
+ */
63
+ getAmount() {
64
+ return this._amount;
65
+ }
66
+ /**
67
+ * Set the controller account for bond
68
+ */
69
+ controller(controller) {
70
+ this.validateAddress(controller);
71
+ this._controller = controller.address;
72
+ return this;
73
+ }
74
+ /**
75
+ * Get the controller address
76
+ */
77
+ getController() {
78
+ return this._controller;
79
+ }
80
+ /**
81
+ * Set the rewards destination for bond ('Staked', 'Stash','Controller', or { Account: string })
82
+ */
83
+ payee(payee) {
84
+ if (typeof payee === 'object' && payee.Account) {
85
+ this._payee = payee;
86
+ }
87
+ else {
88
+ this._payee = payee;
89
+ }
90
+ return this;
91
+ }
92
+ /**
93
+ * Get the payee
94
+ */
95
+ getPayee() {
96
+ return this._payee;
97
+ }
98
+ /**
99
+ * Set the validators to nominate
100
+ */
101
+ validators(validators) {
102
+ for (const address of validators) {
103
+ this.validateAddress({ address });
104
+ }
105
+ this._validators = validators;
106
+ return this;
107
+ }
108
+ /**
109
+ * Get the validators to nominate
110
+ */
111
+ getValidators() {
112
+ return this._validators;
113
+ }
114
+ /** @inheritdoc */
115
+ validateDecodedTransaction(decodedTxn) {
116
+ const methodName = decodedTxn.method?.name;
117
+ // batch bond and nominate
118
+ if (methodName === 'batchAll') {
119
+ const txMethod = decodedTxn.method.args;
120
+ const calls = txMethod.calls;
121
+ if (calls.length !== 2) {
122
+ throw new sdk_core_1.InvalidTransactionError(`Invalid batch staking transaction: expected 2 calls but got ${calls.length}`);
123
+ }
124
+ // Check that first call is bond
125
+ const firstCallMethod = utils_1.default.decodeMethodName(calls[0], this._registry);
126
+ if (firstCallMethod !== 'bond') {
127
+ throw new sdk_core_1.InvalidTransactionError(`Invalid batch staking transaction: first call should be bond but got ${firstCallMethod}`);
128
+ }
129
+ // Check that second call is nominate
130
+ const secondCallMethod = utils_1.default.decodeMethodName(calls[1], this._registry);
131
+ if (secondCallMethod !== 'nominate') {
132
+ throw new sdk_core_1.InvalidTransactionError(`Invalid batch staking transaction: second call should be nominate but got ${secondCallMethod}`);
133
+ }
134
+ // Validate bond arguments
135
+ const bondArgs = calls[0].args;
136
+ this.validateBondArgs(bondArgs);
137
+ // Validate nominate arguments
138
+ const nominateArgs = calls[1].args;
139
+ this.validateNominateArgs(nominateArgs);
140
+ }
141
+ else {
142
+ throw new sdk_core_1.InvalidTransactionError(`Invalid transaction type: ${methodName}`);
143
+ }
144
+ }
145
+ /**
146
+ * Validate bond arguments
147
+ */
148
+ validateBondArgs(args) {
149
+ // Handle both string and object formats for controller
150
+ const controllerValue = args.controller;
151
+ const controllerAddress = typeof controllerValue === 'string' ? controllerValue : controllerValue.id;
152
+ if (!utils_1.default.isValidAddress(controllerAddress)) {
153
+ throw new sdk_core_1.InvalidTransactionError(`Invalid bond args: controller address ${controllerAddress} is not a well-formed address`);
154
+ }
155
+ // Handle both string and number formats for value
156
+ const amountValue = args.value;
157
+ const valueString = typeof amountValue === 'string' ? amountValue : amountValue.toString();
158
+ // Handle different payee formats
159
+ const payeeValue = args.payee;
160
+ let normalizedPayee = payeeValue;
161
+ if (typeof payeeValue === 'object' && payeeValue !== null) {
162
+ const decodedPayee = payeeValue;
163
+ if (decodedPayee.staked !== undefined) {
164
+ normalizedPayee = 'Staked';
165
+ }
166
+ else if (decodedPayee.stash !== undefined) {
167
+ normalizedPayee = 'Stash';
168
+ }
169
+ else if (decodedPayee.controller !== undefined) {
170
+ normalizedPayee = 'Controller';
171
+ }
172
+ else if (decodedPayee.account) {
173
+ normalizedPayee = { Account: decodedPayee.account };
174
+ }
175
+ }
176
+ const validationResult = txnSchema_1.BatchTransactionSchema.validateBond({
177
+ value: valueString,
178
+ controller: controllerAddress,
179
+ payee: normalizedPayee,
180
+ });
181
+ if (validationResult.error) {
182
+ throw new sdk_core_1.InvalidTransactionError(`Invalid bond args: ${validationResult.error.message}`);
183
+ }
184
+ }
185
+ /**
186
+ * Validate nominate arguments
187
+ */
188
+ validateNominateArgs(args) {
189
+ // Handle both string and object formats for targets
190
+ const targetAddresses = args.targets.map((target) => {
191
+ if (typeof target === 'string') {
192
+ return target;
193
+ }
194
+ else if (target && typeof target === 'object' && 'id' in target) {
195
+ return target.id;
196
+ }
197
+ throw new sdk_core_1.InvalidTransactionError(`Invalid target format: ${JSON.stringify(target)}`);
198
+ });
199
+ const validationResult = txnSchema_1.BatchTransactionSchema.validateNominate({
200
+ validators: targetAddresses,
201
+ });
202
+ if (validationResult.error) {
203
+ throw new sdk_core_1.InvalidTransactionError(`Invalid nominate args: ${validationResult.error.message}`);
204
+ }
205
+ }
206
+ /** @inheritdoc */
207
+ fromImplementation(rawTransaction) {
208
+ const tx = super.fromImplementation(rawTransaction);
209
+ // Check if the transaction is a batch transaction
210
+ if (this._method?.name !== 'batchAll') {
211
+ throw new sdk_core_1.InvalidTransactionError(`Invalid Transaction Type: ${this._method?.name}. Expected batchAll`);
212
+ }
213
+ if (this._method) {
214
+ const txMethod = this._method.args;
215
+ for (const call of txMethod.calls) {
216
+ const callMethod = utils_1.default.decodeMethodName(call, this._registry);
217
+ if (callMethod === 'bond') {
218
+ const bondArgs = call.args;
219
+ // Handle both string and number formats for value
220
+ const amountValue = bondArgs.value;
221
+ const valueString = typeof amountValue === 'string' ? amountValue : amountValue.toString();
222
+ this.amount(valueString);
223
+ // Handle both string and object formats for controller
224
+ const controllerValue = bondArgs.controller;
225
+ const controllerAddress = typeof controllerValue === 'string' ? controllerValue : controllerValue.id;
226
+ this.controller({ address: controllerAddress });
227
+ // Handle different payee formats
228
+ const payeeValue = bondArgs.payee;
229
+ let normalizedPayee = payeeValue;
230
+ if (typeof payeeValue === 'object' && payeeValue !== null) {
231
+ const decodedPayee = payeeValue;
232
+ if (decodedPayee.staked !== undefined) {
233
+ normalizedPayee = 'Staked';
234
+ }
235
+ else if (decodedPayee.stash !== undefined) {
236
+ normalizedPayee = 'Stash';
237
+ }
238
+ else if (decodedPayee.controller !== undefined) {
239
+ normalizedPayee = 'Controller';
240
+ }
241
+ else if (decodedPayee.account) {
242
+ normalizedPayee = { Account: decodedPayee.account };
243
+ }
244
+ }
245
+ this.payee(normalizedPayee);
246
+ }
247
+ else if (callMethod === 'nominate') {
248
+ const nominateArgs = call.args;
249
+ // Handle both string and object formats for targets
250
+ const targetAddresses = nominateArgs.targets.map((target) => {
251
+ if (typeof target === 'string') {
252
+ return target;
253
+ }
254
+ else if (target && typeof target === 'object' && 'id' in target) {
255
+ return target.id;
256
+ }
257
+ throw new sdk_core_1.InvalidTransactionError(`Invalid target format: ${JSON.stringify(target)}`);
258
+ });
259
+ this.validators(targetAddresses);
260
+ }
261
+ }
262
+ }
263
+ return tx;
264
+ }
265
+ /** @inheritdoc */
266
+ validateTransaction(tx) {
267
+ super.validateTransaction(tx);
268
+ this.validateFields();
269
+ }
270
+ /**
271
+ * Validate the builder fields
272
+ */
273
+ validateFields() {
274
+ // Ensure both bond and nominate operations are included
275
+ if (!this._amount || this._validators.length === 0) {
276
+ throw new sdk_core_1.InvalidTransactionError('Batch transaction must include both bond and nominate operations');
277
+ }
278
+ const validationResult = txnSchema_1.BatchTransactionSchema.validate({
279
+ amount: this._amount,
280
+ controller: this._controller,
281
+ payee: this._payee,
282
+ validators: this._validators,
283
+ });
284
+ if (validationResult.error) {
285
+ throw new sdk_core_1.InvalidTransactionError(`Invalid transaction: ${validationResult.error.message}`);
286
+ }
287
+ }
288
+ testValidateFields() {
289
+ this.validateFields();
290
+ }
291
+ testValidateBondArgs(args) {
292
+ return this.validateBondArgs(args);
293
+ }
294
+ testValidateNominateArgs(args) {
295
+ return this.validateNominateArgs(args);
296
+ }
297
+ }
298
+ exports.BatchStakingBuilder = BatchStakingBuilder;
299
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmF0Y2hTdGFraW5nQnVpbGRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIvYmF0Y2hTdGFraW5nQnVpbGRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7QUFDQSwrQ0FBaUQ7QUFFakQsc0VBQXdEO0FBRXhELG1EQUE2RjtBQUM3RiwyQ0FBcUQ7QUFDckQsb0RBQTRCO0FBRTVCLGdFQUFxQztBQWtCckMsTUFBYSxtQkFBb0IsU0FBUSw4QkFBZ0I7SUFTdkQsWUFBWSxXQUFpQztRQUMzQyxLQUFLLENBQUMsV0FBVyxDQUFDLENBQUM7UUFKckIseUJBQXlCO1FBQ2YsZ0JBQVcsR0FBYSxFQUFFLENBQUM7UUFJbkMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxlQUFLLENBQUMsV0FBVyxDQUFDLFdBQVcsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztJQUM3RCxDQUFDO0lBRUQsSUFBYyxlQUFlO1FBQzNCLE9BQU8sMEJBQWUsQ0FBQyxLQUFLLENBQUM7SUFDL0IsQ0FBQztJQUVEOzs7T0FHRztJQUNPLGdCQUFnQjtRQUN4Qix3REFBd0Q7UUFDeEQsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLElBQUksSUFBSSxDQUFDLFdBQVcsQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFLENBQUM7WUFDbkQsTUFBTSxJQUFJLGtDQUF1QixDQUFDLGtFQUFrRSxDQUFDLENBQUM7UUFDeEcsQ0FBQztRQUVELE1BQU0sVUFBVSxHQUFHLElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxDQUFDO1FBRTNDLDhCQUE4QjtRQUM5QixNQUFNLEtBQUssR0FBYSxFQUFFLENBQUM7UUFFM0IsZ0JBQWdCO1FBQ2hCLE1BQU0sUUFBUSxHQUFHLDRCQUFPLENBQUMsT0FBTyxDQUFDLElBQUksQ0FDbkM7WUFDRSxVQUFVLEVBQUUsSUFBSSxDQUFDLFdBQVcsSUFBSSxJQUFJLENBQUMsT0FBTztZQUM1QyxLQUFLLEVBQUUsSUFBSSxDQUFD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QyxDQUFDO1FBQzlGLENBQUM7SUFDSCxDQUFDO0lBRUQsa0JBQWtCO1FBQ2hCLElBQUksQ0FBQyxjQUFjLEVBQUUsQ0FBQztJQUN4QixDQUFDO0lBRU0sb0JBQW9CLENBQUMsSUFBYztRQUN4QyxPQUFPLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNyQyxDQUFDO0lBRU0sd0JBQXdCLENBQUMsSUFBa0I7UUFDaEQsT0FBTyxJQUFJLENBQUMsb0JBQW9CLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDekMsQ0FBQztDQUNGO0FBelZELGtEQXlWQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRyYW5zYWN0aW9uIH0gZnJvbSAnLi90cmFuc2FjdGlvbic7XG5pbXBvcnQgeyBQb2x5eEJhc2VCdWlsZGVyIH0gZnJvbSAnLi9iYXNlQnVpbGRlcic7XG5pbXBvcnQgeyBEZWNvZGVkU2lnbmVkVHgsIERlY29kZWRTaWduaW5nUGF5bG9hZCwgVW5zaWduZWRUcmFuc2FjdGlvbiB9IGZyb20gJ0BzdWJzdHJhdGUvdHh3cmFwcGVyLWNvcmUnO1xuaW1wb3J0IHsgbWV0aG9kcyB9IGZyb20gJ0BzdWJzdHJhdGUvdHh3cmFwcGVyLXBvbGthZG90JztcbmltcG9ydCB7IEJhc2VDb2luIGFzIENvaW5Db25maWcgfSBmcm9tICdAYml0Z28tYmV0YS9zdGF0aWNzJztcbmltcG9ydCB7IEJhc2VBZGRyZXNzLCBJbnZhbGlkVHJhbnNhY3Rpb25FcnJvciwgVHJhbnNhY3Rpb25UeXBlIH0gZnJvbSAnQGJpdGdvLWJldGEvc2RrLWNvcmUnO1xuaW1wb3J0IHsgQmF0Y2hUcmFuc2FjdGlvblNjaGVtYSB9IGZyb20gJy4vdHhuU2NoZW1hJztcbmltcG9ydCB1dGlscyBmcm9tICcuL3V0aWxzJztcbmltcG9ydCB7IEJhdGNoQXJncywgQm9uZEFyZ3MsIE5vbWluYXRlQXJncyB9IGZyb20gJy4vaWZhY2UnO1xuaW1wb3J0IEJpZ051bWJlciBmcm9tICdiaWdudW1iZXIuanMnO1xuXG4vLyBUeXBlIGRlZmluaXRpb25zIGZvciBkZWNvZGVkIHRyYW5zYWN0aW9uIGZvcm1hdHNcbmludGVyZmFjZSBEZWNvZGVkQ29udHJvbGxlciB7XG4gIGlkOiBzdHJpbmc7XG59XG5cbmludGVyZmFjZSBEZWNvZGVkUGF5ZWUge1xuICBzdGFrZWQ/OiBudWxsO1xuICBzdGFzaD86IG51bGw7XG4gIGNvbnRyb2xsZXI/OiBudWxsO1xuICBhY2NvdW50Pzogc3RyaW5nO1xufVxuXG50eXBlIENvbnRyb2xsZXJWYWx1ZSA9IHN0cmluZyB8IERlY29kZWRDb250cm9sbGVyO1xudHlwZSBQYXllZVZhbHVlID0gc3RyaW5nIHwgRGVjb2RlZFBheWVlO1xudHlwZSBBbW91bnRWYWx1ZSA9IHN0cmluZyB8IG51bWJlcjtcblxuZXhwb3J0IGNsYXNzIEJhdGNoU3Rha2luZ0J1aWxkZXIgZXh0ZW5kcyBQb2x5eEJhc2VCdWlsZGVyIHtcbiAgLy8gRm9yIGJvbmQgb3BlcmF0aW9uXG4gIHByb3RlY3RlZCBfYW1vdW50OiBzdHJpbmc7XG4gIHByb3RlY3RlZCBfY29udHJvbGxlcjogc3RyaW5nO1xuICBwcm90ZWN0ZWQgX3BheWVlOiBzdHJpbmcgfCB7IEFjY291bnQ6IHN0cmluZyB9O1xuXG4gIC8vIEZvciBub21pbmF0ZSBvcGVyYXRpb25cbiAgcHJvdGVjdGVkIF92YWxpZGF0b3JzOiBzdHJpbmdbXSA9IFtdO1xuXG4gIGNvbnN0cnVjdG9yKF9jb2luQ29uZmlnOiBSZWFkb25seTxDb2luQ29uZmlnPikge1xuICAgIHN1cGVyKF9jb2luQ29uZmlnKTtcbiAgICB0aGlzLm1hdGVyaWFsKHV0aWxzLmdldE1hdGVyaWFsKF9jb2luQ29uZmlnLm5ldHdvcmsudHlwZSkpO1xuICB9XG5cbiAgcHJvdGVjdGVkIGdldCB0cmFuc2FjdGlvblR5cGUoKTogVHJhbnNhY3Rpb25UeXBlIHtcbiAgICByZXR1cm4gVHJhbnNhY3Rpb25UeXBlLkJhdGNoO1xuICB9XG5cbiAgLyoqXG4gICAqIEJ1aWxkIGEgYmF0Y2ggdHJhbnNhY3Rpb24gdGhhdCBjb21iaW5lcyBib25kIGFuZCBub21pbmF0ZSBvcGVyYXRpb25zXG4gICAqIEJvdGggb3BlcmF0aW9ucyBhcmUgcmVxdWlyZWQgYW5kIGFsd2F5cyBhdG9taWMgKHVzaW5nIGJhdGNoQWxsKVxuICAgKi9cbiAgcHJvdGVjdGVkIGJ1aWxkVHJhbnNhY3Rpb24oKTogVW5zaWduZWRUcmFuc2FjdGlvbiB7XG4gICAgLy8gRW5zdXJlIGJvdGggYm9uZCBhbmQgbm9taW5hdGUgb3BlcmF0aW9ucyBhcmUgaW5jbHVkZWRcbiAgICBpZiAoIXRoaXMuX2Ftb3VudCB8fCB0aGlzLl92YWxpZGF0b3JzLmxlbmd0aCA9PT0gMCkge1xuICAgICAgdGhyb3cgbmV3IEludmFsaWRUcmFuc2FjdGlvbkVycm9yKCdCYXRjaCB0cmFuc2FjdGlvbiBtdXN0IGluY2x1ZGUgYm90aCBib25kIGFuZCBub21pbmF0ZSBvcGVyYXRpb25zJyk7XG4gICAgfVxuXG4gICAgY29uc3QgYmFzZVR4SW5mbyA9IHRoaXMuY3JlYXRlQmFzZVR4SW5mbygpO1xuXG4gICAgLy8gQ3JlYXRlIHRoZSBpbmRpdmlkdWFsIGNhbGxzXG4gICAgY29uc3QgY2FsbHM6IHN0cmluZ1tdID0gW107XG5cbiAgICAvLyBBZGQgYm9uZCBjYWxsXG4gICAgY29uc3QgYm9uZENhbGwgPSBtZXRob2RzLnN0YWtpbmcuYm9uZChcbiAgICAgIHtcbiAgICAgICAgY29udHJvbGxlcjogdGhpcy5fY29udHJvbGxlciB8fCB0aGlzLl9zZW5kZXIsXG4gICAgICAgIHZhbHVlOiB0aGlzLl9hbW91bnQsXG4gICAgICAgIHBheWVlOiB0aGlzLl9wYXllZSB8fCAnU3Rha2VkJyxcbiAgICAgIH0sXG4gICAgICBiYXNlVHhJbmZvLmJhc2VUeEluZm8sXG4gICAgICBiYXNlVHhJbmZvLm9wdGlvbnNcbiAgICApO1xuICAgIGNhbGxzLnB1c2goYm9uZENhbGwubWV0aG9kKTtcblxuICAgIC8vIEFkZCBub21pbmF0ZSBjYWxsXG4gICAgY29uc3Qgbm9taW5hdGVDYWxsID0gbWV0aG9kcy5zdGFraW5nLm5vbWluYXRlKFxuICAgICAge1xuICAgICAgICB0YXJnZXRzOiB0aGlzLl92YWxpZGF0b3JzLFxuICAgICAgfSxcbiAgICAgIGJhc2VUeEluZm8uYmFzZVR4SW5mbyxcbiAgICAgIGJhc2VUeEluZm8ub3B0aW9uc1xuICAgICk7XG4gICAgY2FsbHMucHVzaChub21pbmF0ZUNhbGwubWV0aG9kKTtcblxuICAgIC8vIEFsd2F5cyB1c2UgYmF0Y2hBbGwgKGF0b21pYylcbiAgICByZXR1cm4gbWV0aG9kcy51dGlsaXR5LmJhdGNoQWxsKFxuICAgICAge1xuICAgICAgICBjYWxscyxcbiAgICAgIH0sXG4gICAgICBiYXNlVHhJbmZvLmJhc2VUeEluZm8sXG4gICAgICBiYXNlVHhJbmZvLm9wdGlvbnNcbiAgICApO1xuICB9XG5cbiAgLyoqXG4gICAqIFNldCB0aGUgc3Rha2luZyBhbW91bnQgZm9yIGJvbmRcbiAgICovXG4gIGFtb3VudChhbW91bnQ6IHN0cmluZyk6IHRoaXMge1xuICAgIHRoaXMudmFsaWRhdGVWYWx1ZShuZXcgQmlnTnVtYmVyKGFtb3VudCkpO1xuICAgIHRoaXMuX2Ftb3VudCA9IGFtb3VudDtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBHZXQgdGhlIHN0YWtpbmcgYW1vdW50XG4gICAqL1xuICBnZXRBbW91bnQoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gdGhpcy5fYW1vdW50O1xuICB9XG5cbiAgLyoqXG4gICAqIFNldCB0aGUgY29udHJvbGxlciBhY2NvdW50IGZvciBib25kXG4gICAqL1xuICBjb250cm9sbGVyKGNvbnRyb2xsZXI6IEJhc2VBZGRyZXNzKTogdGhpcyB7XG4gICAgdGhpcy52YWxpZGF0ZUFkZHJlc3MoY29udHJvbGxlcik7XG4gICAgdGhpcy5fY29udHJvbGxlciA9IGNvbnRyb2xsZXIuYWRkcmVzcztcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBHZXQgdGhlIGNvbnRyb2xsZXIgYWRkcmVzc1xuICAgKi9cbiAgZ2V0Q29udHJvbGxlcigpOiBzdHJpbmcge1xuICAgIHJldHVybiB0aGlzLl9jb250cm9sbGVyO1xuICB9XG5cbiAgLyoqXG4gICAqIFNldCB0aGUgcmV3YXJkcyBkZXN0aW5hdGlvbiBmb3IgYm9uZCAoJ1N0YWtlZCcsICdTdGFzaCcsJ0NvbnRyb2xsZXInLCBvciB7IEFjY291bnQ6IHN0cmluZyB9KVxuICAgKi9cbiAgcGF5ZWUocGF5ZWU6IHN0cmluZyB8IHsgQWNjb3VudDogc3RyaW5nIH0pOiB0aGlzIHtcbiAgICBpZiAodHlwZW9mIHBheWVlID09PSAnb2JqZWN0JyAmJiBwYXllZS5BY2NvdW50KSB7XG4gICAgICB0aGlzLl9wYXllZSA9IHBheWVlO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLl9wYXllZSA9IHBheWVlO1xuICAgIH1cbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIC8qKlxuICAgKiBHZXQgdGhlIHBheWVlXG4gICAqL1xuICBnZXRQYXllZSgpOiBzdHJpbmcgfCB7IEFjY291bnQ6IHN0cmluZyB9IHtcbiAgICByZXR1cm4gdGhpcy5fcGF5ZWU7XG4gIH1cblxuICAvKipcbiAgICogU2V0IHRoZSB2YWxpZGF0b3JzIHRvIG5vbWluYXRlXG4gICAqL1xuICB2YWxpZGF0b3JzKHZhbGlkYXRvcnM6IHN0cmluZ1tdKTogdGhpcyB7XG4gICAgZm9yIChjb25zdCBhZGRyZXNzIG9mIHZhbGlkYXRvcnMpIHtcbiAgICAgIHRoaXMudmFsaWRhdGVBZGRyZXNzKHsgYWRkcmVzcyB9KTtcbiAgICB9XG4gICAgdGhpcy5fdmFsaWRhdG9ycyA9IHZhbGlkYXRvcnM7XG4gICAgcmV0dXJuIHRoaXM7XG4gIH1cblxuICAvKipcbiAgICogR2V0IHRoZSB2YWxpZGF0b3JzIHRvIG5vbWluYXRlXG4gICAqL1xuICBnZXRWYWxpZGF0b3JzKCk6IHN0cmluZ1tdIHtcbiAgICByZXR1cm4gdGhpcy5fdmFsaWRhdG9ycztcbiAgfVxuXG4gIC8qKiBAaW5oZXJpdGRvYyAqL1xuICB2YWxpZGF0ZURlY29kZWRUcmFuc2FjdGlvbihkZWNvZGVkVHhuOiBEZWNvZGVkU2lnbmluZ1BheWxvYWQgfCBEZWNvZGVkU2lnbmVkVHgpOiB2b2lkIHtcbiAgICBjb25zdCBtZXRob2ROYW1lID0gZGVjb2RlZFR4bi5tZXRob2Q/Lm5hbWUgYXMgc3RyaW5nO1xuXG4gICAgLy8gYmF0Y2ggYm9uZCBhbmQgbm9taW5hdGVcbiAgICBpZiAobWV0aG9kTmFtZSA9PT0gJ2JhdGNoQWxsJykge1xuICAgICAgY29uc3QgdHhNZXRob2QgPSBkZWNvZGVkVHhuLm1ldGhvZC5hcmdzIGFzIHVua25vd24gYXMgQmF0Y2hBcmdzO1xuICAgICAgY29uc3QgY2FsbHMgPSB0eE1ldGhvZC5jYWxscztcblxuICAgICAgaWYgKGNhbGxzLmxlbmd0aCAhPT0gMikge1xuICAgICAgICB0aHJvdyBuZXcgSW52YWxpZFRyYW5zYWN0aW9uRXJyb3IoXG4gICAgICAgICAgYEludmFsaWQgYmF0Y2ggc3Rha2luZyB0cmFuc2FjdGlvbjogZXhwZWN0ZWQgMiBjYWxscyBidXQgZ290ICR7Y2FsbHMubGVuZ3RofWBcbiAgICAgICAgKTtcbiAgICAgIH1cblxuICAgICAgLy8gQ2hlY2sgdGhhdCBmaXJzdCBjYWxsIGlzIGJvbmRcbiAgICAgIGNvbnN0IGZpcnN0Q2FsbE1ldGhvZCA9IHV0aWxzLmRlY29kZU1ldGhvZE5hbWUoY2FsbHNbMF0sIHRoaXMuX3JlZ2lzdHJ5KTtcbiAgICAgIGlmIChmaXJzdENhbGxNZXRob2QgIT09ICdib25kJykge1xuICAgICAgICB0aHJvdyBuZXcgSW52YWxpZFRyYW5zYWN0aW9uRXJyb3IoXG4gICAgICAgICAgYEludmFsaWQgYmF0Y2ggc3Rha2luZyB0cmFuc2FjdGlvbjogZmlyc3QgY2FsbCBzaG91bGQgYmUgYm9uZCBidXQgZ290ICR7Zmlyc3RDYWxsTWV0aG9kfWBcbiAgICAgICAgKTtcbiAgICAgIH1cblxuICAgICAgLy8gQ2hlY2sgdGhhdCBzZWNvbmQgY2FsbCBpcyBub21pbmF0ZVxuICAgICAgY29uc3Qgc2Vjb25kQ2FsbE1ldGhvZCA9IHV0aWxzLmRlY29kZU1ldGhvZE5hbWUoY2FsbHNbMV0sIHRoaXMuX3JlZ2lzdHJ5KTtcbiAgICAgIGlmIChzZWNvbmRDYWxsTWV0aG9kICE9PSAnbm9taW5hdGUnKSB7XG4gICAgICAgIHRocm93IG5ldyBJbnZhbGlkVHJhbnNhY3Rpb25FcnJvcihcbiAgICAgICAgICBgSW52YWxpZCBiYXRjaCBzdGFraW5nIHRyYW5zYWN0aW9uOiBzZWNvbmQgY2FsbCBzaG91bGQgYmUgbm9taW5hdGUgYnV0IGdvdCAke3NlY29uZENhbGxNZXRob2R9YFxuICAgICAgICApO1xuICAgICAgfVxuXG4gICAgICAvLyBWYWxpZGF0ZSBib25kIGFyZ3VtZW50c1xuICAgICAgY29uc3QgYm9uZEFyZ3MgPSBjYWxsc1swXS5hcmdzIGFzIHVua25vd24gYXMgQm9uZEFyZ3M7XG4gICAgICB0aGlzLnZhbGlkYXRlQm9uZEFyZ3MoYm9uZEFyZ3MpO1xuXG4gICAgICAvLyBWYWxpZGF0ZSBub21pbmF0ZSBhcmd1bWVudHNcbiAgICAgIGNvbnN0IG5vbWluYXRlQXJncyA9IGNhbGxzWzFdLmFyZ3MgYXMgdW5rbm93biBhcyBOb21pbmF0ZUFyZ3M7XG4gICAgICB0aGlzLnZhbGlkYXRlTm9taW5hdGVBcmdzKG5vbWluYXRlQXJncyk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRocm93IG5ldyBJbnZhbGlkVHJhbnNhY3Rpb25FcnJvcihgSW52YWxpZCB0cmFuc2FjdGlvbiB0eXBlOiAke21ldGhvZE5hbWV9YCk7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIFZhbGlkYXRlIGJvbmQgYXJndW1lbnRzXG4gICAqL1xuICBwcml2YXRlIHZhbGlkYXRlQm9uZEFyZ3MoYXJnczogQm9uZEFyZ3MpOiB2b2lkIHtcbiAgICAvLyBIYW5kbGUgYm90aCBzdHJpbmcgYW5kIG9iamVjdCBmb3JtYXRzIGZvciBjb250cm9sbGVyXG4gICAgY29uc3QgY29udHJvbGxlclZhbHVlID0gYXJncy5jb250cm9sbGVyIGFzIENvbnRyb2xsZXJWYWx1ZTtcbiAgICBjb25zdCBjb250cm9sbGVyQWRkcmVzcyA9IHR5cGVvZiBjb250cm9sbGVyVmFsdWUgPT09ICdzdHJpbmcnID8gY29udHJvbGxlclZhbHVlIDogY29udHJvbGxlclZhbHVlLmlkO1xuXG4gICAgaWYgKCF1dGlscy5pc1ZhbGlkQWRkcmVzcyhjb250cm9sbGVyQWRkcmVzcykpIHtcbiAgICAgIHRocm93IG5ldyBJbnZhbGlkVHJhbnNhY3Rpb25FcnJvcihcbiAgICAgICAgYEludmFsaWQgYm9uZCBhcmdzOiBjb250cm9sbGVyIGFkZHJlc3MgJHtjb250cm9sbGVyQWRkcmVzc30gaXMgbm90IGEgd2VsbC1mb3JtZWQgYWRkcmVzc2BcbiAgICAgICk7XG4gICAgfVxuXG4gICAgLy8gSGFuZGxlIGJvdGggc3RyaW5nIGFuZCBudW1iZXIgZm9ybWF0cyBmb3IgdmFsdWVcbiAgICBjb25zdCBhbW91bnRWYWx1ZSA9IGFyZ3MudmFsdWUgYXMgQW1vdW50VmFsdWU7XG4gICAgY29uc3QgdmFsdWVTdHJpbmcgPSB0eXBlb2YgYW1vdW50VmFsdWUgPT09ICdzdHJpbmcnID8gYW1vdW50VmFsdWUgOiBhbW91bnRWYWx1ZS50b1N0cmluZygpO1xuXG4gICAgLy8gSGFuZGxlIGRpZmZlcmVudCBwYXllZSBmb3JtYXRzXG4gICAgY29uc3QgcGF5ZWVWYWx1ZSA9IGFyZ3MucGF5ZWUgYXMgUGF5ZWVWYWx1ZTtcbiAgICBsZXQgbm9ybWFsaXplZFBheWVlOiBzdHJpbmcgfCB7IEFjY291bnQ6IHN0cmluZyB9ID0gcGF5ZWVWYWx1ZSBhcyBzdHJpbmc7XG4gICAgaWYgKHR5cGVvZiBwYXllZVZhbHVlID09PSAnb2JqZWN0JyAmJiBwYXllZVZhbHVlICE9PSBudWxsKSB7XG4gICAgICBjb25zdCBkZWNvZGVkUGF5ZWUgPSBwYXllZVZhbHVlIGFzIERlY29kZWRQYXllZTtcbiAgICAgIGlmIChkZWNvZGVkUGF5ZWUuc3Rha2VkICE9PSB1bmRlZmluZWQpIHtcbiAgICAgICAgbm9ybWFsaXplZFBheWVlID0gJ1N0YWtlZCc7XG4gICAgICB9IGVsc2UgaWYgKGRlY29kZWRQYXllZS5zdGFzaCAhPT0gdW5kZWZpbmVkKSB7XG4gICAgICAgIG5vcm1hbGl6ZWRQYXllZSA9ICdTdGFzaCc7XG4gICAgICB9IGVsc2UgaWYgKGRlY29kZWRQYXllZS5jb250cm9sbGVyICE9PSB1bmRlZmluZWQpIHtcbiAgICAgICAgbm9ybWFsaXplZFBheWVlID0gJ0NvbnRyb2xsZXInO1xuICAgICAgfSBlbHNlIGlmIChkZWNvZGVkUGF5ZWUuYWNjb3VudCkge1xuICAgICAgICBub3JtYWxpemVkUGF5ZWUgPSB7IEFjY291bnQ6IGRlY29kZWRQYXllZS5hY2NvdW50IH07XG4gICAgICB9XG4gICAgfVxuXG4gICAgY29uc3QgdmFsaWRhdGlvblJlc3VsdCA9IEJhdGNoVHJhbnNhY3Rpb25TY2hlbWEudmFsaWRhdGVCb25kKHtcbiAgICAgIHZhbHVlOiB2YWx1ZVN0cmluZyxcbiAgICAgIGNvbnRyb2xsZXI6IGNvbnRyb2xsZXJBZGRyZXNzLFxuICAgICAgcGF5ZWU6IG5vcm1hbGl6ZWRQYXllZSxcbiAgICB9KTtcblxuICAgIGlmICh2YWxpZGF0aW9uUmVzdWx0LmVycm9yKSB7XG4gICAgICB0aHJvdyBuZXcgSW52YWxpZFRyYW5zYWN0aW9uRXJyb3IoYEludmFsaWQgYm9uZCBhcmdzOiAke3ZhbGlkYXRpb25SZXN1bHQuZXJyb3IubWVzc2FnZX1gKTtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogVmFsaWRhdGUgbm9taW5hdGUgYXJndW1lbnRzXG4gICAqL1xuICBwcml2YXRlIHZhbGlkYXRlTm9taW5hdGVBcmdzKGFyZ3M6IE5vbWluYXRlQXJncyk6IHZvaWQge1xuICAgIC8vIEhhbmRsZSBib3RoIHN0cmluZyBhbmQgb2JqZWN0IGZvcm1hdHMgZm9yIHRhcmdldHNcbiAgICBjb25zdCB0YXJnZXRBZGRyZXNzZXMgPSBhcmdzLnRhcmdldHMubWFwKCh0YXJnZXQpID0+IHtcbiAgICAgIGlmICh0eXBlb2YgdGFyZ2V0ID09PSAnc3RyaW5nJykge1xuICAgICAgICByZXR1cm4gdGFyZ2V0O1xuICAgICAgfSBlbHNlIGlmICh0YXJnZXQgJiYgdHlwZW9mIHRhcmdldCA9PT0gJ29iamVjdCcgJiYgJ2lkJyBpbiB0YXJnZXQpIHtcbiAgICAgICAgcmV0dXJuICh0YXJnZXQgYXMgeyBpZDogc3RyaW5nIH0pLmlkO1xuICAgICAgfVxuICAgICAgdGhyb3cgbmV3IEludmFsaWRUcmFuc2FjdGlvbkVycm9yKGBJbnZhbGlkIHRhcmdldCBmb3JtYXQ6ICR7SlNPTi5zdHJpbmdpZnkodGFyZ2V0KX1gKTtcbiAgICB9KTtcblxuICAgIGNvbnN0IHZhbGlkYXRpb25SZXN1bHQgPSBCYXRjaFRyYW5zYWN0aW9uU2NoZW1hLnZhbGlkYXRlTm9taW5hdGUoe1xuICAgICAgdmFsaWRhdG9yczogdGFyZ2V0QWRkcmVzc2VzLFxuICAgIH0pO1xuXG4gICAgaWYgKHZhbGlkYXRpb25SZXN1bHQuZXJyb3IpIHtcbiAgICAgIHRocm93IG5ldyBJbnZhbGlkVHJhbnNhY3Rpb25FcnJvcihgSW52YWxpZCBub21pbmF0ZSBhcmdzOiAke3ZhbGlkYXRpb25SZXN1bHQuZXJyb3IubWVzc2FnZX1gKTtcbiAgICB9XG4gIH1cblxuICAvKiogQGluaGVyaXRkb2MgKi9cbiAgcHJvdGVjdGVkIGZyb21JbXBsZW1lbnRhdGlvbihyYXdUcmFuc2FjdGlvbjogc3RyaW5nKTogVHJhbnNhY3Rpb24ge1xuICAgIGNvbnN0IHR4ID0gc3VwZXIuZnJvbUltcGxlbWVudGF0aW9uKHJhd1RyYW5zYWN0aW9uKTtcblxuICAgIC8vIENoZWNrIGlmIHRoZSB0cmFuc2FjdGlvbiBpcyBhIGJhdGNoIHRyYW5zYWN0aW9uXG4gICAgaWYgKCh0aGlzLl9tZXRob2Q/Lm5hbWUgYXMgc3RyaW5nKSAhPT0gJ2JhdGNoQWxsJykge1xuICAgICAgdGhyb3cgbmV3IEludmFsaWRUcmFuc2FjdGlvbkVycm9yKGBJbnZhbGlkIFRyYW5zYWN0aW9uIFR5cGU6ICR7dGhpcy5fbWV0aG9kPy5uYW1lfS4gRXhwZWN0ZWQgYmF0Y2hBbGxgKTtcbiAgICB9XG5cbiAgICBpZiAodGhpcy5fbWV0aG9kKSB7XG4gICAgICBjb25zdCB0eE1ldGhvZCA9IHRoaXMuX21ldGhvZC5hcmdzIGFzIHVua25vd24gYXMgQmF0Y2hBcmdzO1xuXG4gICAgICBmb3IgKGNvbnN0IGNhbGwgb2YgdHhNZXRob2QuY2FsbHMpIHtcbiAgICAgICAgY29uc3QgY2FsbE1ldGhvZCA9IHV0aWxzLmRlY29kZU1ldGhvZE5hbWUoY2FsbCwgdGhpcy5fcmVnaXN0cnkpO1xuICAgICAgICBpZiAoY2FsbE1ldGhvZCA9PT0gJ2JvbmQnKSB7XG4gICAgICAgICAgY29uc3QgYm9uZEFyZ3MgPSBjYWxsLmFyZ3MgYXMgdW5rbm93biBhcyBCb25kQXJncztcbiAgICAgICAgICAvLyBIYW5kbGUgYm90aCBzdHJpbmcgYW5kIG51bWJlciBmb3JtYXRzIGZvciB2YWx1ZVxuICAgICAgICAgIGNvbnN0IGFtb3VudFZhbHVlID0gYm9uZEFyZ3MudmFsdWUgYXMgQW1vdW50VmFsdWU7XG4gICAgICAgICAgY29uc3QgdmFsdWVTdHJpbmcgPSB0eXBlb2YgYW1vdW50VmFsdWUgPT09ICdzdHJpbmcnID8gYW1vdW50VmFsdWUgOiBhbW91bnRWYWx1ZS50b1N0cmluZygpO1xuICAgICAgICAgIHRoaXMuYW1vdW50KHZhbHVlU3RyaW5nKTtcblxuICAgICAgICAgIC8vIEhhbmRsZSBib3RoIHN0cmluZyBhbmQgb2JqZWN0IGZvcm1hdHMgZm9yIGNvbnRyb2xsZXJcbiAgICAgICAgICBjb25zdCBjb250cm9sbGVyVmFsdWUgPSBib25kQXJncy5jb250cm9sbGVyIGFzIENvbnRyb2xsZXJWYWx1ZTtcbiAgICAgICAgICBjb25zdCBjb250cm9sbGVyQWRkcmVzcyA9IHR5cGVvZiBjb250cm9sbGVyVmFsdWUgPT09ICdzdHJpbmcnID8gY29udHJvbGxlclZhbHVlIDogY29udHJvbGxlclZhbHVlLmlkO1xuICAgICAgICAgIHRoaXMuY29udHJvbGxlcih7IGFkZHJlc3M6IGNvbnRyb2xsZXJBZGRyZXNzIH0pO1xuXG4gICAgICAgICAgLy8gSGFuZGxlIGRpZmZlcmVudCBwYXllZSBmb3JtYXRzXG4gICAgICAgICAgY29uc3QgcGF5ZWVWYWx1ZSA9IGJvbmRBcmdzLnBheWVlIGFzIFBheWVlVmFsdWU7XG4gICAgICAgICAgbGV0IG5vcm1hbGl6ZWRQYXllZTogc3RyaW5nIHwgeyBBY2NvdW50OiBzdHJpbmcgfSA9IHBheWVlVmFsdWUgYXMgc3RyaW5nO1xuICAgICAgICAgIGlmICh0eXBlb2YgcGF5ZWVWYWx1ZSA9PT0gJ29iamVjdCcgJiYgcGF5ZWVWYWx1ZSAhPT0gbnVsbCkge1xuICAgICAgICAgICAgY29uc3QgZGVjb2RlZFBheWVlID0gcGF5ZWVWYWx1ZSBhcyBEZWNvZGVkUGF5ZWU7XG4gICAgICAgICAgICBpZiAoZGVjb2RlZFBheWVlLnN0YWtlZCAhPT0gdW5kZWZpbmVkKSB7XG4gICAgICAgICAgICAgIG5vcm1hbGl6ZWRQYXllZSA9ICdTdGFrZWQnO1xuICAgICAgICAgICAgfSBlbHNlIGlmIChkZWNvZGVkUGF5ZWUuc3Rhc2ggIT09IHVuZGVmaW5lZCkge1xuICAgICAgICAgICAgICBub3JtYWxpemVkUGF5ZWUgPSAnU3Rhc2gnO1xuICAgICAgICAgICAgfSBlbHNlIGlmIChkZWNvZGVkUGF5ZWUuY29udHJvbGxlciAhPT0gdW5kZWZpbmVkKSB7XG4gICAgICAgICAgICAgIG5vcm1hbGl6ZWRQYXllZSA9ICdDb250cm9sbGVyJztcbiAgICAgICAgICAgIH0gZWxzZSBpZiAoZGVjb2RlZFBheWVlLmFjY291bnQpIHtcbiAgICAgICAgICAgICAgbm9ybWFsaXplZFBheWVlID0geyBBY2NvdW50OiBkZWNvZGVkUGF5ZWUuYWNjb3VudCB9O1xuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cbiAgICAgICAgICB0aGlzLnBheWVlKG5vcm1hbGl6ZWRQYXllZSk7XG4gICAgICAgIH0gZWxzZSBpZiAoY2FsbE1ldGhvZCA9PT0gJ25vbWluYXRlJykge1xuICAgICAgICAgIGNvbnN0IG5vbWluYXRlQXJncyA9IGNhbGwuYXJncyBhcyB1bmtub3duIGFzIE5vbWluYXRlQXJncztcblxuICAgICAgICAgIC8vIEhhbmRsZSBib3RoIHN0cmluZyBhbmQgb2JqZWN0IGZvcm1hdHMgZm9yIHRhcmdldHNcbiAgICAgICAgICBjb25zdCB0YXJnZXRBZGRyZXNzZXMgPSBub21pbmF0ZUFyZ3MudGFyZ2V0cy5tYXAoKHRhcmdldCkgPT4ge1xuICAgICAgICAgICAgaWYgKHR5cGVvZiB0YXJnZXQgPT09ICdzdHJpbmcnKSB7XG4gICAgICAgICAgICAgIHJldHVybiB0YXJnZXQ7XG4gICAgICAgICAgICB9IGVsc2UgaWYgKHRhcmdldCAmJiB0eXBlb2YgdGFyZ2V0ID09PSAnb2JqZWN0JyAmJiAnaWQnIGluIHRhcmdldCkge1xuICAgICAgICAgICAgICByZXR1cm4gKHRhcmdldCBhcyB7IGlkOiBzdHJpbmcgfSkuaWQ7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICB0aHJvdyBuZXcgSW52YWxpZFRyYW5zYWN0aW9uRXJyb3IoYEludmFsaWQgdGFyZ2V0IGZvcm1hdDogJHtKU09OLnN0cmluZ2lmeSh0YXJnZXQpfWApO1xuICAgICAgICAgIH0pO1xuICAgICAgICAgIHRoaXMudmFsaWRhdG9ycyh0YXJnZXRBZGRyZXNzZXMpO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIHR4O1xuICB9XG5cbiAgLyoqIEBpbmhlcml0ZG9jICovXG4gIHZhbGlkYXRlVHJhbnNhY3Rpb24odHg6IFRyYW5zYWN0aW9uKTogdm9pZCB7XG4gICAgc3VwZXIudmFsaWRhdGVUcmFuc2FjdGlvbih0eCk7XG4gICAgdGhpcy52YWxpZGF0ZUZpZWxkcygpO1xuICB9XG5cbiAgLyoqXG4gICAqIFZhbGlkYXRlIHRoZSBidWlsZGVyIGZpZWxkc1xuICAgKi9cbiAgcHJpdmF0ZSB2YWxpZGF0ZUZpZWxkcygpOiB2b2lkIHtcbiAgICAvLyBFbnN1cmUgYm90aCBib25kIGFuZCBub21pbmF0ZSBvcGVyYXRpb25zIGFyZSBpbmNsdWRlZFxuICAgIGlmICghdGhpcy5fYW1vdW50IHx8IHRoaXMuX3ZhbGlkYXRvcnMubGVuZ3RoID09PSAwKSB7XG4gICAgICB0aHJvdyBuZXcgSW52YWxpZFRyYW5zYWN0aW9uRXJyb3IoJ0JhdGNoIHRyYW5zYWN0aW9uIG11c3QgaW5jbHVkZSBib3RoIGJvbmQgYW5kIG5vbWluYXRlIG9wZXJhdGlvbnMnKTtcbiAgICB9XG5cbiAgICBjb25zdCB2YWxpZGF0aW9uUmVzdWx0ID0gQmF0Y2hUcmFuc2FjdGlvblNjaGVtYS52YWxpZGF0ZSh7XG4gICAgICBhbW91bnQ6IHRoaXMuX2Ftb3VudCxcbiAgICAgIGNvbnRyb2xsZXI6IHRoaXMuX2NvbnRyb2xsZXIsXG4gICAgICBwYXllZTogdGhpcy5fcGF5ZWUsXG4gICAgICB2YWxpZGF0b3JzOiB0aGlzLl92YWxpZGF0b3JzLFxuICAgIH0pO1xuXG4gICAgaWYgKHZhbGlkYXRpb25SZXN1bHQuZXJyb3IpIHtcbiAgICAgIHRocm93IG5ldyBJbnZhbGlkVHJhbnNhY3Rpb25FcnJvcihgSW52YWxpZCB0cmFuc2FjdGlvbjogJHt2YWxpZGF0aW9uUmVzdWx0LmVycm9yLm1lc3NhZ2V9YCk7XG4gICAgfVxuICB9XG5cbiAgdGVzdFZhbGlkYXRlRmllbGRzKCk6IHZvaWQge1xuICAgIHRoaXMudmFsaWRhdGVGaWVsZHMoKTtcbiAgfVxuXG4gIHB1YmxpYyB0ZXN0VmFsaWRhdGVCb25kQXJncyhhcmdzOiBCb25kQXJncyk6IHZvaWQge1xuICAgIHJldHVybiB0aGlzLnZhbGlkYXRlQm9uZEFyZ3MoYXJncyk7XG4gIH1cblxuICBwdWJsaWMgdGVzdFZhbGlkYXRlTm9taW5hdGVBcmdzKGFyZ3M6IE5vbWluYXRlQXJncyk6IHZvaWQge1xuICAgIHJldHVybiB0aGlzLnZhbGlkYXRlTm9taW5hdGVBcmdzKGFyZ3MpO1xuICB9XG59XG4iXX0=