@bitgo-beta/sdk-coin-sol 2.4.3-beta.130 → 2.4.3-beta.1300

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 (170) hide show
  1. package/dist/src/bigint-buffer-guard.d.ts +1 -0
  2. package/dist/src/bigint-buffer-guard.d.ts.map +1 -0
  3. package/dist/src/bigint-buffer-guard.js +29 -0
  4. package/dist/src/config/token2022StaticConfig.d.ts +3 -0
  5. package/dist/src/config/token2022StaticConfig.d.ts.map +1 -0
  6. package/dist/src/config/token2022StaticConfig.js +50 -0
  7. package/dist/src/index.d.ts +1 -0
  8. package/dist/src/index.d.ts.map +1 -1
  9. package/dist/src/index.js +7 -2
  10. package/dist/src/lib/ataInitializationBuilder.d.ts.map +1 -1
  11. package/dist/src/lib/ataInitializationBuilder.js +60 -22
  12. package/dist/src/lib/closeAtaBuilder.d.ts +19 -0
  13. package/dist/src/lib/closeAtaBuilder.d.ts.map +1 -0
  14. package/dist/src/lib/closeAtaBuilder.js +69 -0
  15. package/dist/src/lib/constants.d.ts +63 -8
  16. package/dist/src/lib/constants.d.ts.map +1 -1
  17. package/dist/src/lib/constants.js +73 -10
  18. package/dist/src/lib/customInstructionBuilder.d.ts +72 -0
  19. package/dist/src/lib/customInstructionBuilder.d.ts.map +1 -0
  20. package/dist/src/lib/customInstructionBuilder.js +289 -0
  21. package/dist/src/lib/iface.d.ts +106 -5
  22. package/dist/src/lib/iface.d.ts.map +1 -1
  23. package/dist/src/lib/iface.js +1 -1
  24. package/dist/src/lib/index.d.ts +13 -10
  25. package/dist/src/lib/index.d.ts.map +1 -1
  26. package/dist/src/lib/index.js +48 -28
  27. package/dist/src/lib/instructionParamsFactory.d.ts +1 -1
  28. package/dist/src/lib/instructionParamsFactory.d.ts.map +1 -1
  29. package/dist/src/lib/instructionParamsFactory.js +521 -85
  30. package/dist/src/lib/jitoStakePoolOperations.d.ts +113 -0
  31. package/dist/src/lib/jitoStakePoolOperations.d.ts.map +1 -0
  32. package/dist/src/lib/jitoStakePoolOperations.js +200 -0
  33. package/dist/src/lib/keyPair.js +5 -5
  34. package/dist/src/lib/messages/index.d.ts +2 -0
  35. package/dist/src/lib/messages/index.d.ts.map +1 -0
  36. package/dist/src/lib/messages/index.js +18 -0
  37. package/dist/src/lib/messages/messageBuilderFactory.d.ts +7 -0
  38. package/dist/src/lib/messages/messageBuilderFactory.d.ts.map +1 -0
  39. package/dist/src/lib/messages/messageBuilderFactory.js +19 -0
  40. package/dist/src/lib/solInstructionFactory.d.ts.map +1 -1
  41. package/dist/src/lib/solInstructionFactory.js +363 -95
  42. package/dist/src/lib/stakingActivateBuilder.d.ts +18 -0
  43. package/dist/src/lib/stakingActivateBuilder.d.ts.map +1 -1
  44. package/dist/src/lib/stakingActivateBuilder.js +34 -8
  45. package/dist/src/lib/stakingAuthorizeBuilder.js +7 -7
  46. package/dist/src/lib/stakingDeactivateBuilder.d.ts +27 -1
  47. package/dist/src/lib/stakingDeactivateBuilder.d.ts.map +1 -1
  48. package/dist/src/lib/stakingDeactivateBuilder.js +82 -15
  49. package/dist/src/lib/stakingDelegateBuilder.js +9 -9
  50. package/dist/src/lib/stakingRawMsgAuthorizeBuilder.js +5 -5
  51. package/dist/src/lib/stakingWithdrawBuilder.js +6 -6
  52. package/dist/src/lib/token2022Config.d.ts +44 -0
  53. package/dist/src/lib/token2022Config.d.ts.map +1 -0
  54. package/dist/src/lib/token2022Config.js +27 -0
  55. package/dist/src/lib/tokenTransferBuilder.d.ts +4 -1
  56. package/dist/src/lib/tokenTransferBuilder.d.ts.map +1 -1
  57. package/dist/src/lib/tokenTransferBuilder.js +87 -23
  58. package/dist/src/lib/transaction.d.ts +42 -6
  59. package/dist/src/lib/transaction.d.ts.map +1 -1
  60. package/dist/src/lib/transaction.js +185 -67
  61. package/dist/src/lib/transactionBuilder.d.ts +20 -3
  62. package/dist/src/lib/transactionBuilder.d.ts.map +1 -1
  63. package/dist/src/lib/transactionBuilder.js +107 -20
  64. package/dist/src/lib/transactionBuilderFactory.d.ts +19 -9
  65. package/dist/src/lib/transactionBuilderFactory.d.ts.map +1 -1
  66. package/dist/src/lib/transactionBuilderFactory.js +29 -10
  67. package/dist/src/lib/transferBuilder.js +4 -4
  68. package/dist/src/lib/transferBuilderV2.d.ts +14 -1
  69. package/dist/src/lib/transferBuilderV2.d.ts.map +1 -1
  70. package/dist/src/lib/transferBuilderV2.js +114 -11
  71. package/dist/src/lib/utils.d.ts +37 -6
  72. package/dist/src/lib/utils.d.ts.map +1 -1
  73. package/dist/src/lib/utils.js +194 -58
  74. package/dist/src/lib/walletInitializationBuilder.js +6 -6
  75. package/dist/src/sol.d.ts +81 -24
  76. package/dist/src/sol.d.ts.map +1 -1
  77. package/dist/src/sol.js +655 -91
  78. package/dist/src/solToken.d.ts +2 -1
  79. package/dist/src/solToken.d.ts.map +1 -1
  80. package/dist/src/solToken.js +6 -3
  81. package/dist/src/tsol.js +1 -1
  82. package/dist/test/fixtures/sol.d.ts +1152 -0
  83. package/dist/test/fixtures/sol.d.ts.map +1 -0
  84. package/dist/test/fixtures/sol.js +1433 -0
  85. package/dist/test/resources/sol.d.ts +238 -0
  86. package/dist/test/resources/sol.d.ts.map +1 -0
  87. package/dist/test/resources/sol.js +320 -0
  88. package/dist/test/unit/fixtures/solBackupKey.d.ts +5 -0
  89. package/dist/test/unit/fixtures/solBackupKey.d.ts.map +1 -0
  90. package/dist/test/unit/fixtures/solBackupKey.js +8 -0
  91. package/dist/test/unit/getBuilderFactory.d.ts +3 -0
  92. package/dist/test/unit/getBuilderFactory.d.ts.map +1 -0
  93. package/dist/test/unit/getBuilderFactory.js +10 -0
  94. package/dist/test/unit/instructionParamsFactory.d.ts +2 -0
  95. package/dist/test/unit/instructionParamsFactory.d.ts.map +1 -0
  96. package/dist/test/unit/instructionParamsFactory.js +412 -0
  97. package/dist/test/unit/instructionParamsFactory.staking.d.ts +2 -0
  98. package/dist/test/unit/instructionParamsFactory.staking.d.ts.map +1 -0
  99. package/dist/test/unit/instructionParamsFactory.staking.js +1059 -0
  100. package/dist/test/unit/keyPair.d.ts +2 -0
  101. package/dist/test/unit/keyPair.d.ts.map +1 -0
  102. package/dist/test/unit/keyPair.js +177 -0
  103. package/dist/test/unit/messages/messageBuilderFactory.d.ts +2 -0
  104. package/dist/test/unit/messages/messageBuilderFactory.d.ts.map +1 -0
  105. package/dist/test/unit/messages/messageBuilderFactory.js +118 -0
  106. package/dist/test/unit/messages/simpleMessageBuilder.d.ts +2 -0
  107. package/dist/test/unit/messages/simpleMessageBuilder.d.ts.map +1 -0
  108. package/dist/test/unit/messages/simpleMessageBuilder.js +194 -0
  109. package/dist/test/unit/sol.d.ts +2 -0
  110. package/dist/test/unit/sol.d.ts.map +1 -0
  111. package/dist/test/unit/sol.js +3108 -0
  112. package/dist/test/unit/solInstructionFactory.d.ts +2 -0
  113. package/dist/test/unit/solInstructionFactory.d.ts.map +1 -0
  114. package/dist/test/unit/solInstructionFactory.js +454 -0
  115. package/dist/test/unit/solToken.d.ts +2 -0
  116. package/dist/test/unit/solToken.d.ts.map +1 -0
  117. package/dist/test/unit/solToken.js +31 -0
  118. package/dist/test/unit/transaction.d.ts +2 -0
  119. package/dist/test/unit/transaction.d.ts.map +1 -0
  120. package/dist/test/unit/transaction.js +983 -0
  121. package/dist/test/unit/transactionBuilder/StakingWithdrawBuilder.d.ts +2 -0
  122. package/dist/test/unit/transactionBuilder/StakingWithdrawBuilder.d.ts.map +1 -0
  123. package/dist/test/unit/transactionBuilder/StakingWithdrawBuilder.js +202 -0
  124. package/dist/test/unit/transactionBuilder/ataInitBuilder.d.ts +2 -0
  125. package/dist/test/unit/transactionBuilder/ataInitBuilder.d.ts.map +1 -0
  126. package/dist/test/unit/transactionBuilder/ataInitBuilder.js +471 -0
  127. package/dist/test/unit/transactionBuilder/customInstructionBuilder.d.ts +2 -0
  128. package/dist/test/unit/transactionBuilder/customInstructionBuilder.d.ts.map +1 -0
  129. package/dist/test/unit/transactionBuilder/customInstructionBuilder.js +413 -0
  130. package/dist/test/unit/transactionBuilder/stakingActivateBuilder.d.ts +2 -0
  131. package/dist/test/unit/transactionBuilder/stakingActivateBuilder.d.ts.map +1 -0
  132. package/dist/test/unit/transactionBuilder/stakingActivateBuilder.js +430 -0
  133. package/dist/test/unit/transactionBuilder/stakingAuthorizeBuilder.d.ts +2 -0
  134. package/dist/test/unit/transactionBuilder/stakingAuthorizeBuilder.d.ts.map +1 -0
  135. package/dist/test/unit/transactionBuilder/stakingAuthorizeBuilder.js +157 -0
  136. package/dist/test/unit/transactionBuilder/stakingDeactivateBuilder.d.ts +2 -0
  137. package/dist/test/unit/transactionBuilder/stakingDeactivateBuilder.d.ts.map +1 -0
  138. package/dist/test/unit/transactionBuilder/stakingDeactivateBuilder.js +384 -0
  139. package/dist/test/unit/transactionBuilder/stakingDelegateBuilder.d.ts +2 -0
  140. package/dist/test/unit/transactionBuilder/stakingDelegateBuilder.d.ts.map +1 -0
  141. package/dist/test/unit/transactionBuilder/stakingDelegateBuilder.js +224 -0
  142. package/dist/test/unit/transactionBuilder/stakingRawMsgAuthorizeBuilder.d.ts +2 -0
  143. package/dist/test/unit/transactionBuilder/stakingRawMsgAuthorizeBuilder.d.ts.map +1 -0
  144. package/dist/test/unit/transactionBuilder/stakingRawMsgAuthorizeBuilder.js +259 -0
  145. package/dist/test/unit/transactionBuilder/tokenTransferBuilder.d.ts +2 -0
  146. package/dist/test/unit/transactionBuilder/tokenTransferBuilder.d.ts.map +1 -0
  147. package/dist/test/unit/transactionBuilder/tokenTransferBuilder.js +787 -0
  148. package/dist/test/unit/transactionBuilder/transactionBuilder.d.ts +2 -0
  149. package/dist/test/unit/transactionBuilder/transactionBuilder.d.ts.map +1 -0
  150. package/dist/test/unit/transactionBuilder/transactionBuilder.js +495 -0
  151. package/dist/test/unit/transactionBuilder/transferBuilder.d.ts +2 -0
  152. package/dist/test/unit/transactionBuilder/transferBuilder.d.ts.map +1 -0
  153. package/dist/test/unit/transactionBuilder/transferBuilder.js +286 -0
  154. package/dist/test/unit/transactionBuilder/transferBuilderV2.d.ts +2 -0
  155. package/dist/test/unit/transactionBuilder/transferBuilderV2.d.ts.map +1 -0
  156. package/dist/test/unit/transactionBuilder/transferBuilderV2.js +862 -0
  157. package/dist/test/unit/transactionBuilder/walletInitBuilder.d.ts +2 -0
  158. package/dist/test/unit/transactionBuilder/walletInitBuilder.d.ts.map +1 -0
  159. package/dist/test/unit/transactionBuilder/walletInitBuilder.js +259 -0
  160. package/dist/test/unit/utils.d.ts +2 -0
  161. package/dist/test/unit/utils.d.ts.map +1 -0
  162. package/dist/test/unit/utils.js +459 -0
  163. package/dist/test/unit/versionedTransaction.d.ts +2 -0
  164. package/dist/test/unit/versionedTransaction.d.ts.map +1 -0
  165. package/dist/test/unit/versionedTransaction.js +207 -0
  166. package/dist/tsconfig.tsbuildinfo +1 -0
  167. package/package.json +16 -11
  168. package/.eslintignore +0 -5
  169. package/.mocharc.yml +0 -8
  170. package/CHANGELOG.md +0 -353
@@ -3,13 +3,17 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.solInstructionFactory = void 0;
6
+ exports.solInstructionFactory = solInstructionFactory;
7
+ const public_types_1 = require("@bitgo/public-types");
8
+ const statics_1 = require("@bitgo-beta/statics");
9
+ const spl_token_1 = require("@solana/spl-token");
7
10
  const web3_js_1 = require("@solana/web3.js");
8
11
  const assert_1 = __importDefault(require("assert"));
9
12
  const bignumber_js_1 = __importDefault(require("bignumber.js"));
10
13
  const constants_1 = require("./constants");
11
- const statics_1 = require("@bitgo-beta/statics");
12
- const spl_token_1 = require("@solana/spl-token");
14
+ const utils_1 = require("./utils");
15
+ const jitoStakePoolOperations_1 = require("./jitoStakePoolOperations");
16
+ const token2022Config_1 = require("./token2022Config");
13
17
  /**
14
18
  * Construct Solana instructions from instructions params
15
19
  *
@@ -26,6 +30,8 @@ function solInstructionFactory(instructionToBuild) {
26
30
  return transferInstruction(instructionToBuild);
27
31
  case constants_1.InstructionBuilderTypes.TokenTransfer:
28
32
  return tokenTransferInstruction(instructionToBuild);
33
+ case constants_1.InstructionBuilderTypes.Approve:
34
+ return approveInstruction(instructionToBuild);
29
35
  case constants_1.InstructionBuilderTypes.CreateNonceAccount:
30
36
  return createNonceAccountInstruction(instructionToBuild);
31
37
  case constants_1.InstructionBuilderTypes.StakingActivate:
@@ -36,15 +42,24 @@ function solInstructionFactory(instructionToBuild) {
36
42
  return stakingWithdrawInstruction(instructionToBuild);
37
43
  case constants_1.InstructionBuilderTypes.CreateAssociatedTokenAccount:
38
44
  return createATAInstruction(instructionToBuild);
45
+ case constants_1.InstructionBuilderTypes.CloseAssociatedTokenAccount:
46
+ return closeATAInstruction(instructionToBuild);
39
47
  case constants_1.InstructionBuilderTypes.StakingAuthorize:
40
48
  return stakingAuthorizeInstruction(instructionToBuild);
41
49
  case constants_1.InstructionBuilderTypes.StakingDelegate:
42
50
  return stakingDelegateInstruction(instructionToBuild);
51
+ case constants_1.InstructionBuilderTypes.SetPriorityFee:
52
+ return fetchPriorityFeeInstruction(instructionToBuild);
53
+ case constants_1.InstructionBuilderTypes.MintTo:
54
+ return mintToInstruction(instructionToBuild);
55
+ case constants_1.InstructionBuilderTypes.Burn:
56
+ return burnInstruction(instructionToBuild);
57
+ case constants_1.InstructionBuilderTypes.CustomInstruction:
58
+ return customInstruction(instructionToBuild);
43
59
  default:
44
60
  throw new Error(`Invalid instruction type or not supported`);
45
61
  }
46
62
  }
47
- exports.solInstructionFactory = solInstructionFactory;
48
63
  /**
49
64
  * Construct Advance Nonce Solana instructions
50
65
  *
@@ -53,14 +68,20 @@ exports.solInstructionFactory = solInstructionFactory;
53
68
  */
54
69
  function advanceNonceInstruction(data) {
55
70
  const { params: { authWalletAddress, walletNonceAddress }, } = data;
56
- assert_1.default(authWalletAddress, 'Missing authWalletAddress param');
57
- assert_1.default(walletNonceAddress, 'Missing walletNonceAddress param');
71
+ (0, assert_1.default)(authWalletAddress, 'Missing authWalletAddress param');
72
+ (0, assert_1.default)(walletNonceAddress, 'Missing walletNonceAddress param');
58
73
  const nonceInstruction = web3_js_1.SystemProgram.nonceAdvance({
59
74
  noncePubkey: new web3_js_1.PublicKey(walletNonceAddress),
60
75
  authorizedPubkey: new web3_js_1.PublicKey(authWalletAddress),
61
76
  });
62
77
  return [nonceInstruction];
63
78
  }
79
+ function fetchPriorityFeeInstruction(instructionToBuild) {
80
+ const addPriorityFee = web3_js_1.ComputeBudgetProgram.setComputeUnitPrice({
81
+ microLamports: instructionToBuild.params.fee,
82
+ });
83
+ return [addPriorityFee];
84
+ }
64
85
  /**
65
86
  * Construct Memo Solana instructions
66
87
  *
@@ -69,7 +90,7 @@ function advanceNonceInstruction(data) {
69
90
  */
70
91
  function memoInstruction(data) {
71
92
  const { params: { memo }, } = data;
72
- assert_1.default(memo, 'Missing memo param');
93
+ (0, assert_1.default)(memo, 'Missing memo param');
73
94
  const memoInstruction = new web3_js_1.TransactionInstruction({
74
95
  keys: [],
75
96
  programId: new web3_js_1.PublicKey(constants_1.MEMO_PROGRAM_PK),
@@ -85,9 +106,9 @@ function memoInstruction(data) {
85
106
  */
86
107
  function transferInstruction(data) {
87
108
  const { params: { fromAddress, toAddress, amount }, } = data;
88
- assert_1.default(fromAddress, 'Missing fromAddress param');
89
- assert_1.default(toAddress, 'Missing toAddress param');
90
- assert_1.default(amount, 'Missing toAddress param');
109
+ (0, assert_1.default)(fromAddress, 'Missing fromAddress param');
110
+ (0, assert_1.default)(toAddress, 'Missing toAddress param');
111
+ (0, assert_1.default)(amount, 'Missing toAddress param');
91
112
  const transferInstruction = web3_js_1.SystemProgram.transfer({
92
113
  fromPubkey: new web3_js_1.PublicKey(fromAddress),
93
114
  toPubkey: new web3_js_1.PublicKey(toAddress),
@@ -103,15 +124,62 @@ function transferInstruction(data) {
103
124
  */
104
125
  function tokenTransferInstruction(data) {
105
126
  const { params: { fromAddress, toAddress, amount, tokenName, sourceAddress }, } = data;
106
- assert_1.default(fromAddress, 'Missing fromAddress (owner) param');
107
- assert_1.default(toAddress, 'Missing toAddress param');
108
- assert_1.default(amount, 'Missing amount param');
109
- assert_1.default(tokenName, 'Missing token name');
110
- assert_1.default(sourceAddress, 'Missing ata address');
111
- const token = statics_1.coins.get(data.params.tokenName);
112
- assert_1.default(token instanceof statics_1.SolCoin);
113
- const transferInstruction = spl_token_1.createTransferCheckedInstruction(new web3_js_1.PublicKey(sourceAddress), new web3_js_1.PublicKey(token.tokenAddress), new web3_js_1.PublicKey(toAddress), new web3_js_1.PublicKey(fromAddress), BigInt(amount), token.decimalPlaces);
114
- return [transferInstruction];
127
+ (0, assert_1.default)(fromAddress, 'Missing fromAddress (owner) param');
128
+ (0, assert_1.default)(toAddress, 'Missing toAddress param');
129
+ (0, assert_1.default)(amount, 'Missing amount param');
130
+ (0, assert_1.default)(tokenName, 'Missing token name');
131
+ (0, assert_1.default)(sourceAddress, 'Missing ata address');
132
+ const token = (0, utils_1.getSolTokenFromTokenName)(data.params.tokenName);
133
+ let tokenAddress;
134
+ let programId;
135
+ let decimalPlaces;
136
+ if (data.params.tokenAddress && data.params.decimalPlaces) {
137
+ tokenAddress = data.params.tokenAddress;
138
+ decimalPlaces = data.params.decimalPlaces;
139
+ programId = data.params.programId;
140
+ }
141
+ else if (token) {
142
+ (0, assert_1.default)(token instanceof statics_1.SolCoin);
143
+ tokenAddress = token.tokenAddress;
144
+ decimalPlaces = token.decimalPlaces;
145
+ programId = token.programId;
146
+ }
147
+ else {
148
+ throw new Error('Invalid token name, got:' + data.params.tokenName);
149
+ }
150
+ let transferInstruction;
151
+ const instructions = [];
152
+ if (programId === spl_token_1.TOKEN_2022_PROGRAM_ID.toString()) {
153
+ // Create the base transfer instruction
154
+ transferInstruction = (0, spl_token_1.createTransferCheckedInstruction)(new web3_js_1.PublicKey(sourceAddress), new web3_js_1.PublicKey(tokenAddress), new web3_js_1.PublicKey(toAddress), new web3_js_1.PublicKey(fromAddress), BigInt(amount), decimalPlaces, [], spl_token_1.TOKEN_2022_PROGRAM_ID);
155
+ // Check if this token has a transfer hook configuration
156
+ const tokenConfig = (0, token2022Config_1.getToken2022Config)(tokenAddress);
157
+ if (tokenConfig?.transferHook) {
158
+ addTransferHookAccounts(transferInstruction, tokenConfig.transferHook);
159
+ }
160
+ }
161
+ else {
162
+ transferInstruction = (0, spl_token_1.createTransferCheckedInstruction)(new web3_js_1.PublicKey(sourceAddress), new web3_js_1.PublicKey(tokenAddress), new web3_js_1.PublicKey(toAddress), new web3_js_1.PublicKey(fromAddress), BigInt(amount), decimalPlaces);
163
+ }
164
+ instructions.push(transferInstruction);
165
+ return instructions;
166
+ }
167
+ /**
168
+ * Construct Transfer Solana instructions
169
+ *
170
+ * @param {Transfer} data - the data to build the instruction
171
+ * @returns {TransactionInstruction[]} An array containing Transfer Solana instruction
172
+ */
173
+ function approveInstruction(data) {
174
+ const { params: { accountAddress, delegateAddress, ownerAddress, amount, programId }, } = data;
175
+ (0, assert_1.default)(accountAddress, 'Missing fromAddress (owner) param');
176
+ (0, assert_1.default)(delegateAddress, 'Missing toAddress param');
177
+ (0, assert_1.default)(ownerAddress, 'Missing ownerAddress param');
178
+ (0, assert_1.default)(programId, 'Missing programId param');
179
+ (0, assert_1.default)(amount, 'Missing amount param');
180
+ return [
181
+ (0, spl_token_1.createApproveInstruction)(new web3_js_1.PublicKey(accountAddress), new web3_js_1.PublicKey(delegateAddress), new web3_js_1.PublicKey(ownerAddress), BigInt(amount), undefined, programId === undefined ? undefined : new web3_js_1.PublicKey(programId)),
182
+ ];
115
183
  }
116
184
  /**
117
185
  * Construct Create and Initialize Nonce Solana instructions
@@ -121,10 +189,10 @@ function tokenTransferInstruction(data) {
121
189
  */
122
190
  function createNonceAccountInstruction(data) {
123
191
  const { params: { fromAddress, nonceAddress, authAddress, amount }, } = data;
124
- assert_1.default(fromAddress, 'Missing fromAddress param');
125
- assert_1.default(nonceAddress, 'Missing nonceAddress param');
126
- assert_1.default(authAddress, 'Missing authAddress param');
127
- assert_1.default(amount, 'Missing amount param');
192
+ (0, assert_1.default)(fromAddress, 'Missing fromAddress param');
193
+ (0, assert_1.default)(nonceAddress, 'Missing nonceAddress param');
194
+ (0, assert_1.default)(authAddress, 'Missing authAddress param');
195
+ (0, assert_1.default)(amount, 'Missing amount param');
128
196
  const nonceAccountInstruction = web3_js_1.SystemProgram.createNonceAccount({
129
197
  fromPubkey: new web3_js_1.PublicKey(fromAddress),
130
198
  noncePubkey: new web3_js_1.PublicKey(nonceAddress),
@@ -140,28 +208,59 @@ function createNonceAccountInstruction(data) {
140
208
  * @returns {TransactionInstruction[]} An array containing Create Staking Account and Delegate Solana instructions
141
209
  */
142
210
  function stakingInitializeInstruction(data) {
143
- const { params: { fromAddress, stakingAddress, amount, validator }, } = data;
144
- assert_1.default(fromAddress, 'Missing fromAddress param');
145
- assert_1.default(stakingAddress, 'Missing stakingAddress param');
146
- assert_1.default(amount, 'Missing amount param');
147
- assert_1.default(validator, 'Missing validator param');
211
+ const { params: { fromAddress, stakingAddress, amount, validator, stakingType, extraParams }, } = data;
212
+ (0, assert_1.default)(fromAddress, 'Missing fromAddress param');
213
+ (0, assert_1.default)(stakingAddress, 'Missing stakingAddress param');
214
+ (0, assert_1.default)(amount, 'Missing amount param');
215
+ (0, assert_1.default)(validator, 'Missing validator param');
148
216
  const fromPubkey = new web3_js_1.PublicKey(fromAddress);
149
217
  const stakePubkey = new web3_js_1.PublicKey(stakingAddress);
218
+ const validatorPubkey = new web3_js_1.PublicKey(validator);
150
219
  const tx = new web3_js_1.Transaction();
151
- const walletInitStaking = web3_js_1.StakeProgram.createAccount({
152
- fromPubkey,
153
- stakePubkey,
154
- authorized: new web3_js_1.Authorized(fromPubkey, fromPubkey),
155
- lockup: new web3_js_1.Lockup(0, 0, fromPubkey),
156
- lamports: new bignumber_js_1.default(amount).toNumber(),
157
- });
158
- tx.add(walletInitStaking);
159
- const delegateStaking = web3_js_1.StakeProgram.delegate({
160
- stakePubkey: new web3_js_1.PublicKey(stakingAddress),
161
- authorizedPubkey: new web3_js_1.PublicKey(fromAddress),
162
- votePubkey: new web3_js_1.PublicKey(validator),
163
- });
164
- tx.add(delegateStaking);
220
+ switch (stakingType) {
221
+ case public_types_1.SolStakingTypeEnum.JITO: {
222
+ (0, assert_1.default)(extraParams !== undefined, 'Missing extraParams param');
223
+ const instructions = (0, jitoStakePoolOperations_1.depositSolInstructions)({
224
+ stakePoolAddress: stakePubkey,
225
+ from: fromPubkey,
226
+ lamports: BigInt(amount),
227
+ }, extraParams.stakePoolData, !!extraParams.createAssociatedTokenAccount);
228
+ tx.add(...instructions);
229
+ break;
230
+ }
231
+ case public_types_1.SolStakingTypeEnum.MARINADE: {
232
+ const walletInitStaking = web3_js_1.StakeProgram.createAccount({
233
+ fromPubkey,
234
+ stakePubkey,
235
+ authorized: new web3_js_1.Authorized(validatorPubkey, fromPubkey), // staker and withdrawer
236
+ lockup: new web3_js_1.Lockup(0, 0, fromPubkey), // No minimum epoch to withdraw
237
+ lamports: new bignumber_js_1.default(amount).toNumber(),
238
+ });
239
+ tx.add(walletInitStaking);
240
+ break;
241
+ }
242
+ case public_types_1.SolStakingTypeEnum.NATIVE: {
243
+ const walletInitStaking = web3_js_1.StakeProgram.createAccount({
244
+ fromPubkey,
245
+ stakePubkey,
246
+ authorized: new web3_js_1.Authorized(fromPubkey, fromPubkey), // staker and withdrawer
247
+ lockup: new web3_js_1.Lockup(0, 0, fromPubkey), // No minimum epoch to withdraw
248
+ lamports: new bignumber_js_1.default(amount).toNumber(),
249
+ });
250
+ tx.add(walletInitStaking);
251
+ const delegateStaking = web3_js_1.StakeProgram.delegate({
252
+ stakePubkey: new web3_js_1.PublicKey(stakingAddress),
253
+ authorizedPubkey: new web3_js_1.PublicKey(fromAddress),
254
+ votePubkey: new web3_js_1.PublicKey(validator),
255
+ });
256
+ tx.add(delegateStaking);
257
+ break;
258
+ }
259
+ default: {
260
+ const unreachable = stakingType;
261
+ throw new Error(`Unknown staking type ${unreachable}`);
262
+ }
263
+ }
165
264
  return tx.instructions;
166
265
  }
167
266
  /**
@@ -171,42 +270,78 @@ function stakingInitializeInstruction(data) {
171
270
  * @returns {TransactionInstruction[]} An array containing staking deactivate instruction
172
271
  */
173
272
  function stakingDeactivateInstruction(data) {
174
- const { params: { fromAddress, stakingAddress }, } = data;
175
- assert_1.default(fromAddress, 'Missing fromAddress param');
176
- assert_1.default(stakingAddress, 'Missing stakingAddress param');
177
- if (data.params.amount && data.params.unstakingAddress) {
178
- const tx = new web3_js_1.Transaction();
179
- const unstakingAddress = new web3_js_1.PublicKey(data.params.unstakingAddress);
180
- const allocateAccount = web3_js_1.SystemProgram.allocate({
181
- accountPubkey: unstakingAddress,
182
- space: web3_js_1.StakeProgram.space,
183
- });
184
- tx.add(allocateAccount);
185
- const assignAccount = web3_js_1.SystemProgram.assign({
186
- accountPubkey: unstakingAddress,
187
- programId: web3_js_1.StakeProgram.programId,
188
- });
189
- tx.add(assignAccount);
190
- const splitStake = web3_js_1.StakeProgram.split({
191
- stakePubkey: new web3_js_1.PublicKey(stakingAddress),
192
- authorizedPubkey: new web3_js_1.PublicKey(fromAddress),
193
- splitStakePubkey: unstakingAddress,
194
- lamports: new bignumber_js_1.default(data.params.amount).toNumber(),
195
- });
196
- tx.add(splitStake.instructions[1]);
197
- const deactivateStaking = web3_js_1.StakeProgram.deactivate({
198
- stakePubkey: unstakingAddress,
199
- authorizedPubkey: new web3_js_1.PublicKey(fromAddress),
200
- });
201
- tx.add(deactivateStaking);
202
- return tx.instructions;
203
- }
204
- else {
205
- const deactivateStaking = web3_js_1.StakeProgram.deactivate({
206
- stakePubkey: new web3_js_1.PublicKey(stakingAddress),
207
- authorizedPubkey: new web3_js_1.PublicKey(fromAddress),
208
- });
209
- return deactivateStaking.instructions;
273
+ const { params: { fromAddress, stakingAddress, amount, unstakingAddress, recipients, stakingType, extraParams }, } = data;
274
+ (0, assert_1.default)(fromAddress, 'Missing fromAddress param');
275
+ switch (stakingType) {
276
+ case public_types_1.SolStakingTypeEnum.JITO: {
277
+ (0, assert_1.default)(stakingAddress, 'Missing stakingAddress param');
278
+ (0, assert_1.default)(unstakingAddress, 'Missing unstakingAddress param');
279
+ (0, assert_1.default)(amount, 'Missing amount param');
280
+ (0, assert_1.default)(extraParams, 'Missing extraParams param');
281
+ const tx = new web3_js_1.Transaction();
282
+ tx.add(...(0, jitoStakePoolOperations_1.withdrawStakeInstructions)({
283
+ stakePoolAddress: new web3_js_1.PublicKey(stakingAddress),
284
+ tokenOwner: new web3_js_1.PublicKey(fromAddress),
285
+ destinationStakeAccount: new web3_js_1.PublicKey(unstakingAddress),
286
+ validatorAddress: new web3_js_1.PublicKey(extraParams.validatorAddress),
287
+ transferAuthority: new web3_js_1.PublicKey(extraParams.transferAuthorityAddress),
288
+ poolAmount: amount,
289
+ }, extraParams.stakePoolData));
290
+ return tx.instructions;
291
+ }
292
+ case public_types_1.SolStakingTypeEnum.MARINADE: {
293
+ (0, assert_1.default)(recipients, 'Missing recipients param');
294
+ const tx = new web3_js_1.Transaction();
295
+ const toPubkeyAddress = new web3_js_1.PublicKey(recipients[0].address || '');
296
+ const transferInstruction = web3_js_1.SystemProgram.transfer({
297
+ fromPubkey: new web3_js_1.PublicKey(fromAddress),
298
+ toPubkey: toPubkeyAddress,
299
+ lamports: parseInt(recipients[0].amount, 10),
300
+ });
301
+ tx.add(transferInstruction);
302
+ return tx.instructions;
303
+ }
304
+ case public_types_1.SolStakingTypeEnum.NATIVE: {
305
+ (0, assert_1.default)(stakingAddress, 'Missing stakingAddress param');
306
+ if (data.params.amount && data.params.unstakingAddress) {
307
+ const tx = new web3_js_1.Transaction();
308
+ const unstakingAddress = new web3_js_1.PublicKey(data.params.unstakingAddress);
309
+ const allocateAccount = web3_js_1.SystemProgram.allocate({
310
+ accountPubkey: unstakingAddress,
311
+ space: web3_js_1.StakeProgram.space,
312
+ });
313
+ tx.add(allocateAccount);
314
+ const assignAccount = web3_js_1.SystemProgram.assign({
315
+ accountPubkey: unstakingAddress,
316
+ programId: web3_js_1.StakeProgram.programId,
317
+ });
318
+ tx.add(assignAccount);
319
+ const splitStake = web3_js_1.StakeProgram.split({
320
+ stakePubkey: new web3_js_1.PublicKey(stakingAddress),
321
+ authorizedPubkey: new web3_js_1.PublicKey(fromAddress),
322
+ splitStakePubkey: unstakingAddress,
323
+ lamports: new bignumber_js_1.default(data.params.amount).toNumber(),
324
+ }, 0);
325
+ tx.add(splitStake.instructions[1]);
326
+ const deactivateStaking = web3_js_1.StakeProgram.deactivate({
327
+ stakePubkey: unstakingAddress,
328
+ authorizedPubkey: new web3_js_1.PublicKey(fromAddress),
329
+ });
330
+ tx.add(deactivateStaking);
331
+ return tx.instructions;
332
+ }
333
+ else {
334
+ const deactivateStaking = web3_js_1.StakeProgram.deactivate({
335
+ stakePubkey: new web3_js_1.PublicKey(stakingAddress),
336
+ authorizedPubkey: new web3_js_1.PublicKey(fromAddress),
337
+ });
338
+ return deactivateStaking.instructions;
339
+ }
340
+ }
341
+ default: {
342
+ const unreachable = stakingType;
343
+ throw new Error(`Unknown staking type ${unreachable}`);
344
+ }
210
345
  }
211
346
  }
212
347
  /**
@@ -217,9 +352,9 @@ function stakingDeactivateInstruction(data) {
217
352
  */
218
353
  function stakingWithdrawInstruction(data) {
219
354
  const { params: { fromAddress, stakingAddress, amount }, } = data;
220
- assert_1.default(fromAddress, 'Missing fromAddress param');
221
- assert_1.default(stakingAddress, 'Missing stakingAddress param');
222
- assert_1.default(amount, 'Missing amount param');
355
+ (0, assert_1.default)(fromAddress, 'Missing fromAddress param');
356
+ (0, assert_1.default)(stakingAddress, 'Missing stakingAddress param');
357
+ (0, assert_1.default)(amount, 'Missing amount param');
223
358
  const withdrawStaking = web3_js_1.StakeProgram.withdraw({
224
359
  stakePubkey: new web3_js_1.PublicKey(stakingAddress),
225
360
  authorizedPubkey: new web3_js_1.PublicKey(fromAddress),
@@ -235,14 +370,34 @@ function stakingWithdrawInstruction(data) {
235
370
  * @returns {TransactionInstruction[]} An array containing Create and Initialize Nonce Solana instruction
236
371
  */
237
372
  function createATAInstruction(data) {
238
- const { params: { mintAddress, ataAddress, ownerAddress, payerAddress }, } = data;
239
- assert_1.default(mintAddress, 'Missing mintAddress param');
240
- assert_1.default(ataAddress, 'Missing ataAddress param');
241
- assert_1.default(ownerAddress, 'Missing ownerAddress param');
242
- assert_1.default(payerAddress, 'Missing payerAddress param');
243
- const associatedTokenAccountInstruction = spl_token_1.createAssociatedTokenAccountInstruction(new web3_js_1.PublicKey(payerAddress), new web3_js_1.PublicKey(ataAddress), new web3_js_1.PublicKey(ownerAddress), new web3_js_1.PublicKey(mintAddress));
373
+ const { params: { mintAddress, ataAddress, ownerAddress, payerAddress, programId }, } = data;
374
+ (0, assert_1.default)(mintAddress, 'Missing mintAddress param');
375
+ (0, assert_1.default)(ataAddress, 'Missing ataAddress param');
376
+ (0, assert_1.default)(ownerAddress, 'Missing ownerAddress param');
377
+ (0, assert_1.default)(payerAddress, 'Missing payerAddress param');
378
+ let associatedTokenAccountInstruction;
379
+ if (programId && programId === spl_token_1.TOKEN_2022_PROGRAM_ID.toString()) {
380
+ associatedTokenAccountInstruction = (0, spl_token_1.createAssociatedTokenAccountInstruction)(new web3_js_1.PublicKey(payerAddress), new web3_js_1.PublicKey(ataAddress), new web3_js_1.PublicKey(ownerAddress), new web3_js_1.PublicKey(mintAddress), spl_token_1.TOKEN_2022_PROGRAM_ID);
381
+ }
382
+ else {
383
+ associatedTokenAccountInstruction = (0, spl_token_1.createAssociatedTokenAccountInstruction)(new web3_js_1.PublicKey(payerAddress), new web3_js_1.PublicKey(ataAddress), new web3_js_1.PublicKey(ownerAddress), new web3_js_1.PublicKey(mintAddress));
384
+ }
244
385
  return [associatedTokenAccountInstruction];
245
386
  }
387
+ /**
388
+ * Construct Close ATA Solana instructions
389
+ *
390
+ * @param {WalletInit} data - the data to build the instruction
391
+ * @returns {TransactionInstruction[]} An array containing Close ATA Solana instruction
392
+ */
393
+ function closeATAInstruction(data) {
394
+ const { params: { accountAddress, destinationAddress, authorityAddress }, } = data;
395
+ (0, assert_1.default)(accountAddress, 'Missing accountAddress param');
396
+ (0, assert_1.default)(destinationAddress, 'Missing destinationAddress param');
397
+ (0, assert_1.default)(authorityAddress, 'Missing authorityAddress param');
398
+ const closeAssociatedTokenAccountInstruction = (0, spl_token_1.createCloseAccountInstruction)(new web3_js_1.PublicKey(accountAddress), new web3_js_1.PublicKey(destinationAddress), new web3_js_1.PublicKey(authorityAddress));
399
+ return [closeAssociatedTokenAccountInstruction];
400
+ }
246
401
  /**
247
402
  * Construct Staking Account Authorize Solana instructions
248
403
  *
@@ -251,10 +406,10 @@ function createATAInstruction(data) {
251
406
  */
252
407
  function stakingAuthorizeInstruction(data) {
253
408
  const { params: { stakingAddress, oldAuthorizeAddress, newAuthorizeAddress, newWithdrawAddress }, } = data;
254
- assert_1.default(stakingAddress, 'Missing stakingAddress param');
255
- assert_1.default(oldAuthorizeAddress, 'Missing oldAuthorizeAddress param');
256
- assert_1.default(newAuthorizeAddress, 'Missing newAuthorizeAddress param');
257
- assert_1.default(newWithdrawAddress, 'Missing newWithdrawAddress param');
409
+ (0, assert_1.default)(stakingAddress, 'Missing stakingAddress param');
410
+ (0, assert_1.default)(oldAuthorizeAddress, 'Missing oldAuthorizeAddress param');
411
+ (0, assert_1.default)(newAuthorizeAddress, 'Missing newAuthorizeAddress param');
412
+ (0, assert_1.default)(newWithdrawAddress, 'Missing newWithdrawAddress param');
258
413
  const tx = new web3_js_1.Transaction();
259
414
  const authorizeStaking = web3_js_1.StakeProgram.authorize({
260
415
  stakePubkey: new web3_js_1.PublicKey(stakingAddress),
@@ -281,9 +436,9 @@ function stakingAuthorizeInstruction(data) {
281
436
  */
282
437
  function stakingDelegateInstruction(data) {
283
438
  const { params: { fromAddress, stakingAddress, validator }, } = data;
284
- assert_1.default(fromAddress, 'Missing fromAddress param');
285
- assert_1.default(stakingAddress, 'Missing stakingAddress param');
286
- assert_1.default(validator, 'Missing validator param');
439
+ (0, assert_1.default)(fromAddress, 'Missing fromAddress param');
440
+ (0, assert_1.default)(stakingAddress, 'Missing stakingAddress param');
441
+ (0, assert_1.default)(validator, 'Missing validator param');
287
442
  const tx = new web3_js_1.Transaction();
288
443
  const delegateStaking = web3_js_1.StakeProgram.delegate({
289
444
  stakePubkey: new web3_js_1.PublicKey(stakingAddress),
@@ -293,4 +448,117 @@ function stakingDelegateInstruction(data) {
293
448
  tx.add(delegateStaking);
294
449
  return tx.instructions;
295
450
  }
296
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic29sSW5zdHJ1Y3Rpb25GYWN0b3J5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2xpYi9zb2xJbnN0cnVjdGlvbkZhY3RvcnkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsNkNBU3lCO0FBQ3pCLG9EQUE0QjtBQUM1QixnRUFBcUM7QUFDckMsMkNBQXVFO0FBZXZFLGlEQUFxRDtBQUNyRCxpREFBOEc7QUFFOUc7Ozs7O0dBS0c7QUFDSCxTQUFnQixxQkFBcUIsQ0FBQyxrQkFBcUM7SUFDekUsUUFBUSxrQkFBa0IsQ0FBQyxJQUFJLEVBQUU7UUFDL0IsS0FBSyxtQ0FBdUIsQ0FBQyxZQUFZO1lBQ3ZDLE9BQU8sdUJBQXVCLENBQUMsa0JBQWtCLENBQUMsQ0FBQztRQUNyRCxLQUFLLG1DQUF1QixDQUFDLElBQUk7WUFDL0IsT0FBTyxlQUFlLENBQUMsa0JBQWtCLENBQUMsQ0FBQztRQUM3QyxLQUFLLG1DQUF1QixDQUFDLFFBQVE7WUFDbkMsT0FBTyxtQkFBbUIsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO1FBQ2pELEtBQUssbUNBQXVCLENBQUMsYUFBYTtZQUN4QyxPQUFPLHdCQUF3QixDQUFDLGtCQUFrQixDQUFDLENBQUM7UUFDdEQsS0FBSyxtQ0FBdUIsQ0FBQyxrQkFBa0I7WUFDN0MsT0FBTyw2QkFBNkIsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO1FBQzNELEtBQUssbUNBQXVCLENBQUMsZUFBZTtZQUMxQyxPQUFPLDRCQUE0QixDQUFDLGtCQUFrQixDQUFDLENBQUM7UUFDMUQsS0FBSyxtQ0FBdUIsQ0FBQyxpQkFBaUI7WUFDNUMsT0FBTyw0QkFBNEIsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO1FBQzFELEtBQUssbUNBQXVCLENBQUMsZUFBZTtZQUMxQyxPQUFPLDBCQUEwQixDQUFDLGtCQUFrQixDQUFDLENBQUM7UUFDeEQsS0FBSyxtQ0FBdUIsQ0FBQyw0QkFBNEI7WUFDdkQsT0FBTyxvQkFBb0IsQ0FB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Z0IsQ0FBQyxDQUFDO0lBQ3pCLEVBQUUsQ0FBQyxHQUFHLENBQUMsaUJBQWlCLENBQUMsQ0FBQztJQUUxQixPQUFPLEVBQUUsQ0FBQyxZQUFZLENBQUM7QUFDekIsQ0FBQztBQUVEOzs7OztHQUtHO0FBQ0gsU0FBUywwQkFBMEIsQ0FBQyxJQUFxQjtJQUN2RCxNQUFNLEVBQ0osTUFBTSxFQUFFLEVBQUUsV0FBVyxFQUFFLGNBQWMsRUFBRSxTQUFTLEVBQUUsR0FDbkQsR0FBRyxJQUFJLENBQUM7SUFDVCxnQkFBTSxDQUFDLFdBQVcsRUFBRSwyQkFBMkIsQ0FBQyxDQUFDO0lBQ2pELGdCQUFNLENBQUMsY0FBYyxFQUFFLDhCQUE4QixDQUFDLENBQUM7SUFDdkQsZ0JBQU0sQ0FBQyxTQUFTLEVBQUUseUJBQXlCLENBQUMsQ0FBQztJQUM3QyxNQUFNLEVBQUUsR0FBRyxJQUFJLHFCQUFXLEVBQUUsQ0FBQztJQUM3QixNQUFNLGVBQWUsR0FBRyxzQkFBWSxDQUFDLFFBQVEsQ0FBQztRQUM1QyxXQUFXLEVBQUUsSUFBSSxtQkFBUyxDQUFDLGNBQWMsQ0FBQztRQUMxQyxnQkFBZ0IsRUFBRSxJQUFJLG1CQUFTLENBQUMsV0FBVyxDQUFDO1FBQzVDLFVBQVUsRUFBRSxJQUFJLG1CQUFTLENBQUMsU0FBUyxDQUFDO0tBQ3JDLENBQUMsQ0FBQztJQUNILEVBQUUsQ0FBQyxHQUFHLENBQUMsZUFBZSxDQUFDLENBQUM7SUFFeEIsT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDO0FBQ3pCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBBdXRob3JpemVkLFxuICBMb2NrdXAsXG4gIFB1YmxpY0tleSxcbiAgU3Rha2VQcm9ncmFtLFxuICBTeXN0ZW1Qcm9ncmFtLFxuICBUcmFuc2FjdGlvbkluc3RydWN0aW9uLFxuICBUcmFuc2FjdGlvbixcbiAgU3Rha2VBdXRob3JpemF0aW9uTGF5b3V0LFxufSBmcm9tICdAc29sYW5hL3dlYjMuanMnO1xuaW1wb3J0IGFzc2VydCBmcm9tICdhc3NlcnQnO1xuaW1wb3J0IEJpZ051bWJlciBmcm9tICdiaWdudW1iZXIuanMnO1xuaW1wb3J0IHsgSW5zdHJ1Y3Rpb25CdWlsZGVyVHlwZXMsIE1FTU9fUFJPR1JBTV9QSyB9IGZyb20gJy4vY29uc3RhbnRzJztcbmltcG9ydCB7XG4gIEF0YUluaXQsXG4gIEluc3RydWN0aW9uUGFyYW1zLFxuICBNZW1vLFxuICBOb25jZSxcbiAgU3Rha2luZ0FjdGl2YXRlLFxuICBTdGFraW5nQXV0aG9yaXplLFxuICBTdGFraW5nRGVhY3RpdmF0ZSxcbiAgU3Rha2luZ0RlbGVnYXRlLFxuICBTdGFraW5nV2l0aGRyYXcsXG4gIFRva2VuVHJhbnNmZXIsXG4gIFRyYW5zZmVyLFxuICBXYWxsZXRJbml0LFxufSBmcm9tICcuL2lmYWNlJztcbmltcG9ydCB7IGNvaW5zLCBTb2xDb2luIH0gZnJvbSAnQGJpdGdvLWJldGEvc3RhdGljcyc7XG5pbXBvcnQgeyBjcmVhdGVUcmFuc2ZlckNoZWNrZWRJbnN0cnVjdGlvbiwgY3JlYXRlQXNzb2NpYXRlZFRva2VuQWNjb3VudEluc3RydWN0aW9uIH0gZnJvbSAnQHNvbGFuYS9zcGwtdG9rZW4nO1xuXG4vKipcbiAqIENvbnN0cnVjdCBTb2xhbmEgaW5zdHJ1Y3Rpb25zIGZyb20gaW5zdHJ1Y3Rpb25zIHBhcmFtc1xuICpcbiAqIEBwYXJhbSB7SW5zdHJ1Y3Rpb25QYXJhbXN9IGluc3RydWN0aW9uVG9CdWlsZCAtIHRoZSBkYXRhIGNvbnRhaW5pbmcgdGhlIGluc3RydWN0aW9uIHBhcmFtc1xuICogQHJldHVybnMge1RyYW5zYWN0aW9uSW5zdHJ1Y3Rpb25bXX0gQW4gYXJyYXkgY29udGFpbmluZyBzdXBwb3J0ZWQgU29sYW5hIGluc3RydWN0aW9uc1xuICovXG5leHBvcnQgZnVuY3Rpb24gc29sSW5zdHJ1Y3Rpb25GYWN0b3J5KGluc3RydWN0aW9uVG9CdWlsZDogSW5zdHJ1Y3Rpb25QYXJhbXMpOiBUcmFuc2FjdGlvbkluc3RydWN0aW9uW10ge1xuICBzd2l0Y2ggKGluc3RydWN0aW9uVG9CdWlsZC50eXBlKSB7XG4gICAgY2FzZSBJbnN0cnVjdGlvbkJ1aWxkZXJUeXBlcy5Ob25jZUFkdmFuY2U6XG4gICAgICByZXR1cm4gYWR2YW5jZU5vbmNlSW5zdHJ1Y3Rpb24oaW5zdHJ1Y3Rpb25Ub0J1aWxkKTtcbiAgICBjYXNlIEluc3RydWN0aW9uQnVpbGRlclR5cGVzLk1lbW86XG4gICAgICByZXR1cm4gbWVtb0luc3RydWN0aW9uKGluc3RydWN0aW9uVG9CdWlsZCk7XG4gICAgY2FzZSBJbnN0cnVjdGlvbkJ1aWxkZXJUeXBlcy5UcmFuc2ZlcjpcbiAgICAgIHJldHVybiB0cmFuc2Zlckluc3RydWN0aW9uKGluc3RydWN0aW9uVG9CdWlsZCk7XG4gICAgY2FzZSBJbnN0cnVjdGlvbkJ1aWxkZXJUeXBlcy5Ub2tlblRyYW5zZmVyOlxuICAgICAgcmV0dXJuIHRva2VuVHJhbnNmZXJJbnN0cnVjdGlvbihpbnN0cnVjdGlvblRvQnVpbGQpO1xuICAgIGNhc2UgSW5zdHJ1Y3Rpb25CdWlsZGVyVHlwZXMuQ3JlYXRlTm9uY2VBY2NvdW50OlxuICAgICAgcmV0dXJuIGNyZWF0ZU5vbmNlQWNjb3VudEluc3RydWN0aW9uKGluc3RydWN0aW9uVG9CdWlsZCk7XG4gICAgY2FzZSBJbnN0cnVjdGlvbkJ1aWxkZXJUeXBlcy5TdGFraW5nQWN0aXZhdGU6XG4gICAgICByZXR1cm4gc3Rha2luZ0luaXRpYWxpemVJbnN0cnVjdGlvbihpbnN0cnVjdGlvblRvQnVpbGQpO1xuICAgIGNhc2UgSW5zdHJ1Y3Rpb25CdWlsZGVyVHlwZXMuU3Rha2luZ0RlYWN0aXZhdGU6XG4gICAgICByZXR1cm4gc3Rha2luZ0RlYWN0aXZhdGVJbnN0cnVjdGlvbihpbnN0cnVjdGlvblRvQnVpbGQpO1xuICAgIGNhc2UgSW5zdHJ1Y3Rpb25CdWlsZGVyVHlwZXMuU3Rha2luZ1dpdGhkcmF3OlxuICAgICAgcmV0dXJuIHN0YWtpbmdXaXRoZHJhd0luc3RydWN0aW9uKGluc3RydWN0aW9uVG9CdWlsZCk7XG4gICAgY2FzZSBJbnN0cnVjdGlvbkJ1aWxkZXJUeXBlcy5DcmVhdGVBc3NvY2lhdGVkVG9rZW5BY2NvdW50OlxuICAgICAgcmV0dXJuIGNyZWF0ZUFUQUluc3RydWN0aW9uKGluc3RydWN0aW9uVG9CdWlsZCk7XG4gICAgY2FzZSBJbnN0cnVjdGlvbkJ1aWxkZXJUeXBlcy5TdGFraW5nQXV0aG9yaXplOlxuICAgICAgcmV0dXJuIHN0YWtpbmdBdXRob3JpemVJbnN0cnVjdGlvbihpbnN0cnVjdGlvblRvQnVpbGQpO1xuICAgIGNhc2UgSW5zdHJ1Y3Rpb25CdWlsZGVyVHlwZXMuU3Rha2luZ0RlbGVnYXRlOlxuICAgICAgcmV0dXJuIHN0YWtpbmdEZWxlZ2F0ZUluc3RydWN0aW9uKGluc3RydWN0aW9uVG9CdWlsZCk7XG4gICAgZGVmYXVsdDpcbiAgICAgIHRocm93IG5ldyBFcnJvcihgSW52YWxpZCBpbnN0cnVjdGlvbiB0eXBlIG9yIG5vdCBzdXBwb3J0ZWRgKTtcbiAgfVxufVxuXG4vKipcbiAqIENvbnN0cnVjdCBBZHZhbmNlIE5vbmNlIFNvbGFuYSBpbnN0cnVjdGlvbnNcbiAqXG4gKiBAcGFyYW0ge05vbmNlfSBkYXRhIC0gdGhlIGRhdGEgdG8gYnVpbGQgdGhlIGluc3RydWN0aW9uXG4gKiBAcmV0dXJucyB7VHJhbnNhY3Rpb25JbnN0cnVjdGlvbltdfSBBbiBhcnJheSBjb250YWluaW5nIEFkdmFuY2UgTm9uY2UgU29sYW5hIGluc3RydWN0aW9uXG4gKi9cbmZ1bmN0aW9uIGFkdmFuY2VOb25jZUluc3RydWN0aW9uKGRhdGE6IE5vbmNlKTogVHJhbnNhY3Rpb25JbnN0cnVjdGlvbltdIHtcbiAgY29uc3Qge1xuICAgIHBhcmFtczogeyBhdXRoV2FsbGV0QWRkcmVzcywgd2FsbGV0Tm9uY2VBZGRyZXNzIH0sXG4gIH0gPSBkYXRhO1xuICBhc3NlcnQoYXV0aFdhbGxldEFkZHJlc3MsICdNaXNzaW5nIGF1dGhXYWxsZXRBZGRyZXNzIHBhcmFtJyk7XG4gIGFzc2VydCh3YWxsZXROb25jZUFkZHJlc3MsICdNaXNzaW5nIHdhbGxldE5vbmNlQWRkcmVzcyBwYXJhbScpO1xuICBjb25zdCBub25jZUluc3RydWN0aW9uID0gU3lzdGVtUHJvZ3JhbS5ub25jZUFkdmFuY2Uoe1xuICAgIG5vbmNlUHVia2V5OiBuZXcgUHVibGljS2V5KHdhbGxldE5vbmNlQWRkcmVzcyksXG4gICAgYXV0aG9yaXplZFB1YmtleTogbmV3IFB1YmxpY0tleShhdXRoV2FsbGV0QWRkcmVzcyksXG4gIH0pO1xuICByZXR1cm4gW25vbmNlSW5zdHJ1Y3Rpb25dO1xufVxuXG4vKipcbiAqIENvbnN0cnVjdCBNZW1vIFNvbGFuYSBpbnN0cnVjdGlvbnNcbiAqXG4gKiBAcGFyYW0ge01lbW99IGRhdGEgLSB0aGUgZGF0YSB0byBidWlsZCB0aGUgaW5zdHJ1Y3Rpb25cbiAqIEByZXR1cm5zIHtUcmFuc2FjdGlvbkluc3RydWN0aW9uW119IEFuIGFycmF5IGNvbnRhaW5pbmcgTWVtbyBTb2xhbmEgaW5zdHJ1Y3Rpb25cbiAqL1xuZnVuY3Rpb24gbWVtb0luc3RydWN0aW9uKGRhdGE6IE1lbW8pOiBUcmFuc2FjdGlvbkluc3RydWN0aW9uW10ge1xuICBjb25zdCB7XG4gICAgcGFyYW1zOiB7IG1lbW8gfSxcbiAgfSA9IGRhdGE7XG4gIGFzc2VydChtZW1vLCAnTWlzc2luZyBtZW1vIHBhcmFtJyk7XG4gIGNvbnN0IG1lbW9JbnN0cnVjdGlvbiA9IG5ldyBUcmFuc2FjdGlvbkluc3RydWN0aW9uKHtcbiAgICBrZXlzOiBbXSxcbiAgICBwcm9ncmFtSWQ6IG5ldyBQdWJsaWNLZXkoTUVNT19QUk9HUkFNX1BLKSxcbiAgICBkYXRhOiBCdWZmZXIuZnJvbShtZW1vKSxcbiAgfSk7XG4gIHJldHVybiBbbWVtb0luc3RydWN0aW9uXTtcbn1cblxuLyoqXG4gKiBDb25zdHJ1Y3QgVHJhbnNmZXIgU29sYW5hIGluc3RydWN0aW9uc1xuICpcbiAqIEBwYXJhbSB7VHJhbnNmZXJ9IGRhdGEgLSB0aGUgZGF0YSB0byBidWlsZCB0aGUgaW5zdHJ1Y3Rpb25cbiAqIEByZXR1cm5zIHtUcmFuc2FjdGlvbkluc3RydWN0aW9uW119IEFuIGFycmF5IGNvbnRhaW5pbmcgVHJhbnNmZXIgU29sYW5hIGluc3RydWN0aW9uXG4gKi9cbmZ1bmN0aW9uIHRyYW5zZmVySW5zdHJ1Y3Rpb24oZGF0YTogVHJhbnNmZXIpOiBUcmFuc2FjdGlvbkluc3RydWN0aW9uW10ge1xuICBjb25zdCB7XG4gICAgcGFyYW1zOiB7IGZyb21BZGRyZXNzLCB0b0FkZHJlc3MsIGFtb3VudCB9LFxuICB9ID0gZGF0YTtcbiAgYXNzZXJ0KGZyb21BZGRyZXNzLCAnTWlzc2luZyBmcm9tQWRkcmVzcyBwYXJhbScpO1xuICBhc3NlcnQodG9BZGRyZXNzLCAnTWlzc2luZyB0b0FkZHJlc3MgcGFyYW0nKTtcbiAgYXNzZXJ0KGFtb3VudCwgJ01pc3NpbmcgdG9BZGRyZXNzIHBhcmFtJyk7XG4gIGNvbnN0IHRyYW5zZmVySW5zdHJ1Y3Rpb24gPSBTeXN0ZW1Qcm9ncmFtLnRyYW5zZmVyKHtcbiAgICBmcm9tUHVia2V5OiBuZXcgUHVibGljS2V5KGZyb21BZGRyZXNzKSxcbiAgICB0b1B1YmtleTogbmV3IFB1YmxpY0tleSh0b0FkZHJlc3MpLFxuICAgIGxhbXBvcnRzOiBwYXJzZUludChhbW91bnQsIDEwKSxcbiAgfSk7XG4gIHJldHVybiBbdHJhbnNmZXJJbnN0cnVjdGlvbl07XG59XG5cbi8qKlxuICogQ29uc3RydWN0IFRyYW5zZmVyIFNvbGFuYSBpbnN0cnVjdGlvbnNcbiAqXG4gKiBAcGFyYW0ge1RyYW5zZmVyfSBkYXRhIC0gdGhlIGRhdGEgdG8gYnVpbGQgdGhlIGluc3RydWN0aW9uXG4gKiBAcmV0dXJucyB7VHJhbnNhY3Rpb25JbnN0cnVjdGlvbltdfSBBbiBhcnJheSBjb250YWluaW5nIFRyYW5zZmVyIFNvbGFuYSBpbnN0cnVjdGlvblxuICovXG5mdW5jdGlvbiB0b2tlblRyYW5zZmVySW5zdHJ1Y3Rpb24oZGF0YTogVG9rZW5UcmFuc2Zlcik6IFRyYW5zYWN0aW9uSW5zdHJ1Y3Rpb25bXSB7XG4gIGNvbnN0IHtcbiAgICBwYXJhbXM6IHsgZnJvbUFkZHJlc3MsIHRvQWRkcmVzcywgYW1vdW50LCB0b2tlbk5hbWUsIHNvdXJjZUFkZHJlc3MgfSxcbiAgfSA9IGRhdGE7XG4gIGFzc2VydChmcm9tQWRkcmVzcywgJ01pc3NpbmcgZnJvbUFkZHJlc3MgKG93bmVyKSBwYXJhbScpO1xuICBhc3NlcnQodG9BZGRyZXNzLCAnTWlzc2luZyB0b0FkZHJlc3MgcGFyYW0nKTtcbiAgYXNzZXJ0KGFtb3VudCwgJ01pc3NpbmcgYW1vdW50IHBhcmFtJyk7XG4gIGFzc2VydCh0b2tlbk5hbWUsICdNaXNzaW5nIHRva2VuIG5hbWUnKTtcbiAgYXNzZXJ0KHNvdXJjZUFkZHJlc3MsICdNaXNzaW5nIGF0YSBhZGRyZXNzJyk7XG4gIGNvbnN0IHRva2VuID0gY29pbnMuZ2V0KGRhdGEucGFyYW1zLnRva2VuTmFtZSk7XG4gIGFzc2VydCh0b2tlbiBpbnN0YW5jZW9mIFNvbENvaW4pO1xuICBjb25zdCB0cmFuc2Zlckluc3RydWN0aW9uID0gY3JlYXRlVHJhbnNmZXJDaGVja2VkSW5zdHJ1Y3Rpb24oXG4gICAgbmV3IFB1YmxpY0tleShzb3VyY2VBZGRyZXNzKSxcbiAgICBuZXcgUHVibGljS2V5KHRva2VuLnRva2VuQWRkcmVzcyksXG4gICAgbmV3IFB1YmxpY0tleSh0b0FkZHJlc3MpLFxuICAgIG5ldyBQdWJsaWNLZXkoZnJvbUFkZHJlc3MpLFxuICAgIEJpZ0ludChhbW91bnQpLFxuICAgIHRva2VuLmRlY2ltYWxQbGFjZXNcbiAgKTtcbiAgcmV0dXJuIFt0cmFuc2Zlckluc3RydWN0aW9uXTtcbn1cblxuLyoqXG4gKiBDb25zdHJ1Y3QgQ3JlYXRlIGFuZCBJbml0aWFsaXplIE5vbmNlIFNvbGFuYSBpbnN0cnVjdGlvbnNcbiAqXG4gKiBAcGFyYW0ge1dhbGxldEluaXR9IGRhdGEgLSB0aGUgZGF0YSB0byBidWlsZCB0aGUgaW5zdHJ1Y3Rpb25cbiAqIEByZXR1cm5zIHtUcmFuc2FjdGlvbkluc3RydWN0aW9uW119IEFuIGFycmF5IGNvbnRhaW5pbmcgQ3JlYXRlIGFuZCBJbml0aWFsaXplIE5vbmNlIFNvbGFuYSBpbnN0cnVjdGlvblxuICovXG5mdW5jdGlvbiBjcmVhdGVOb25jZUFjY291bnRJbnN0cnVjdGlvbihkYXRhOiBXYWxsZXRJbml0KTogVHJhbnNhY3Rpb25JbnN0cnVjdGlvbltdIHtcbiAgY29uc3Qge1xuICAgIHBhcmFtczogeyBmcm9tQWRkcmVzcywgbm9uY2VBZGRyZXNzLCBhdXRoQWRkcmVzcywgYW1vdW50IH0sXG4gIH0gPSBkYXRhO1xuICBhc3NlcnQoZnJvbUFkZHJlc3MsICdNaXNzaW5nIGZyb21BZGRyZXNzIHBhcmFtJyk7XG4gIGFzc2VydChub25jZUFkZHJlc3MsICdNaXNzaW5nIG5vbmNlQWRkcmVzcyBwYXJhbScpO1xuICBhc3NlcnQoYXV0aEFkZHJlc3MsICdNaXNzaW5nIGF1dGhBZGRyZXNzIHBhcmFtJyk7XG4gIGFzc2VydChhbW91bnQsICdNaXNzaW5nIGFtb3VudCBwYXJhbScpO1xuICBjb25zdCBub25jZUFjY291bnRJbnN0cnVjdGlvbiA9IFN5c3RlbVByb2dyYW0uY3JlYXRlTm9uY2VBY2NvdW50KHtcbiAgICBmcm9tUHVia2V5OiBuZXcgUHVibGljS2V5KGZyb21BZGRyZXNzKSxcbiAgICBub25jZVB1YmtleTogbmV3IFB1YmxpY0tleShub25jZUFkZHJlc3MpLFxuICAgIGF1dGhvcml6ZWRQdWJrZXk6IG5ldyBQdWJsaWNLZXkoYXV0aEFkZHJlc3MpLFxuICAgIGxhbXBvcnRzOiBuZXcgQmlnTnVtYmVyKGFtb3VudCkudG9OdW1iZXIoKSxcbiAgfSk7XG4gIHJldHVybiBub25jZUFjY291bnRJbnN0cnVjdGlvbi5pbnN0cnVjdGlvbnM7XG59XG5cbi8qKlxuICogQ29uc3RydWN0IENyZWF0ZSBTdGFraW5nIEFjY291bnQgYW5kIERlbGVnYXRlIFNvbGFuYSBpbnN0cnVjdGlvbnNcbiAqXG4gKiBAcGFyYW0ge1N0YWtpbmdBY3RpdmF0ZX0gZGF0YSAtIHRoZSBkYXRhIHRvIGJ1aWxkIHRoZSBpbnN0cnVjdGlvblxuICogQHJldHVybnMge1RyYW5zYWN0aW9uSW5zdHJ1Y3Rpb25bXX0gQW4gYXJyYXkgY29udGFpbmluZyBDcmVhdGUgU3Rha2luZyBBY2NvdW50IGFuZCBEZWxlZ2F0ZSBTb2xhbmEgaW5zdHJ1Y3Rpb25zXG4gKi9cbmZ1bmN0aW9uIHN0YWtpbmdJbml0aWFsaXplSW5zdHJ1Y3Rpb24oZGF0YTogU3Rha2luZ0FjdGl2YXRlKTogVHJhbnNhY3Rpb25JbnN0cnVjdGlvbltdIHtcbiAgY29uc3Qge1xuICAgIHBhcmFtczogeyBmcm9tQWRkcmVzcywgc3Rha2luZ0FkZHJlc3MsIGFtb3VudCwgdmFsaWRhdG9yIH0sXG4gIH0gPSBkYXRhO1xuICBhc3NlcnQoZnJvbUFkZHJlc3MsICdNaXNzaW5nIGZyb21BZGRyZXNzIHBhcmFtJyk7XG4gIGFzc2VydChzdGFraW5nQWRkcmVzcywgJ01pc3Npbmcgc3Rha2luZ0FkZHJlc3MgcGFyYW0nKTtcbiAgYXNzZXJ0KGFtb3VudCwgJ01pc3NpbmcgYW1vdW50IHBhcmFtJyk7XG4gIGFzc2VydCh2YWxpZGF0b3IsICdNaXNzaW5nIHZhbGlkYXRvciBwYXJhbScpO1xuXG4gIGNvbnN0IGZyb21QdWJrZXkgPSBuZXcgUHVibGljS2V5KGZyb21BZGRyZXNzKTtcbiAgY29uc3Qgc3Rha2VQdWJrZXkgPSBuZXcgUHVibGljS2V5KHN0YWtpbmdBZGRyZXNzKTtcblxuICBjb25zdCB0eCA9IG5ldyBUcmFuc2FjdGlvbigpO1xuXG4gIGNvbnN0IHdhbGxldEluaXRTdGFraW5nID0gU3Rha2VQcm9ncmFtLmNyZWF0ZUFjY291bnQoe1xuICAgIGZyb21QdWJrZXksXG4gICAgc3Rha2VQdWJrZXksXG4gICAgYXV0aG9yaXplZDogbmV3IEF1dGhvcml6ZWQoZnJvbVB1YmtleSwgZnJvbVB1YmtleSksIC8vIHN0YWtlciBhbmQgd2l0aGRyYXdlclxuICAgIGxvY2t1cDogbmV3IExvY2t1cCgwLCAwLCBmcm9tUHVia2V5KSwgLy8gTG9va3VwIHNldHMgdGhlIG1pbmltdW0gZXBvY2ggdG8gd2l0aGRyYXcsIGJ5IGRlZmF1bHQgaXMgMCwwIHdoaWNoIG1lYW5zIHRoZXJlJ3Mgbm8gbWluaW11bSBsaW1pdFxuICAgIGxhbXBvcnRzOiBuZXcgQmlnTnVtYmVyKGFtb3VudCkudG9OdW1iZXIoKSxcbiAgfSk7XG4gIHR4LmFkZCh3YWxsZXRJbml0U3Rha2luZyk7XG5cbiAgY29uc3QgZGVsZWdhdGVTdGFraW5nID0gU3Rha2VQcm9ncmFtLmRlbGVnYXRlKHtcbiAgICBzdGFrZVB1YmtleTogbmV3IFB1YmxpY0tleShzdGFraW5nQWRkcmVzcyksXG4gICAgYXV0aG9yaXplZFB1YmtleTogbmV3IFB1YmxpY0tleShmcm9tQWRkcmVzcyksXG4gICAgdm90ZVB1YmtleTogbmV3IFB1YmxpY0tleSh2YWxpZGF0b3IpLFxuICB9KTtcbiAgdHguYWRkKGRlbGVnYXRlU3Rha2luZyk7XG5cbiAgcmV0dXJuIHR4Lmluc3RydWN0aW9ucztcbn1cblxuLyoqXG4gKiBDb25zdHJ1Y3Qgc3Rha2luZyBkZWFjdGl2YXRlIFNvbGFuYSBpbnN0cnVjdGlvbnNcbiAqXG4gKiBAcGFyYW0ge1N0YWtpbmdEZWFjdGl2YXRlfSBkYXRhIC0gdGhlIGRhdGEgdG8gYnVpbGQgdGhlIGluc3RydWN0aW9uXG4gKiBAcmV0dXJucyB7VHJhbnNhY3Rpb25JbnN0cnVjdGlvbltdfSBBbiBhcnJheSBjb250YWluaW5nIHN0YWtpbmcgZGVhY3RpdmF0ZSBpbnN0cnVjdGlvblxuICovXG5mdW5jdGlvbiBzdGFraW5nRGVhY3RpdmF0ZUluc3RydWN0aW9uKGRhdGE6IFN0YWtpbmdEZWFjdGl2YXRlKTogVHJhbnNhY3Rpb25JbnN0cnVjdGlvbltdIHtcbiAgY29uc3Qge1xuICAgIHBhcmFtczogeyBmcm9tQWRkcmVzcywgc3Rha2luZ0FkZHJlc3MgfSxcbiAgfSA9IGRhdGE7XG4gIGFzc2VydChmcm9tQWRkcmVzcywgJ01pc3NpbmcgZnJvbUFkZHJlc3MgcGFyYW0nKTtcbiAgYXNzZXJ0KHN0YWtpbmdBZGRyZXNzLCAnTWlzc2luZyBzdGFraW5nQWRkcmVzcyBwYXJhbScpO1xuXG4gIGlmIChkYXRhLnBhcmFtcy5hbW91bnQgJiYgZGF0YS5wYXJhbXMudW5zdGFraW5nQWRkcmVzcykge1xuICAgIGNvbnN0IHR4ID0gbmV3IFRyYW5zYWN0aW9uKCk7XG5cbiAgICBjb25zdCB1bnN0YWtpbmdBZGRyZXNzID0gbmV3IFB1YmxpY0tleShkYXRhLnBhcmFtcy51bnN0YWtpbmdBZGRyZXNzKTtcbiAgICBjb25zdCBhbGxvY2F0ZUFjY291bnQgPSBTeXN0ZW1Qcm9ncmFtLmFsbG9jYXRlKHtcbiAgICAgIGFjY291bnRQdWJrZXk6IHVuc3Rha2luZ0FkZHJlc3MsXG4gICAgICBzcGFjZTogU3Rha2VQcm9ncmFtLnNwYWNlLFxuICAgIH0pO1xuICAgIHR4LmFkZChhbGxvY2F0ZUFjY291bnQpO1xuXG4gICAgY29uc3QgYXNzaWduQWNjb3VudCA9IFN5c3RlbVByb2dyYW0uYXNzaWduKHtcbiAgICAgIGFjY291bnRQdWJrZXk6IHVuc3Rha2luZ0FkZHJlc3MsXG4gICAgICBwcm9ncmFtSWQ6IFN0YWtlUHJvZ3JhbS5wcm9ncmFtSWQsXG4gICAgfSk7XG4gICAgdHguYWRkKGFzc2lnbkFjY291bnQpO1xuXG4gICAgY29uc3Qgc3BsaXRTdGFrZSA9IFN0YWtlUHJvZ3JhbS5zcGxpdCh7XG4gICAgICBzdGFrZVB1YmtleTogbmV3IFB1YmxpY0tleShzdGFraW5nQWRkcmVzcyksXG4gICAgICBhdXRob3JpemVkUHVia2V5OiBuZXcgUHVibGljS2V5KGZyb21BZGRyZXNzKSxcbiAgICAgIHNwbGl0U3Rha2VQdWJrZXk6IHVuc3Rha2luZ0FkZHJlc3MsXG4gICAgICBsYW1wb3J0czogbmV3IEJpZ051bWJlcihkYXRhLnBhcmFtcy5hbW91bnQpLnRvTnVtYmVyKCksXG4gICAgfSk7XG4gICAgdHguYWRkKHNwbGl0U3Rha2UuaW5zdHJ1Y3Rpb25zWzFdKTtcblxuICAgIGNvbnN0IGRlYWN0aXZhdGVTdGFraW5nID0gU3Rha2VQcm9ncmFtLmRlYWN0aXZhdGUoe1xuICAgICAgc3Rha2VQdWJrZXk6IHVuc3Rha2luZ0FkZHJlc3MsXG4gICAgICBhdXRob3JpemVkUHVia2V5OiBuZXcgUHVibGljS2V5KGZyb21BZGRyZXNzKSxcbiAgICB9KTtcbiAgICB0eC5hZGQoZGVhY3RpdmF0ZVN0YWtpbmcpO1xuXG4gICAgcmV0dXJuIHR4Lmluc3RydWN0aW9ucztcbiAgfSBlbHNlIHtcbiAgICBjb25zdCBkZWFjdGl2YXRlU3Rha2luZyA9IFN0YWtlUHJvZ3JhbS5kZWFjdGl2YXRlKHtcbiAgICAgIHN0YWtlUHVia2V5OiBuZXcgUHVibGljS2V5KHN0YWtpbmdBZGRyZXNzKSxcbiAgICAgIGF1dGhvcml6ZWRQdWJrZXk6IG5ldyBQdWJsaWNLZXkoZnJvbUFkZHJlc3MpLFxuICAgIH0pO1xuXG4gICAgcmV0dXJuIGRlYWN0aXZhdGVTdGFraW5nLmluc3RydWN0aW9ucztcbiAgfVxufVxuXG4vKipcbiAqIENvbnN0cnVjdCBTdGFraW5nIFdpdGhkcmF3IFNvbGFuYSBpbnN0cnVjdGlvbnNcbiAqXG4gKiBAcGFyYW0ge1N0YWtpbmdXaXRoZHJhd30gZGF0YSAtIHRoZSBkYXRhIHRvIGJ1aWxkIHRoZSBpbnN0cnVjdGlvblxuICogQHJldHVybnMge1RyYW5zYWN0aW9uSW5zdHJ1Y3Rpb25bXX0gQW4gYXJyYXkgY29udGFpbmluZyBTdGFraW5nIFdpdGhkcmF3ICBTb2xhbmEgaW5zdHJ1Y3Rpb25zXG4gKi9cbmZ1bmN0aW9uIHN0YWtpbmdXaXRoZHJhd0luc3RydWN0aW9uKGRhdGE6IFN0YWtpbmdXaXRoZHJhdyk6IFRyYW5zYWN0aW9uSW5zdHJ1Y3Rpb25bXSB7XG4gIGNvbnN0IHtcbiAgICBwYXJhbXM6IHsgZnJvbUFkZHJlc3MsIHN0YWtpbmdBZGRyZXNzLCBhbW91bnQgfSxcbiAgfSA9IGRhdGE7XG4gIGFzc2VydChmcm9tQWRkcmVzcywgJ01pc3NpbmcgZnJvbUFkZHJlc3MgcGFyYW0nKTtcbiAgYXNzZXJ0KHN0YWtpbmdBZGRyZXNzLCAnTWlzc2luZyBzdGFraW5nQWRkcmVzcyBwYXJhbScpO1xuICBhc3NlcnQoYW1vdW50LCAnTWlzc2luZyBhbW91bnQgcGFyYW0nKTtcblxuICBjb25zdCB3aXRoZHJhd1N0YWtpbmcgPSBTdGFrZVByb2dyYW0ud2l0aGRyYXcoe1xuICAgIHN0YWtlUHVia2V5OiBuZXcgUHVibGljS2V5KHN0YWtpbmdBZGRyZXNzKSxcbiAgICBhdXRob3JpemVkUHVia2V5OiBuZXcgUHVibGljS2V5KGZyb21BZGRyZXNzKSxcbiAgICB0b1B1YmtleTogbmV3IFB1YmxpY0tleShmcm9tQWRkcmVzcyksXG4gICAgbGFtcG9ydHM6IG5ldyBCaWdOdW1iZXIoYW1vdW50KS50b051bWJlcigpLFxuICB9KTtcblxuICByZXR1cm4gd2l0aGRyYXdTdGFraW5nLmluc3RydWN0aW9ucztcbn1cblxuLyoqXG4gKiBDb25zdHJ1Y3QgQ3JlYXRlIGFuZCBJbml0aWFsaXplIE5vbmNlIFNvbGFuYSBpbnN0cnVjdGlvbnNcbiAqXG4gKiBAcGFyYW0ge1dhbGxldEluaXR9IGRhdGEgLSB0aGUgZGF0YSB0byBidWlsZCB0aGUgaW5zdHJ1Y3Rpb25cbiAqIEByZXR1cm5zIHtUcmFuc2FjdGlvbkluc3RydWN0aW9uW119IEFuIGFycmF5IGNvbnRhaW5pbmcgQ3JlYXRlIGFuZCBJbml0aWFsaXplIE5vbmNlIFNvbGFuYSBpbnN0cnVjdGlvblxuICovXG5mdW5jdGlvbiBjcmVhdGVBVEFJbnN0cnVjdGlvbihkYXRhOiBBdGFJbml0KTogVHJhbnNhY3Rpb25JbnN0cnVjdGlvbltdIHtcbiAgY29uc3Qge1xuICAgIHBhcmFtczogeyBtaW50QWRkcmVzcywgYXRhQWRkcmVzcywgb3duZXJBZGRyZXNzLCBwYXllckFkZHJlc3MgfSxcbiAgfSA9IGRhdGE7XG4gIGFzc2VydChtaW50QWRkcmVzcywgJ01pc3NpbmcgbWludEFkZHJlc3MgcGFyYW0nKTtcbiAgYXNzZXJ0KGF0YUFkZHJlc3MsICdNaXNzaW5nIGF0YUFkZHJlc3MgcGFyYW0nKTtcbiAgYXNzZXJ0KG93bmVyQWRkcmVzcywgJ01pc3Npbmcgb3duZXJBZGRyZXNzIHBhcmFtJyk7XG4gIGFzc2VydChwYXllckFkZHJlc3MsICdNaXNzaW5nIHBheWVyQWRkcmVzcyBwYXJhbScpO1xuXG4gIGNvbnN0IGFzc29jaWF0ZWRUb2tlbkFjY291bnRJbnN0cnVjdGlvbiA9IGNyZWF0ZUFzc29jaWF0ZWRUb2tlbkFjY291bnRJbnN0cnVjdGlvbihcbiAgICBuZXcgUHVibGljS2V5KHBheWVyQWRkcmVzcyksXG4gICAgbmV3IFB1YmxpY0tleShhdGFBZGRyZXNzKSxcbiAgICBuZXcgUHVibGljS2V5KG93bmVyQWRkcmVzcyksXG4gICAgbmV3IFB1YmxpY0tleShtaW50QWRkcmVzcylcbiAgKTtcbiAgcmV0dXJuIFthc3NvY2lhdGVkVG9rZW5BY2NvdW50SW5zdHJ1Y3Rpb25dO1xufVxuXG4vKipcbiAqIENvbnN0cnVjdCBTdGFraW5nIEFjY291bnQgQXV0aG9yaXplIFNvbGFuYSBpbnN0cnVjdGlvbnNcbiAqXG4gKiBAcGFyYW0ge1N0YWtpbmdBdXRob3JpemV9IGRhdGEgLSB0aGUgZGF0YSB0byBidWlsZCB0aGUgaW5zdHJ1Y3Rpb25cbiAqIEByZXR1cm5zIHtUcmFuc2FjdGlvbkluc3RydWN0aW9uW119IEFuIGFycmF5IGNvbnRhaW5pbmcgU3Rha2luZyBBY2NvdW50IEF1dGhvcml6ZSBpbnN0cnVjdGlvbnNcbiAqL1xuZnVuY3Rpb24gc3Rha2luZ0F1dGhvcml6ZUluc3RydWN0aW9uKGRhdGE6IFN0YWtpbmdBdXRob3JpemUpOiBUcmFuc2FjdGlvbkluc3RydWN0aW9uW10ge1xuICBjb25zdCB7XG4gICAgcGFyYW1zOiB7IHN0YWtpbmdBZGRyZXNzLCBvbGRBdXRob3JpemVBZGRyZXNzLCBuZXdBdXRob3JpemVBZGRyZXNzLCBuZXdXaXRoZHJhd0FkZHJlc3MgfSxcbiAgfSA9IGRhdGE7XG4gIGFzc2VydChzdGFraW5nQWRkcmVzcywgJ01pc3Npbmcgc3Rha2luZ0FkZHJlc3MgcGFyYW0nKTtcbiAgYXNzZXJ0KG9sZEF1dGhvcml6ZUFkZHJlc3MsICdNaXNzaW5nIG9sZEF1dGhvcml6ZUFkZHJlc3MgcGFyYW0nKTtcbiAgYXNzZXJ0KG5ld0F1dGhvcml6ZUFkZHJlc3MsICdNaXNzaW5nIG5ld0F1dGhvcml6ZUFkZHJlc3MgcGFyYW0nKTtcbiAgYXNzZXJ0KG5ld1dpdGhkcmF3QWRkcmVzcywgJ01pc3NpbmcgbmV3V2l0aGRyYXdBZGRyZXNzIHBhcmFtJyk7XG5cbiAgY29uc3QgdHggPSBuZXcgVHJhbnNhY3Rpb24oKTtcblxuICBjb25zdCBhdXRob3JpemVTdGFraW5nID0gU3Rha2VQcm9ncmFtLmF1dGhvcml6ZSh7XG4gICAgc3Rha2VQdWJrZXk6IG5ldyBQdWJsaWNLZXkoc3Rha2luZ0FkZHJlc3MpLFxuICAgIGF1dGhvcml6ZWRQdWJrZXk6IG5ldyBQdWJsaWNLZXkob2xkQXV0aG9yaXplQWRkcmVzcyksXG4gICAgbmV3QXV0aG9yaXplZFB1YmtleTogbmV3IFB1YmxpY0tleShuZXdBdXRob3JpemVBZGRyZXNzKSxcbiAgICBzdGFrZUF1dGhvcml6YXRpb25UeXBlOiBTdGFrZUF1dGhvcml6YXRpb25MYXlvdXQuU3Rha2VyLFxuICB9KTtcblxuICBjb25zdCBhdXRob3JpemVXaXRoZHJhdyA9IFN0YWtlUHJvZ3JhbS5hdXRob3JpemUoe1xuICAgIHN0YWtlUHVia2V5OiBuZXcgUHVibGljS2V5KHN0YWtpbmdBZGRyZXNzKSxcbiAgICBhdXRob3JpemVkUHVia2V5OiBuZXcgUHVibGljS2V5KG9sZEF1dGhvcml6ZUFkZHJlc3MpLFxuICAgIG5ld0F1dGhvcml6ZWRQdWJrZXk6IG5ldyBQdWJsaWNLZXkobmV3QXV0aG9yaXplQWRkcmVzcyksXG4gICAgc3Rha2VBdXRob3JpemF0aW9uVHlwZTogU3Rha2VBdXRob3JpemF0aW9uTGF5b3V0LldpdGhkcmF3ZXIsXG4gICAgY3VzdG9kaWFuUHVia2V5OiBuZXcgUHVibGljS2V5KG5ld1dpdGhkcmF3QWRkcmVzcyksXG4gIH0pO1xuICB0eC5hZGQoYXV0aG9yaXplU3Rha2luZyk7XG4gIHR4LmFkZChhdXRob3JpemVXaXRoZHJhdyk7XG5cbiAgcmV0dXJuIHR4Lmluc3RydWN0aW9ucztcbn1cblxuLyoqXG4gKiBDb25zdHJ1Y3QgRGVsZWdhdGUgU29sYW5hIGluc3RydWN0aW9uc1xuICpcbiAqIEBwYXJhbSB7U3Rha2luZ0FjdGl2YXRlfSBkYXRhIC0gdGhlIGRhdGEgdG8gYnVpbGQgdGhlIGluc3RydWN0aW9uXG4gKiBAcmV0dXJucyB7VHJhbnNhY3Rpb25JbnN0cnVjdGlvbltdfSBBbiBhcnJheSBjb250YWluaW5nIERlbGVnYXRlIFNvbGFuYSBpbnN0cnVjdGlvbnNcbiAqL1xuZnVuY3Rpb24gc3Rha2luZ0RlbGVnYXRlSW5zdHJ1Y3Rpb24oZGF0YTogU3Rha2luZ0RlbGVnYXRlKTogVHJhbnNhY3Rpb25JbnN0cnVjdGlvbltdIHtcbiAgY29uc3Qge1xuICAgIHBhcmFtczogeyBmcm9tQWRkcmVzcywgc3Rha2luZ0FkZHJlc3MsIHZhbGlkYXRvciB9LFxuICB9ID0gZGF0YTtcbiAgYXNzZXJ0KGZyb21BZGRyZXNzLCAnTWlzc2luZyBmcm9tQWRkcmVzcyBwYXJhbScpO1xuICBhc3NlcnQoc3Rha2luZ0FkZHJlc3MsICdNaXNzaW5nIHN0YWtpbmdBZGRyZXNzIHBhcmFtJyk7XG4gIGFzc2VydCh2YWxpZGF0b3IsICdNaXNzaW5nIHZhbGlkYXRvciBwYXJhbScpO1xuICBjb25zdCB0eCA9IG5ldyBUcmFuc2FjdGlvbigpO1xuICBjb25zdCBkZWxlZ2F0ZVN0YWtpbmcgPSBTdGFrZVByb2dyYW0uZGVsZWdhdGUoe1xuICAgIHN0YWtlUHVia2V5OiBuZXcgUHVibGljS2V5KHN0YWtpbmdBZGRyZXNzKSxcbiAgICBhdXRob3JpemVkUHVia2V5OiBuZXcgUHVibGljS2V5KGZyb21BZGRyZXNzKSxcbiAgICB2b3RlUHVia2V5OiBuZXcgUHVibGljS2V5KHZhbGlkYXRvciksXG4gIH0pO1xuICB0eC5hZGQoZGVsZWdhdGVTdGFraW5nKTtcblxuICByZXR1cm4gdHguaW5zdHJ1Y3Rpb25zO1xufVxuIl19
451
+ /**
452
+ * Construct MintTo Solana instructions
453
+ *
454
+ * @param {MintTo} data - the data to build the instruction
455
+ * @returns {TransactionInstruction[]} An array containing MintTo Solana instructions
456
+ */
457
+ function mintToInstruction(data) {
458
+ const { params: { mintAddress, destinationAddress, authorityAddress, amount, programId }, } = data;
459
+ (0, assert_1.default)(mintAddress, 'Missing mintAddress param');
460
+ (0, assert_1.default)(destinationAddress, 'Missing destinationAddress param');
461
+ (0, assert_1.default)(authorityAddress, 'Missing authorityAddress param');
462
+ (0, assert_1.default)(amount, 'Missing amount param');
463
+ const mint = new web3_js_1.PublicKey(mintAddress);
464
+ const destination = new web3_js_1.PublicKey(destinationAddress);
465
+ const authority = new web3_js_1.PublicKey(authorityAddress);
466
+ let mintToInstr;
467
+ if (programId && programId === spl_token_1.TOKEN_2022_PROGRAM_ID.toString()) {
468
+ mintToInstr = (0, spl_token_1.createMintToInstruction)(mint, destination, authority, BigInt(amount), [], spl_token_1.TOKEN_2022_PROGRAM_ID);
469
+ }
470
+ else {
471
+ mintToInstr = (0, spl_token_1.createMintToInstruction)(mint, destination, authority, BigInt(amount));
472
+ }
473
+ return [mintToInstr];
474
+ }
475
+ /**
476
+ * Construct Burn Solana instructions
477
+ *
478
+ * @param {Burn} data - the data to build the instruction
479
+ * @returns {TransactionInstruction[]} An array containing Burn Solana instructions
480
+ */
481
+ function burnInstruction(data) {
482
+ const { params: { mintAddress, accountAddress, authorityAddress, amount, programId }, } = data;
483
+ (0, assert_1.default)(mintAddress, 'Missing mintAddress param');
484
+ (0, assert_1.default)(accountAddress, 'Missing accountAddress param');
485
+ (0, assert_1.default)(authorityAddress, 'Missing authorityAddress param');
486
+ (0, assert_1.default)(amount, 'Missing amount param');
487
+ const mint = new web3_js_1.PublicKey(mintAddress);
488
+ const account = new web3_js_1.PublicKey(accountAddress);
489
+ const authority = new web3_js_1.PublicKey(authorityAddress);
490
+ let burnInstr;
491
+ if (programId && programId === spl_token_1.TOKEN_2022_PROGRAM_ID.toString()) {
492
+ burnInstr = (0, spl_token_1.createBurnInstruction)(account, mint, authority, BigInt(amount), [], spl_token_1.TOKEN_2022_PROGRAM_ID);
493
+ }
494
+ else {
495
+ burnInstr = (0, spl_token_1.createBurnInstruction)(account, mint, authority, BigInt(amount));
496
+ }
497
+ return [burnInstr];
498
+ }
499
+ /**
500
+ * Process custom instruction - converts to TransactionInstruction
501
+ * Handles conversion from string-based format to TransactionInstruction format
502
+ *
503
+ * @param {CustomInstruction} data - the data containing the custom instruction
504
+ * @returns {TransactionInstruction[]} An array containing the custom instruction
505
+ */
506
+ function customInstruction(data) {
507
+ const { params } = data;
508
+ (0, assert_1.default)(params.programId, 'Missing programId in custom instruction');
509
+ (0, assert_1.default)(params.keys && Array.isArray(params.keys), 'Missing or invalid keys in custom instruction');
510
+ (0, assert_1.default)(params.data !== undefined, 'Missing data in custom instruction');
511
+ // Convert string data to Buffer
512
+ let dataBuffer;
513
+ if ((0, utils_1.isValidBase64)(params.data)) {
514
+ dataBuffer = Buffer.from(params.data, 'base64');
515
+ }
516
+ else if ((0, utils_1.isValidHex)(params.data)) {
517
+ dataBuffer = Buffer.from(params.data, 'hex');
518
+ }
519
+ else {
520
+ // Fallback to UTF-8
521
+ dataBuffer = Buffer.from(params.data, 'utf8');
522
+ }
523
+ // Create a new TransactionInstruction with the converted data
524
+ const convertedInstruction = new web3_js_1.TransactionInstruction({
525
+ programId: new web3_js_1.PublicKey(params.programId),
526
+ keys: params.keys.map((key) => ({
527
+ pubkey: new web3_js_1.PublicKey(key.pubkey),
528
+ isSigner: key.isSigner,
529
+ isWritable: key.isWritable,
530
+ })),
531
+ data: dataBuffer,
532
+ });
533
+ return [convertedInstruction];
534
+ }
535
+ function upsertAccountMeta(keys, meta) {
536
+ const existing = keys.find((account) => account.pubkey.equals(meta.pubkey));
537
+ if (existing) {
538
+ existing.isWritable = existing.isWritable || meta.isWritable;
539
+ existing.isSigner = existing.isSigner || meta.isSigner;
540
+ }
541
+ else {
542
+ keys.push(meta);
543
+ }
544
+ }
545
+ function buildStaticTransferHookAccounts(transferHook) {
546
+ const metas = [];
547
+ if (transferHook.extraAccountMetas?.length) {
548
+ for (const meta of transferHook.extraAccountMetas) {
549
+ metas.push({
550
+ pubkey: new web3_js_1.PublicKey(meta.pubkey),
551
+ isSigner: meta.isSigner,
552
+ isWritable: meta.isWritable,
553
+ });
554
+ }
555
+ }
556
+ return metas;
557
+ }
558
+ function addTransferHookAccounts(instruction, transferHook) {
559
+ const extraMetas = buildStaticTransferHookAccounts(transferHook);
560
+ for (const meta of extraMetas) {
561
+ upsertAccountMeta(instruction.keys, meta);
562
+ }
563
+ }
564
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic29sSW5zdHJ1Y3Rpb25GYWN0b3J5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2xpYi9zb2xJbnN0cnVjdGlvbkZhY3RvcnkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUF3REEsc0RBdUNDO0FBL0ZELHNEQUF5RDtBQUN6RCxpREFBOEM7QUFDOUMsaURBUTJCO0FBQzNCLDZDQVd5QjtBQUN6QixvREFBNEI7QUFDNUIsZ0VBQXFDO0FBQ3JDLDJDQUF1RTtBQXFCdkUsbUNBQThFO0FBQzlFLHVFQUE4RjtBQUM5Rix1REFBMkU7QUFFM0U7Ozs7O0dBS0c7QUFDSCxTQUFnQixxQkFBcUIsQ0FBQyxrQkFBcUM7SUFDekUsUUFBUSxrQkFBa0IsQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUNoQyxLQUFLLG1DQUF1QixDQUFDLFlBQVk7WUFDdkMsT0FBTyx1QkFBdUIsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO1FBQ3JELEtBQUssbUNBQXVCLENBQUMsSUFBSTtZQUMvQixPQUFPLGVBQWUsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO1FBQzdDLEtBQUssbUNBQXVCLENBQUMsUUFBUTtZQUNuQyxPQUFPLG1CQUFtQixDQUFDLGtCQUFrQixDQUFDLENBQUM7UUFDakQsS0FBSyxtQ0FBdUIsQ0FBQyxhQUFhO1lBQ3hDLE9BQU8sd0JBQXdCLENBQUMsa0JBQWtCLENBQUMsQ0FBQztRQUN0RCxLQUFLLG1DQUF1QixDQUFDLE9BQU87WUFDbEMsT0FBTyxrQkFBa0IsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO1FBQ2hELEtBQUssbUNBQXVCLENBQUMsa0JBQWtCO1lBQzdDLE9BQU8sNkJBQTZCLENBQUMsa0JBQWtCLENBQUMsQ0FBQztRQUMzRCxLQUFLLG1DQUF1QixDQUFDLGVBQWU7WUFDMUMsT0FBTyw0QkFBNEIsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO1FBQzFELEtBQUssbUNBQXVCLENBQUMsaUJBQWlCO1lBQzVDLE9BQU8sNEJBQTRCLENB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WSxDQUFDLGlCQUFpQixFQUFFLE1BQU0sRUFBRSxDQUFDO1FBQzNDLEtBQUssTUFBTSxJQUFJLElBQUksWUFBWSxDQUFDLGlCQUFpQixFQUFFLENBQUM7WUFDbEQsS0FBSyxDQUFDLElBQUksQ0FBQztnQkFDVCxNQUFNLEVBQUUsSUFBSSxtQkFBUyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUM7Z0JBQ2xDLFFBQVEsRUFBRSxJQUFJLENBQUMsUUFBUTtnQkFDdkIsVUFBVSxFQUFFLElBQUksQ0FBQyxVQUFVO2FBQzVCLENBQUMsQ0FBQztRQUNMLENBQUM7SUFDSCxDQUFDO0lBQ0QsT0FBTyxLQUFLLENBQUM7QUFDZixDQUFDO0FBRUQsU0FBUyx1QkFBdUIsQ0FBQyxXQUFtQyxFQUFFLFlBQWdDO0lBQ3BHLE1BQU0sVUFBVSxHQUFHLCtCQUErQixDQUFDLFlBQVksQ0FBQyxDQUFDO0lBQ2pFLEtBQUssTUFBTSxJQUFJLElBQUksVUFBVSxFQUFFLENBQUM7UUFDOUIsaUJBQWlCLENBQUMsV0FBVyxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsQ0FBQztJQUM1QyxDQUFDO0FBQ0gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNvbFN0YWtpbmdUeXBlRW51bSB9IGZyb20gJ0BiaXRnby9wdWJsaWMtdHlwZXMnO1xuaW1wb3J0IHsgU29sQ29pbiB9IGZyb20gJ0BiaXRnby1iZXRhL3N0YXRpY3MnO1xuaW1wb3J0IHtcbiAgY3JlYXRlQXNzb2NpYXRlZFRva2VuQWNjb3VudEluc3RydWN0aW9uLFxuICBjcmVhdGVDbG9zZUFjY291bnRJbnN0cnVjdGlvbixcbiAgY3JlYXRlTWludFRvSW5zdHJ1Y3Rpb24sXG4gIGNyZWF0ZUJ1cm5JbnN0cnVjdGlvbixcbiAgY3JlYXRlVHJhbnNmZXJDaGVja2VkSW5zdHJ1Y3Rpb24sXG4gIFRPS0VOXzIwMjJfUFJPR1JBTV9JRCxcbiAgY3JlYXRlQXBwcm92ZUluc3RydWN0aW9uLFxufSBmcm9tICdAc29sYW5hL3NwbC10b2tlbic7XG5pbXBvcnQge1xuICBBY2NvdW50TWV0YSxcbiAgQXV0aG9yaXplZCxcbiAgTG9ja3VwLFxuICBQdWJsaWNLZXksXG4gIFN0YWtlQXV0aG9yaXphdGlvbkxheW91dCxcbiAgU3Rha2VQcm9ncmFtLFxuICBTeXN0ZW1Qcm9ncmFtLFxuICBUcmFuc2FjdGlvbixcbiAgVHJhbnNhY3Rpb25JbnN0cnVjdGlvbixcbiAgQ29tcHV0ZUJ1ZGdldFByb2dyYW0sXG59IGZyb20gJ0Bzb2xhbmEvd2ViMy5qcyc7XG5pbXBvcnQgYXNzZXJ0IGZyb20gJ2Fzc2VydCc7XG5pbXBvcnQgQmlnTnVtYmVyIGZyb20gJ2JpZ251bWJlci5qcyc7XG5pbXBvcnQgeyBJbnN0cnVjdGlvbkJ1aWxkZXJUeXBlcywgTUVNT19QUk9HUkFNX1BLIH0gZnJvbSAnLi9jb25zdGFudHMnO1xuaW1wb3J0IHtcbiAgQXRhQ2xvc2UsXG4gIEF0YUluaXQsXG4gIEluc3RydWN0aW9uUGFyYW1zLFxuICBNZW1vLFxuICBNaW50VG8sXG4gIEJ1cm4sXG4gIE5vbmNlLFxuICBTdGFraW5nQWN0aXZhdGUsXG4gIFN0YWtpbmdBdXRob3JpemUsXG4gIFN0YWtpbmdEZWFjdGl2YXRlLFxuICBTdGFraW5nRGVsZWdhdGUsXG4gIFN0YWtpbmdXaXRoZHJhdyxcbiAgVG9rZW5UcmFuc2ZlcixcbiAgVHJhbnNmZXIsXG4gIFdhbGxldEluaXQsXG4gIFNldFByaW9yaXR5RmVlLFxuICBDdXN0b21JbnN0cnVjdGlvbixcbiAgQXBwcm92ZSxcbn0gZnJvbSAnLi9pZmFjZSc7XG5pbXBvcnQgeyBnZXRTb2xUb2tlbkZyb21Ub2tlbk5hbWUsIGlzVmFsaWRCYXNlNjQsIGlzVmFsaWRIZXggfSBmcm9tICcuL3V0aWxzJztcbmltcG9ydCB7IGRlcG9zaXRTb2xJbnN0cnVjdGlvbnMsIHdpdGhkcmF3U3Rha2VJbnN0cnVjdGlvbnMgfSBmcm9tICcuL2ppdG9TdGFrZVBvb2xPcGVyYXRpb25zJztcbmltcG9ydCB7IGdldFRva2VuMjAyMkNvbmZpZywgVHJhbnNmZXJIb29rQ29uZmlnIH0gZnJvbSAnLi90b2tlbjIwMjJDb25maWcnO1xuXG4vKipcbiAqIENvbnN0cnVjdCBTb2xhbmEgaW5zdHJ1Y3Rpb25zIGZyb20gaW5zdHJ1Y3Rpb25zIHBhcmFtc1xuICpcbiAqIEBwYXJhbSB7SW5zdHJ1Y3Rpb25QYXJhbXN9IGluc3RydWN0aW9uVG9CdWlsZCAtIHRoZSBkYXRhIGNvbnRhaW5pbmcgdGhlIGluc3RydWN0aW9uIHBhcmFtc1xuICogQHJldHVybnMge1RyYW5zYWN0aW9uSW5zdHJ1Y3Rpb25bXX0gQW4gYXJyYXkgY29udGFpbmluZyBzdXBwb3J0ZWQgU29sYW5hIGluc3RydWN0aW9uc1xuICovXG5leHBvcnQgZnVuY3Rpb24gc29sSW5zdHJ1Y3Rpb25GYWN0b3J5KGluc3RydWN0aW9uVG9CdWlsZDogSW5zdHJ1Y3Rpb25QYXJhbXMpOiBUcmFuc2FjdGlvbkluc3RydWN0aW9uW10ge1xuICBzd2l0Y2ggKGluc3RydWN0aW9uVG9CdWlsZC50eXBlKSB7XG4gICAgY2FzZSBJbnN0cnVjdGlvbkJ1aWxkZXJUeXBlcy5Ob25jZUFkdmFuY2U6XG4gICAgICByZXR1cm4gYWR2YW5jZU5vbmNlSW5zdHJ1Y3Rpb24oaW5zdHJ1Y3Rpb25Ub0J1aWxkKTtcbiAgICBjYXNlIEluc3RydWN0aW9uQnVpbGRlclR5cGVzLk1lbW86XG4gICAgICByZXR1cm4gbWVtb0luc3RydWN0aW9uKGluc3RydWN0aW9uVG9CdWlsZCk7XG4gICAgY2FzZSBJbnN0cnVjdGlvbkJ1aWxkZXJUeXBlcy5UcmFuc2ZlcjpcbiAgICAgIHJldHVybiB0cmFuc2Zlckluc3RydWN0aW9uKGluc3RydWN0aW9uVG9CdWlsZCk7XG4gICAgY2FzZSBJbnN0cnVjdGlvbkJ1aWxkZXJUeXBlcy5Ub2tlblRyYW5zZmVyOlxuICAgICAgcmV0dXJuIHRva2VuVHJhbnNmZXJJbnN0cnVjdGlvbihpbnN0cnVjdGlvblRvQnVpbGQpO1xuICAgIGNhc2UgSW5zdHJ1Y3Rpb25CdWlsZGVyVHlwZXMuQXBwcm92ZTpcbiAgICAgIHJldHVybiBhcHByb3ZlSW5zdHJ1Y3Rpb24oaW5zdHJ1Y3Rpb25Ub0J1aWxkKTtcbiAgICBjYXNlIEluc3RydWN0aW9uQnVpbGRlclR5cGVzLkNyZWF0ZU5vbmNlQWNjb3VudDpcbiAgICAgIHJldHVybiBjcmVhdGVOb25jZUFjY291bnRJbnN0cnVjdGlvbihpbnN0cnVjdGlvblRvQnVpbGQpO1xuICAgIGNhc2UgSW5zdHJ1Y3Rpb25CdWlsZGVyVHlwZXMuU3Rha2luZ0FjdGl2YXRlOlxuICAgICAgcmV0dXJuIHN0YWtpbmdJbml0aWFsaXplSW5zdHJ1Y3Rpb24oaW5zdHJ1Y3Rpb25Ub0J1aWxkKTtcbiAgICBjYXNlIEluc3RydWN0aW9uQnVpbGRlclR5cGVzLlN0YWtpbmdEZWFjdGl2YXRlOlxuICAgICAgcmV0dXJuIHN0YWtpbmdEZWFjdGl2YXRlSW5zdHJ1Y3Rpb24oaW5zdHJ1Y3Rpb25Ub0J1aWxkKTtcbiAgICBjYXNlIEluc3RydWN0aW9uQnVpbGRlclR5cGVzLlN0YWtpbmdXaXRoZHJhdzpcbiAgICAgIHJldHVybiBzdGFraW5nV2l0aGRyYXdJbnN0cnVjdGlvbihpbnN0cnVjdGlvblRvQnVpbGQpO1xuICAgIGNhc2UgSW5zdHJ1Y3Rpb25CdWlsZGVyVHlwZXMuQ3JlYXRlQXNzb2NpYXRlZFRva2VuQWNjb3VudDpcbiAgICAgIHJldHVybiBjcmVhdGVBVEFJbnN0cnVjdGlvbihpbnN0cnVjdGlvblRvQnVpbGQpO1xuICAgIGNhc2UgSW5zdHJ1Y3Rpb25CdWlsZGVyVHlwZXMuQ2xvc2VBc3NvY2lhdGVkVG9rZW5BY2NvdW50OlxuICAgICAgcmV0dXJuIGNsb3NlQVRBSW5zdHJ1Y3Rpb24oaW5zdHJ1Y3Rpb25Ub0J1aWxkKTtcbiAgICBjYXNlIEluc3RydWN0aW9uQnVpbGRlclR5cGVzLlN0YWtpbmdBdXRob3JpemU6XG4gICAgICByZXR1cm4gc3Rha2luZ0F1dGhvcml6ZUluc3RydWN0aW9uKGluc3RydWN0aW9uVG9CdWlsZCk7XG4gICAgY2FzZSBJbnN0cnVjdGlvbkJ1aWxkZXJUeXBlcy5TdGFraW5nRGVsZWdhdGU6XG4gICAgICByZXR1cm4gc3Rha2luZ0RlbGVnYXRlSW5zdHJ1Y3Rpb24oaW5zdHJ1Y3Rpb25Ub0J1aWxkKTtcbiAgICBjYXNlIEluc3RydWN0aW9uQnVpbGRlclR5cGVzLlNldFByaW9yaXR5RmVlOlxuICAgICAgcmV0dXJuIGZldGNoUHJpb3JpdHlGZWVJbnN0cnVjdGlvbihpbnN0cnVjdGlvblRvQnVpbGQpO1xuICAgIGNhc2UgSW5zdHJ1Y3Rpb25CdWlsZGVyVHlwZXMuTWludFRvOlxuICAgICAgcmV0dXJuIG1pbnRUb0luc3RydWN0aW9uKGluc3RydWN0aW9uVG9CdWlsZCk7XG4gICAgY2FzZSBJbnN0cnVjdGlvbkJ1aWxkZXJUeXBlcy5CdXJuOlxuICAgICAgcmV0dXJuIGJ1cm5JbnN0cnVjdGlvbihpbnN0cnVjdGlvblRvQnVpbGQpO1xuICAgIGNhc2UgSW5zdHJ1Y3Rpb25CdWlsZGVyVHlwZXMuQ3VzdG9tSW5zdHJ1Y3Rpb246XG4gICAgICByZXR1cm4gY3VzdG9tSW5zdHJ1Y3Rpb24oaW5zdHJ1Y3Rpb25Ub0J1aWxkKTtcbiAgICBkZWZhdWx0OlxuICAgICAgdGhyb3cgbmV3IEVycm9yKGBJbnZhbGlkIGluc3RydWN0aW9uIHR5cGUgb3Igbm90IHN1cHBvcnRlZGApO1xuICB9XG59XG5cbi8qKlxuICogQ29uc3RydWN0IEFkdmFuY2UgTm9uY2UgU29sYW5hIGluc3RydWN0aW9uc1xuICpcbiAqIEBwYXJhbSB7Tm9uY2V9IGRhdGEgLSB0aGUgZGF0YSB0byBidWlsZCB0aGUgaW5zdHJ1Y3Rpb25cbiAqIEByZXR1cm5zIHtUcmFuc2FjdGlvbkluc3RydWN0aW9uW119IEFuIGFycmF5IGNvbnRhaW5pbmcgQWR2YW5jZSBOb25jZSBTb2xhbmEgaW5zdHJ1Y3Rpb25cbiAqL1xuZnVuY3Rpb24gYWR2YW5jZU5vbmNlSW5zdHJ1Y3Rpb24oZGF0YTogTm9uY2UpOiBUcmFuc2FjdGlvbkluc3RydWN0aW9uW10ge1xuICBjb25zdCB7XG4gICAgcGFyYW1zOiB7IGF1dGhXYWxsZXRBZGRyZXNzLCB3YWxsZXROb25jZUFkZHJlc3MgfSxcbiAgfSA9IGRhdGE7XG4gIGFzc2VydChhdXRoV2FsbGV0QWRkcmVzcywgJ01pc3NpbmcgYXV0aFdhbGxldEFkZHJlc3MgcGFyYW0nKTtcbiAgYXNzZXJ0KHdhbGxldE5vbmNlQWRkcmVzcywgJ01pc3Npbmcgd2FsbGV0Tm9uY2VBZGRyZXNzIHBhcmFtJyk7XG4gIGNvbnN0IG5vbmNlSW5zdHJ1Y3Rpb24gPSBTeXN0ZW1Qcm9ncmFtLm5vbmNlQWR2YW5jZSh7XG4gICAgbm9uY2VQdWJrZXk6IG5ldyBQdWJsaWNLZXkod2FsbGV0Tm9uY2VBZGRyZXNzKSxcbiAgICBhdXRob3JpemVkUHVia2V5OiBuZXcgUHVibGljS2V5KGF1dGhXYWxsZXRBZGRyZXNzKSxcbiAgfSk7XG4gIHJldHVybiBbbm9uY2VJbnN0cnVjdGlvbl07XG59XG5cbmZ1bmN0aW9uIGZldGNoUHJpb3JpdHlGZWVJbnN0cnVjdGlvbihpbnN0cnVjdGlvblRvQnVpbGQ6IFNldFByaW9yaXR5RmVlKTogVHJhbnNhY3Rpb25JbnN0cnVjdGlvbltdIHtcbiAgY29uc3QgYWRkUHJpb3JpdHlGZWUgPSBDb21wdXRlQnVkZ2V0UHJvZ3JhbS5zZXRDb21wdXRlVW5pdFByaWNlKHtcbiAgICBtaWNyb0xhbXBvcnRzOiBpbnN0cnVjdGlvblRvQnVpbGQucGFyYW1zLmZlZSxcbiAgfSk7XG5cbiAgcmV0dXJuIFthZGRQcmlvcml0eUZlZV07XG59XG5cbi8qKlxuICogQ29uc3RydWN0IE1lbW8gU29sYW5hIGluc3RydWN0aW9uc1xuICpcbiAqIEBwYXJhbSB7TWVtb30gZGF0YSAtIHRoZSBkYXRhIHRvIGJ1aWxkIHRoZSBpbnN0cnVjdGlvblxuICogQHJldHVybnMge1RyYW5zYWN0aW9uSW5zdHJ1Y3Rpb25bXX0gQW4gYXJyYXkgY29udGFpbmluZyBNZW1vIFNvbGFuYSBpbnN0cnVjdGlvblxuICovXG5mdW5jdGlvbiBtZW1vSW5zdHJ1Y3Rpb24oZGF0YTogTWVtbyk6IFRyYW5zYWN0aW9uSW5zdHJ1Y3Rpb25bXSB7XG4gIGNvbnN0IHtcbiAgICBwYXJhbXM6IHsgbWVtbyB9LFxuICB9ID0gZGF0YTtcbiAgYXNzZXJ0KG1lbW8sICdNaXNzaW5nIG1lbW8gcGFyYW0nKTtcbiAgY29uc3QgbWVtb0luc3RydWN0aW9uID0gbmV3IFRyYW5zYWN0aW9uSW5zdHJ1Y3Rpb24oe1xuICAgIGtleXM6IFtdLFxuICAgIHByb2dyYW1JZDogbmV3IFB1YmxpY0tleShNRU1PX1BST0dSQU1fUEspLFxuICAgIGRhdGE6IEJ1ZmZlci5mcm9tKG1lbW8pLFxuICB9KTtcbiAgcmV0dXJuIFttZW1vSW5zdHJ1Y3Rpb25dO1xufVxuXG4vKipcbiAqIENvbnN0cnVjdCBUcmFuc2ZlciBTb2xhbmEgaW5zdHJ1Y3Rpb25zXG4gKlxuICogQHBhcmFtIHtUcmFuc2Zlcn0gZGF0YSAtIHRoZSBkYXRhIHRvIGJ1aWxkIHRoZSBpbnN0cnVjdGlvblxuICogQHJldHVybnMge1RyYW5zYWN0aW9uSW5zdHJ1Y3Rpb25bXX0gQW4gYXJyYXkgY29udGFpbmluZyBUcmFuc2ZlciBTb2xhbmEgaW5zdHJ1Y3Rpb25cbiAqL1xuZnVuY3Rpb24gdHJhbnNmZXJJbnN0cnVjdGlvbihkYXRhOiBUcmFuc2Zlcik6IFRyYW5zYWN0aW9uSW5zdHJ1Y3Rpb25bXSB7XG4gIGNvbnN0IHtcbiAgICBwYXJhbXM6IHsgZnJvbUFkZHJlc3MsIHRvQWRkcmVzcywgYW1vdW50IH0sXG4gIH0gPSBkYXRhO1xuICBhc3NlcnQoZnJvbUFkZHJlc3MsICdNaXNzaW5nIGZyb21BZGRyZXNzIHBhcmFtJyk7XG4gIGFzc2VydCh0b0FkZHJlc3MsICdNaXNzaW5nIHRvQWRkcmVzcyBwYXJhbScpO1xuICBhc3NlcnQoYW1vdW50LCAnTWlzc2luZyB0b0FkZHJlc3MgcGFyYW0nKTtcbiAgY29uc3QgdHJhbnNmZXJJbnN0cnVjdGlvbiA9IFN5c3RlbVByb2dyYW0udHJhbnNmZXIoe1xuICAgIGZyb21QdWJrZXk6IG5ldyBQdWJsaWNLZXkoZnJvbUFkZHJlc3MpLFxuICAgIHRvUHVia2V5OiBuZXcgUHVibGljS2V5KHRvQWRkcmVzcyksXG4gICAgbGFtcG9ydHM6IHBhcnNlSW50KGFtb3VudCwgMTApLFxuICB9KTtcbiAgcmV0dXJuIFt0cmFuc2Zlckluc3RydWN0aW9uXTtcbn1cblxuLyoqXG4gKiBDb25zdHJ1Y3QgVHJhbnNmZXIgU29sYW5hIGluc3RydWN0aW9uc1xuICpcbiAqIEBwYXJhbSB7VHJhbnNmZXJ9IGRhdGEgLSB0aGUgZGF0YSB0byBidWlsZCB0aGUgaW5zdHJ1Y3Rpb25cbiAqIEByZXR1cm5zIHtUcmFuc2FjdGlvbkluc3RydWN0aW9uW119IEFuIGFycmF5IGNvbnRhaW5pbmcgVHJhbnNmZXIgU29sYW5hIGluc3RydWN0aW9uXG4gKi9cbmZ1bmN0aW9uIHRva2VuVHJhbnNmZXJJbnN0cnVjdGlvbihkYXRhOiBUb2tlblRyYW5zZmVyKTogVHJhbnNhY3Rpb25JbnN0cnVjdGlvbltdIHtcbiAgY29uc3Qge1xuICAgIHBhcmFtczogeyBmcm9tQWRkcmVzcywgdG9BZGRyZXNzLCBhbW91bnQsIHRva2VuTmFtZSwgc291cmNlQWRkcmVzcyB9LFxuICB9ID0gZGF0YTtcbiAgYXNzZXJ0KGZyb21BZGRyZXNzLCAnTWlzc2luZyBmcm9tQWRkcmVzcyAob3duZXIpIHBhcmFtJyk7XG4gIGFzc2VydCh0b0FkZHJlc3MsICdNaXNzaW5nIHRvQWRkcmVzcyBwYXJhbScpO1xuICBhc3NlcnQoYW1vdW50LCAnTWlzc2luZyBhbW91bnQgcGFyYW0nKTtcbiAgYXNzZXJ0KHRva2VuTmFtZSwgJ01pc3NpbmcgdG9rZW4gbmFtZScpO1xuICBhc3NlcnQoc291cmNlQWRkcmVzcywgJ01pc3NpbmcgYXRhIGFkZHJlc3MnKTtcbiAgY29uc3QgdG9rZW4gPSBnZXRTb2xUb2tlbkZyb21Ub2tlbk5hbWUoZGF0YS5wYXJhbXMudG9rZW5OYW1lKTtcbiAgbGV0IHRva2VuQWRkcmVzczogc3RyaW5nO1xuICBsZXQgcHJvZ3JhbUlkOiBzdHJpbmcgfCB1bmRlZmluZWQ7XG4gIGxldCBkZWNpbWFsUGxhY2VzOiBudW1iZXI7XG4gIGlmIChkYXRhLnBhcmFtcy50b2tlbkFkZHJlc3MgJiYgZGF0YS5wYXJhbXMuZGVjaW1hbFBsYWNlcykge1xuICAgIHRva2VuQWRkcmVzcyA9IGRhdGEucGFyYW1zLnRva2VuQWRkcmVzcztcbiAgICBkZWNpbWFsUGxhY2VzID0gZGF0YS5wYXJhbXMuZGVjaW1hbFBsYWNlcztcbiAgICBwcm9ncmFtSWQgPSBkYXRhLnBhcmFtcy5wcm9ncmFtSWQ7XG4gIH0gZWxzZSBpZiAodG9rZW4pIHtcbiAgICBhc3NlcnQodG9rZW4gaW5zdGFuY2VvZiBTb2xDb2luKTtcbiAgICB0b2tlbkFkZHJlc3MgPSB0b2tlbi50b2tlbkFkZHJlc3M7XG4gICAgZGVjaW1hbFBsYWNlcyA9IHRva2VuLmRlY2ltYWxQbGFjZXM7XG4gICAgcHJvZ3JhbUlkID0gdG9rZW4ucHJvZ3JhbUlkO1xuICB9IGVsc2Uge1xuICAgIHRocm93IG5ldyBFcnJvcignSW52YWxpZCB0b2tlbiBuYW1lLCBnb3Q6JyArIGRhdGEucGFyYW1zLnRva2VuTmFtZSk7XG4gIH1cblxuICBsZXQgdHJhbnNmZXJJbnN0cnVjdGlvbjogVHJhbnNhY3Rpb25JbnN0cnVjdGlvbjtcbiAgY29uc3QgaW5zdHJ1Y3Rpb25zOiBUcmFuc2FjdGlvbkluc3RydWN0aW9uW10gPSBbXTtcblxuICBpZiAocHJvZ3JhbUlkID09PSBUT0tFTl8yMDIyX1BST0dSQU1fSUQudG9TdHJpbmcoKSkge1xuICAgIC8vIENyZWF0ZSB0aGUgYmFzZSB0cmFuc2ZlciBpbnN0cnVjdGlvblxuICAgIHRyYW5zZmVySW5zdHJ1Y3Rpb24gPSBjcmVhdGVUcmFuc2ZlckNoZWNrZWRJbnN0cnVjdGlvbihcbiAgICAgIG5ldyBQdWJsaWNLZXkoc291cmNlQWRkcmVzcyksXG4gICAgICBuZXcgUHVibGljS2V5KHRva2VuQWRkcmVzcyksXG4gICAgICBuZXcgUHVibGljS2V5KHRvQWRkcmVzcyksXG4gICAgICBuZXcgUHVibGljS2V5KGZyb21BZGRyZXNzKSxcbiAgICAgIEJpZ0ludChhbW91bnQpLFxuICAgICAgZGVjaW1hbFBsYWNlcyxcbiAgICAgIFtdLFxuICAgICAgVE9LRU5fMjAyMl9QUk9HUkFNX0lEXG4gICAgKTtcbiAgICAvLyBDaGVjayBpZiB0aGlzIHRva2VuIGhhcyBhIHRyYW5zZmVyIGhvb2sgY29uZmlndXJhdGlvblxuICAgIGNvbnN0IHRva2VuQ29uZmlnID0gZ2V0VG9rZW4yMDIyQ29uZmlnKHRva2VuQWRkcmVzcyk7XG4gICAgaWYgKHRva2VuQ29uZmlnPy50cmFuc2Zlckhvb2spIHtcbiAgICAgIGFkZFRyYW5zZmVySG9va0FjY291bnRzKHRyYW5zZmVySW5zdHJ1Y3Rpb24sIHRva2VuQ29uZmlnLnRyYW5zZmVySG9vayk7XG4gICAgfVxuICB9IGVsc2Uge1xuICAgIHRyYW5zZmVySW5zdHJ1Y3Rpb24gPSBjcmVhdGVUcmFuc2ZlckNoZWNrZWRJbnN0cnVjdGlvbihcbiAgICAgIG5ldyBQdWJsaWNLZXkoc291cmNlQWRkcmVzcyksXG4gICAgICBuZXcgUHVibGljS2V5KHRva2VuQWRkcmVzcyksXG4gICAgICBuZXcgUHVibGljS2V5KHRvQWRkcmVzcyksXG4gICAgICBuZXcgUHVibGljS2V5KGZyb21BZGRyZXNzKSxcbiAgICAgIEJpZ0ludChhbW91bnQpLFxuICAgICAgZGVjaW1hbFBsYWNlc1xuICAgICk7XG4gIH1cbiAgaW5zdHJ1Y3Rpb25zLnB1c2godHJhbnNmZXJJbnN0cnVjdGlvbik7XG4gIHJldHVybiBpbnN0cnVjdGlvbnM7XG59XG5cbi8qKlxuICogQ29uc3RydWN0IFRyYW5zZmVyIFNvbGFuYSBpbnN0cnVjdGlvbnNcbiAqXG4gKiBAcGFyYW0ge1RyYW5zZmVyfSBkYXRhIC0gdGhlIGRhdGEgdG8gYnVpbGQgdGhlIGluc3RydWN0aW9uXG4gKiBAcmV0dXJucyB7VHJhbnNhY3Rpb25JbnN0cnVjdGlvbltdfSBBbiBhcnJheSBjb250YWluaW5nIFRyYW5zZmVyIFNvbGFuYSBpbnN0cnVjdGlvblxuICovXG5mdW5jdGlvbiBhcHByb3ZlSW5zdHJ1Y3Rpb24oZGF0YTogQXBwcm92ZSk6IFRyYW5zYWN0aW9uSW5zdHJ1Y3Rpb25bXSB7XG4gIGNvbnN0IHtcbiAgICBwYXJhbXM6IHsgYWNjb3VudEFkZHJlc3MsIGRlbGVnYXRlQWRkcmVzcywgb3duZXJBZGRyZXNzLCBhbW91bnQsIHByb2dyYW1JZCB9LFxuICB9ID0gZGF0YTtcbiAgYXNzZXJ0KGFjY291bnRBZGRyZXNzLCAnTWlzc2luZyBmcm9tQWRkcmVzcyAob3duZXIpIHBhcmFtJyk7XG4gIGFzc2VydChkZWxlZ2F0ZUFkZHJlc3MsICdNaXNzaW5nIHRvQWRkcmVzcyBwYXJhbScpO1xuICBhc3NlcnQob3duZXJBZGRyZXNzLCAnTWlzc2luZyBvd25lckFkZHJlc3MgcGFyYW0nKTtcbiAgYXNzZXJ0KHByb2dyYW1JZCwgJ01pc3NpbmcgcHJvZ3JhbUlkIHBhcmFtJyk7XG4gIGFzc2VydChhbW91bnQsICdNaXNzaW5nIGFtb3VudCBwYXJhbScpO1xuICByZXR1cm4gW1xuICAgIGNyZWF0ZUFwcHJvdmVJbnN0cnVjdGlvbihcbiAgICAgIG5ldyBQdWJsaWNLZXkoYWNjb3VudEFkZHJlc3MpLFxuICAgICAgbmV3IFB1YmxpY0tleShkZWxlZ2F0ZUFkZHJlc3MpLFxuICAgICAgbmV3IFB1YmxpY0tleShvd25lckFkZHJlc3MpLFxuICAgICAgQmlnSW50KGFtb3VudCksXG4gICAgICB1bmRlZmluZWQsXG4gICAgICBwcm9ncmFtSWQgPT09IHVuZGVmaW5lZCA/IHVuZGVmaW5lZCA6IG5ldyBQdWJsaWNLZXkocHJvZ3JhbUlkKVxuICAgICksXG4gIF07XG59XG5cbi8qKlxuICogQ29uc3RydWN0IENyZWF0ZSBhbmQgSW5pdGlhbGl6ZSBOb25jZSBTb2xhbmEgaW5zdHJ1Y3Rpb25zXG4gKlxuICogQHBhcmFtIHtXYWxsZXRJbml0fSBkYXRhIC0gdGhlIGRhdGEgdG8gYnVpbGQgdGhlIGluc3RydWN0aW9uXG4gKiBAcmV0dXJucyB7VHJhbnNhY3Rpb25JbnN0cnVjdGlvbltdfSBBbiBhcnJheSBjb250YWluaW5nIENyZWF0ZSBhbmQgSW5pdGlhbGl6ZSBOb25jZSBTb2xhbmEgaW5zdHJ1Y3Rpb25cbiAqL1xuZnVuY3Rpb24gY3JlYXRlTm9uY2VBY2NvdW50SW5zdHJ1Y3Rpb24oZGF0YTogV2FsbGV0SW5pdCk6IFRyYW5zYWN0aW9uSW5zdHJ1Y3Rpb25bXSB7XG4gIGNvbnN0IHtcbiAgICBwYXJhbXM6IHsgZnJvbUFkZHJlc3MsIG5vbmNlQWRkcmVzcywgYXV0aEFkZHJlc3MsIGFtb3VudCB9LFxuICB9ID0gZGF0YTtcbiAgYXNzZXJ0KGZyb21BZGRyZXNzLCAnTWlzc2luZyBmcm9tQWRkcmVzcyBwYXJhbScpO1xuICBhc3NlcnQobm9uY2VBZGRyZXNzLCAnTWlzc2luZyBub25jZUFkZHJlc3MgcGFyYW0nKTtcbiAgYXNzZXJ0KGF1dGhBZGRyZXNzLCAnTWlzc2luZyBhdXRoQWRkcmVzcyBwYXJhbScpO1xuICBhc3NlcnQoYW1vdW50LCAnTWlzc2luZyBhbW91bnQgcGFyYW0nKTtcbiAgY29uc3Qgbm9uY2VBY2NvdW50SW5zdHJ1Y3Rpb24gPSBTeXN0ZW1Qcm9ncmFtLmNyZWF0ZU5vbmNlQWNjb3VudCh7XG4gICAgZnJvbVB1YmtleTogbmV3IFB1YmxpY0tleShmcm9tQWRkcmVzcyksXG4gICAgbm9uY2VQdWJrZXk6IG5ldyBQdWJsaWNLZXkobm9uY2VBZGRyZXNzKSxcbiAgICBhdXRob3JpemVkUHVia2V5OiBuZXcgUHVibGljS2V5KGF1dGhBZGRyZXNzKSxcbiAgICBsYW1wb3J0czogbmV3IEJpZ051bWJlcihhbW91bnQpLnRvTnVtYmVyKCksXG4gIH0pO1xuICByZXR1cm4gbm9uY2VBY2NvdW50SW5zdHJ1Y3Rpb24uaW5zdHJ1Y3Rpb25zO1xufVxuXG4vKipcbiAqIENvbnN0cnVjdCBDcmVhdGUgU3Rha2luZyBBY2NvdW50IGFuZCBEZWxlZ2F0ZSBTb2xhbmEgaW5zdHJ1Y3Rpb25zXG4gKlxuICogQHBhcmFtIHtTdGFraW5nQWN0aXZhdGV9IGRhdGEgLSB0aGUgZGF0YSB0byBidWlsZCB0aGUgaW5zdHJ1Y3Rpb25cbiAqIEByZXR1cm5zIHtUcmFuc2FjdGlvbkluc3RydWN0aW9uW119IEFuIGFycmF5IGNvbnRhaW5pbmcgQ3JlYXRlIFN0YWtpbmcgQWNjb3VudCBhbmQgRGVsZWdhdGUgU29sYW5hIGluc3RydWN0aW9uc1xuICovXG5mdW5jdGlvbiBzdGFraW5nSW5pdGlhbGl6ZUluc3RydWN0aW9uKGRhdGE6IFN0YWtpbmdBY3RpdmF0ZSk6IFRyYW5zYWN0aW9uSW5zdHJ1Y3Rpb25bXSB7XG4gIGNvbnN0IHtcbiAgICBwYXJhbXM6IHsgZnJvbUFkZHJlc3MsIHN0YWtpbmdBZGRyZXNzLCBhbW91bnQsIHZhbGlkYXRvciwgc3Rha2luZ1R5cGUsIGV4dHJhUGFyYW1zIH0sXG4gIH0gPSBkYXRhO1xuICBhc3NlcnQoZnJvbUFkZHJlc3MsICdNaXNzaW5nIGZyb21BZGRyZXNzIHBhcmFtJyk7XG4gIGFzc2VydChzdGFraW5nQWRkcmVzcywgJ01pc3Npbmcgc3Rha2luZ0FkZHJlc3MgcGFyYW0nKTtcbiAgYXNzZXJ0KGFtb3VudCwgJ01pc3NpbmcgYW1vdW50IHBhcmFtJyk7XG4gIGFzc2VydCh2YWxpZGF0b3IsICdNaXNzaW5nIHZhbGlkYXRvciBwYXJhbScpO1xuXG4gIGNvbnN0IGZyb21QdWJrZXkgPSBuZXcgUHVibGljS2V5KGZyb21BZGRyZXNzKTtcbiAgY29uc3Qgc3Rha2VQdWJrZXkgPSBuZXcgUHVibGljS2V5KHN0YWtpbmdBZGRyZXNzKTtcbiAgY29uc3QgdmFsaWRhdG9yUHVia2V5ID0gbmV3IFB1YmxpY0tleSh2YWxpZGF0b3IpO1xuICBjb25zdCB0eCA9IG5ldyBUcmFuc2FjdGlvbigpO1xuXG4gIHN3aXRjaCAoc3Rha2luZ1R5cGUpIHtcbiAgICBjYXNlIFNvbFN0YWtpbmdUeXBlRW51bS5KSVRPOiB7XG4gICAgICBhc3NlcnQoZXh0cmFQYXJhbXMgIT09IHVuZGVmaW5lZCwgJ01pc3NpbmcgZXh0cmFQYXJhbXMgcGFyYW0nKTtcbiAgICAgIGNvbnN0IGluc3RydWN0aW9ucyA9IGRlcG9zaXRTb2xJbnN0cnVjdGlvbnMoXG4gICAgICAgIHtcbiAgICAgICAgICBzdGFrZVBvb2xBZGRyZXNzOiBzdGFrZVB1YmtleSxcbiAgICAgICAgICBmcm9tOiBmcm9tUHVia2V5LFxuICAgICAgICAgIGxhbXBvcnRzOiBCaWdJbnQoYW1vdW50KSxcbiAgICAgICAgfSxcbiAgICAgICAgZXh0cmFQYXJhbXMuc3Rha2VQb29sRGF0YSxcbiAgICAgICAgISFleHRyYVBhcmFtcy5jcmVhdGVBc3NvY2lhdGVkVG9rZW5BY2NvdW50XG4gICAgICApO1xuICAgICAgdHguYWRkKC4uLmluc3RydWN0aW9ucyk7XG4gICAgICBicmVhaztcbiAgICB9XG5cbiAgICBjYXNlIFNvbFN0YWtpbmdUeXBlRW51bS5NQVJJTkFERToge1xuICAgICAgY29uc3Qgd2FsbGV0SW5pdFN0YWtpbmcgPSBTdGFrZVByb2dyYW0uY3JlYXRlQWNjb3VudCh7XG4gICAgICAgIGZyb21QdWJrZXksXG4gICAgICAgIHN0YWtlUHVia2V5LFxuICAgICAgICBhdXRob3JpemVkOiBuZXcgQXV0aG9yaXplZCh2YWxpZGF0b3JQdWJrZXksIGZyb21QdWJrZXkpLCAvLyBzdGFrZXIgYW5kIHdpdGhkcmF3ZXJcbiAgICAgICAgbG9ja3VwOiBuZXcgTG9ja3VwKDAsIDAsIGZyb21QdWJrZXkpLCAvLyBObyBtaW5pbXVtIGVwb2NoIHRvIHdpdGhkcmF3XG4gICAgICAgIGxhbXBvcnRzOiBuZXcgQmlnTnVtYmVyKGFtb3VudCkudG9OdW1iZXIoKSxcbiAgICAgIH0pO1xuICAgICAgdHguYWRkKHdhbGxldEluaXRTdGFraW5nKTtcbiAgICAgIGJyZWFrO1xuICAgIH1cblxuICAgIGNhc2UgU29sU3Rha2luZ1R5cGVFbnVtLk5BVElWRToge1xuICAgICAgY29uc3Qgd2FsbGV0SW5pdFN0YWtpbmcgPSBTdGFrZVByb2dyYW0uY3JlYXRlQWNjb3VudCh7XG4gICAgICAgIGZyb21QdWJrZXksXG4gICAgICAgIHN0YWtlUHVia2V5LFxuICAgICAgICBhdXRob3JpemVkOiBuZXcgQXV0aG9yaXplZChmcm9tUHVia2V5LCBmcm9tUHVia2V5KSwgLy8gc3Rha2VyIGFuZCB3aXRoZHJhd2VyXG4gICAgICAgIGxvY2t1cDogbmV3IExvY2t1cCgwLCAwLCBmcm9tUHVia2V5KSwgLy8gTm8gbWluaW11bSBlcG9jaCB0byB3aXRoZHJhd1xuICAgICAgICBsYW1wb3J0czogbmV3IEJpZ051bWJlcihhbW91bnQpLnRvTnVtYmVyKCksXG4gICAgICB9KTtcbiAgICAgIHR4LmFkZCh3YWxsZXRJbml0U3Rha2luZyk7XG5cbiAgICAgIGNvbnN0IGRlbGVnYXRlU3Rha2luZyA9IFN0YWtlUHJvZ3JhbS5kZWxlZ2F0ZSh7XG4gICAgICAgIHN0YWtlUHVia2V5OiBuZXcgUHVibGljS2V5KHN0YWtpbmdBZGRyZXNzKSxcbiAgICAgICAgYXV0aG9yaXplZFB1YmtleTogbmV3IFB1YmxpY0tleShmcm9tQWRkcmVzcyksXG4gICAgICAgIHZvdGVQdWJrZXk6IG5ldyBQdWJsaWNLZXkodmFsaWRhdG9yKSxcbiAgICAgIH0pO1xuICAgICAgdHguYWRkKGRlbGVnYXRlU3Rha2luZyk7XG4gICAgICBicmVhaztcbiAgICB9XG5cbiAgICBkZWZhdWx0OiB7XG4gICAgICBjb25zdCB1bnJlYWNoYWJsZTogbmV2ZXIgPSBzdGFraW5nVHlwZTtcbiAgICAgIHRocm93IG5ldyBFcnJvcihgVW5rbm93biBzdGFraW5nIHR5cGUgJHt1bnJlYWNoYWJsZX1gKTtcbiAgICB9XG4gIH1cblxuICByZXR1cm4gdHguaW5zdHJ1Y3Rpb25zO1xufVxuXG4vKipcbiAqIENvbnN0cnVjdCBzdGFraW5nIGRlYWN0aXZhdGUgU29sYW5hIGluc3RydWN0aW9uc1xuICpcbiAqIEBwYXJhbSB7U3Rha2luZ0RlYWN0aXZhdGV9IGRhdGEgLSB0aGUgZGF0YSB0byBidWlsZCB0aGUgaW5zdHJ1Y3Rpb25cbiAqIEByZXR1cm5zIHtUcmFuc2FjdGlvbkluc3RydWN0aW9uW119IEFuIGFycmF5IGNvbnRhaW5pbmcgc3Rha2luZyBkZWFjdGl2YXRlIGluc3RydWN0aW9uXG4gKi9cbmZ1bmN0aW9uIHN0YWtpbmdEZWFjdGl2YXRlSW5zdHJ1Y3Rpb24oZGF0YTogU3Rha2luZ0RlYWN0aXZhdGUpOiBUcmFuc2FjdGlvbkluc3RydWN0aW9uW10ge1xuICBjb25zdCB7XG4gICAgcGFyYW1zOiB7IGZyb21BZGRyZXNzLCBzdGFraW5nQWRkcmVzcywgYW1vdW50LCB1bnN0YWtpbmdBZGRyZXNzLCByZWNpcGllbnRzLCBzdGFraW5nVHlwZSwgZXh0cmFQYXJhbXMgfSxcbiAgfSA9IGRhdGE7XG4gIGFzc2VydChmcm9tQWRkcmVzcywgJ01pc3NpbmcgZnJvbUFkZHJlc3MgcGFyYW0nKTtcblxuICBzd2l0Y2ggKHN0YWtpbmdUeXBlKSB7XG4gICAgY2FzZSBTb2xTdGFraW5nVHlwZUVudW0uSklUTzoge1xuICAgICAgYXNzZXJ0KHN0YWtpbmdBZGRyZXNzLCAnTWlzc2luZyBzdGFraW5nQWRkcmVzcyBwYXJhbScpO1xuICAgICAgYXNzZXJ0KHVuc3Rha2luZ0FkZHJlc3MsICdNaXNzaW5nIHVuc3Rha2luZ0FkZHJlc3MgcGFyYW0nKTtcbiAgICAgIGFzc2VydChhbW91bnQsICdNaXNzaW5nIGFtb3VudCBwYXJhbScpO1xuICAgICAgYXNzZXJ0KGV4dHJhUGFyYW1zLCAnTWlzc2luZyBleHRyYVBhcmFtcyBwYXJhbScpO1xuXG4gICAgICBjb25zdCB0eCA9IG5ldyBUcmFuc2FjdGlvbigpO1xuICAgICAgdHguYWRkKFxuICAgICAgICAuLi53aXRoZHJhd1N0YWtlSW5zdHJ1Y3Rpb25zKFxuICAgICAgICAgIHtcbiAgICAgICAgICAgIHN0YWtlUG9vbEFkZHJlc3M6IG5ldyBQdWJsaWNLZXkoc3Rha2luZ0FkZHJlc3MpLFxuICAgICAgICAgICAgdG9rZW5Pd25lcjogbmV3IFB1YmxpY0tleShmcm9tQWRkcmVzcyksXG4gICAgICAgICAgICBkZXN0aW5hdGlvblN0YWtlQWNjb3VudDogbmV3IFB1YmxpY0tleSh1bnN0YWtpbmdBZGRyZXNzKSxcbiAgICAgICAgICAgIHZhbGlkYXRvckFkZHJlc3M6IG5ldyBQdWJsaWNLZXkoZXh0cmFQYXJhbXMudmFsaWRhdG9yQWRkcmVzcyksXG4gICAgICAgICAgICB0cmFuc2ZlckF1dGhvcml0eTogbmV3IFB1YmxpY0tleShleHRyYVBhcmFtcy50cmFuc2ZlckF1dGhvcml0eUFkZHJlc3MpLFxuICAgICAgICAgICAgcG9vbEFtb3VudDogYW1vdW50LFxuICAgICAgICAgIH0sXG4gICAgICAgICAgZXh0cmFQYXJhbXMuc3Rha2VQb29sRGF0YVxuICAgICAgICApXG4gICAgICApO1xuICAgICAgcmV0dXJuIHR4Lmluc3RydWN0aW9ucztcbiAgICB9XG5cbiAgICBjYXNlIFNvbFN0YWtpbmdUeXBlRW51bS5NQVJJTkFERToge1xuICAgICAgYXNzZXJ0KHJlY2lwaWVudHMsICdNaXNzaW5nIHJlY2lwaWVudHMgcGFyYW0nKTtcblxuICAgICAgY29uc3QgdHggPSBuZXcgVHJhbnNhY3Rpb24oKTtcbiAgICAgIGNvbnN0IHRvUHVia2V5QWRkcmVzcyA9IG5ldyBQdWJsaWNLZXkocmVjaXBpZW50c1swXS5hZGRyZXNzIHx8ICcnKTtcbiAgICAgIGNvbnN0IHRyYW5zZmVySW5zdHJ1Y3Rpb24gPSBTeXN0ZW1Qcm9ncmFtLnRyYW5zZmVyKHtcbiAgICAgICAgZnJvbVB1YmtleTogbmV3IFB1YmxpY0tleShmcm9tQWRkcmVzcyksXG4gICAgICAgIHRvUHVia2V5OiB0b1B1YmtleUFkZHJlc3MsXG4gICAgICAgIGxhbXBvcnRzOiBwYXJzZUludChyZWNpcGllbnRzWzBdLmFtb3VudCwgMTApLFxuICAgICAgfSk7XG5cbiAgICAgIHR4LmFkZCh0cmFuc2Zlckluc3RydWN0aW9uKTtcbiAgICAgIHJldHVybiB0eC5pbnN0cnVjdGlvbnM7XG4gICAgfVxuXG4gICAgY2FzZSBTb2xTdGFraW5nVHlwZUVudW0uTkFUSVZFOiB7XG4gICAgICBhc3NlcnQoc3Rha2luZ0FkZHJlc3MsICdNaXNzaW5nIHN0YWtpbmdBZGRyZXNzIHBhcmFtJyk7XG5cbiAgICAgIGlmIChkYXRhLnBhcmFtcy5hbW91bnQgJiYgZGF0YS5wYXJhbXMudW5zdGFraW5nQWRkcmVzcykge1xuICAgICAgICBjb25zdCB0eCA9IG5ldyBUcmFuc2FjdGlvbigpO1xuICAgICAgICBjb25zdCB1bnN0YWtpbmdBZGRyZXNzID0gbmV3IFB1YmxpY0tleShkYXRhLnBhcmFtcy51bnN0YWtpbmdBZGRyZXNzKTtcblxuICAgICAgICBjb25zdCBhbGxvY2F0ZUFjY291bnQgPSBTeXN0ZW1Qcm9ncmFtLmFsbG9jYXRlKHtcbiAgICAgICAgICBhY2NvdW50UHVia2V5OiB1bnN0YWtpbmdBZGRyZXNzLFxuICAgICAgICAgIHNwYWNlOiBTdGFrZVByb2dyYW0uc3BhY2UsXG4gICAgICAgIH0pO1xuICAgICAgICB0eC5hZGQoYWxsb2NhdGVBY2NvdW50KTtcblxuICAgICAgICBjb25zdCBhc3NpZ25BY2NvdW50ID0gU3lzdGVtUHJvZ3JhbS5hc3NpZ24oe1xuICAgICAgICAgIGFjY291bnRQdWJrZXk6IHVuc3Rha2luZ0FkZHJlc3MsXG4gICAgICAgICAgcHJvZ3JhbUlkOiBTdGFrZVByb2dyYW0ucHJvZ3JhbUlkLFxuICAgICAgICB9KTtcbiAgICAgICAgdHguYWRkKGFzc2lnbkFjY291bnQpO1xuXG4gICAgICAgIGNvbnN0IHNwbGl0U3Rha2UgPSBTdGFrZVByb2dyYW0uc3BsaXQoXG4gICAgICAgICAge1xuICAgICAgICAgICAgc3Rha2VQdWJrZXk6IG5ldyBQdWJsaWNLZXkoc3Rha2luZ0FkZHJlc3MpLFxuICAgICAgICAgICAgYXV0aG9yaXplZFB1YmtleTogbmV3IFB1YmxpY0tleShmcm9tQWRkcmVzcyksXG4gICAgICAgICAgICBzcGxpdFN0YWtlUHVia2V5OiB1bnN0YWtpbmdBZGRyZXNzLFxuICAgICAgICAgICAgbGFtcG9ydHM6IG5ldyBCaWdOdW1iZXIoZGF0YS5wYXJhbXMuYW1vdW50KS50b051bWJlcigpLFxuICAgICAgICAgIH0sXG4gICAgICAgICAgMFxuICAgICAgICApO1xuICAgICAgICB0eC5hZGQoc3BsaXRTdGFrZS5pbnN0cnVjdGlvbnNbMV0pO1xuXG4gICAgICAgIGNvbnN0IGRlYWN0aXZhdGVTdGFraW5nID0gU3Rha2VQcm9ncmFtLmRlYWN0aXZhdGUoe1xuICAgICAgICAgIHN0YWtlUHVia2V5OiB1bnN0YWtpbmdBZGRyZXNzLFxuICAgICAgICAgIGF1dGhvcml6ZWRQdWJrZXk6IG5ldyBQdWJsaWNLZXkoZnJvbUFkZHJlc3MpLFxuICAgICAgICB9KTtcbiAgICAgICAgdHguYWRkKGRlYWN0aXZhdGVTdGFraW5nKTtcblxuICAgICAgICByZXR1cm4gdHguaW5zdHJ1Y3Rpb25zO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgY29uc3QgZGVhY3RpdmF0ZVN0YWtpbmcgPSBTdGFrZVByb2dyYW0uZGVhY3RpdmF0ZSh7XG4gICAgICAgICAgc3Rha2VQdWJrZXk6IG5ldyBQdWJsaWNLZXkoc3Rha2luZ0FkZHJlc3MpLFxuICAgICAgICAgIGF1dGhvcml6ZWRQdWJrZXk6IG5ldyBQdWJsaWNLZXkoZnJvbUFkZHJlc3MpLFxuICAgICAgICB9KTtcblxuICAgICAgICByZXR1cm4gZGVhY3RpdmF0ZVN0YWtpbmcuaW5zdHJ1Y3Rpb25zO1xuICAgICAgfVxuICAgIH1cblxuICAgIGRlZmF1bHQ6IHtcbiAgICAgIGNvbnN0IHVucmVhY2hhYmxlOiBuZXZlciA9IHN0YWtpbmdUeXBlO1xuICAgICAgdGhyb3cgbmV3IEVycm9yKGBVbmtub3duIHN0YWtpbmcgdHlwZSAke3VucmVhY2hhYmxlfWApO1xuICAgIH1cbiAgfVxufVxuXG4vKipcbiAqIENvbnN0cnVjdCBTdGFraW5nIFdpdGhkcmF3IFNvbGFuYSBpbnN0cnVjdGlvbnNcbiAqXG4gKiBAcGFyYW0ge1N0YWtpbmdXaXRoZHJhd30gZGF0YSAtIHRoZSBkYXRhIHRvIGJ1aWxkIHRoZSBpbnN0cnVjdGlvblxuICogQHJldHVybnMge1RyYW5zYWN0aW9uSW5zdHJ1Y3Rpb25bXX0gQW4gYXJyYXkgY29udGFpbmluZyBTdGFraW5nIFdpdGhkcmF3ICBTb2xhbmEgaW5zdHJ1Y3Rpb25zXG4gKi9cbmZ1bmN0aW9uIHN0YWtpbmdXaXRoZHJhd0luc3RydWN0aW9uKGRhdGE6IFN0YWtpbmdXaXRoZHJhdyk6IFRyYW5zYWN0aW9uSW5zdHJ1Y3Rpb25bXSB7XG4gIGNvbnN0IHtcbiAgICBwYXJhbXM6IHsgZnJvbUFkZHJlc3MsIHN0YWtpbmdBZGRyZXNzLCBhbW91bnQgfSxcbiAgfSA9IGRhdGE7XG4gIGFzc2VydChmcm9tQWRkcmVzcywgJ01pc3NpbmcgZnJvbUFkZHJlc3MgcGFyYW0nKTtcbiAgYXNzZXJ0KHN0YWtpbmdBZGRyZXNzLCAnTWlzc2luZyBzdGFraW5nQWRkcmVzcyBwYXJhbScpO1xuICBhc3NlcnQoYW1vdW50LCAnTWlzc2luZyBhbW91bnQgcGFyYW0nKTtcblxuICBjb25zdCB3aXRoZHJhd1N0YWtpbmcgPSBTdGFrZVByb2dyYW0ud2l0aGRyYXcoe1xuICAgIHN0YWtlUHVia2V5OiBuZXcgUHVibGljS2V5KHN0YWtpbmdBZGRyZXNzKSxcbiAgICBhdXRob3JpemVkUHVia2V5OiBuZXcgUHVibGljS2V5KGZyb21BZGRyZXNzKSxcbiAgICB0b1B1YmtleTogbmV3IFB1YmxpY0tleShmcm9tQWRkcmVzcyksXG4gICAgbGFtcG9ydHM6IG5ldyBCaWdOdW1iZXIoYW1vdW50KS50b051bWJlcigpLFxuICB9KTtcblxuICByZXR1cm4gd2l0aGRyYXdTdGFraW5nLmluc3RydWN0aW9ucztcbn1cblxuLyoqXG4gKiBDb25zdHJ1Y3QgQ3JlYXRlIGFuZCBJbml0aWFsaXplIE5vbmNlIFNvbGFuYSBpbnN0cnVjdGlvbnNcbiAqXG4gKiBAcGFyYW0ge1dhbGxldEluaXR9IGRhdGEgLSB0aGUgZGF0YSB0byBidWlsZCB0aGUgaW5zdHJ1Y3Rpb25cbiAqIEByZXR1cm5zIHtUcmFuc2FjdGlvbkluc3RydWN0aW9uW119IEFuIGFycmF5IGNvbnRhaW5pbmcgQ3JlYXRlIGFuZCBJbml0aWFsaXplIE5vbmNlIFNvbGFuYSBpbnN0cnVjdGlvblxuICovXG5mdW5jdGlvbiBjcmVhdGVBVEFJbnN0cnVjdGlvbihkYXRhOiBBdGFJbml0KTogVHJhbnNhY3Rpb25JbnN0cnVjdGlvbltdIHtcbiAgY29uc3Qge1xuICAgIHBhcmFtczogeyBtaW50QWRkcmVzcywgYXRhQWRkcmVzcywgb3duZXJBZGRyZXNzLCBwYXllckFkZHJlc3MsIHByb2dyYW1JZCB9LFxuICB9ID0gZGF0YTtcbiAgYXNzZXJ0KG1pbnRBZGRyZXNzLCAnTWlzc2luZyBtaW50QWRkcmVzcyBwYXJhbScpO1xuICBhc3NlcnQoYXRhQWRkcmVzcywgJ01pc3NpbmcgYXRhQWRkcmVzcyBwYXJhbScpO1xuICBhc3NlcnQob3duZXJBZGRyZXNzLCAnTWlzc2luZyBvd25lckFkZHJlc3MgcGFyYW0nKTtcbiAgYXNzZXJ0KHBheWVyQWRkcmVzcywgJ01pc3NpbmcgcGF5ZXJBZGRyZXNzIHBhcmFtJyk7XG5cbiAgbGV0IGFzc29jaWF0ZWRUb2tlbkFjY291bnRJbnN0cnVjdGlvbjogVHJhbnNhY3Rpb25JbnN0cnVjdGlvbjtcbiAgaWYgKHByb2dyYW1JZCAmJiBwcm9ncmFtSWQgPT09IFRPS0VOXzIwMjJfUFJPR1JBTV9JRC50b1N0cmluZygpKSB7XG4gICAgYXNzb2NpYXRlZFRva2VuQWNjb3VudEluc3RydWN0aW9uID0gY3JlYXRlQXNzb2NpYXRlZFRva2VuQWNjb3VudEluc3RydWN0aW9uKFxuICAgICAgbmV3IFB1YmxpY0tleShwYXllckFkZHJlc3MpLFxuICAgICAgbmV3IFB1YmxpY0tleShhdGFBZGRyZXNzKSxcbiAgICAgIG5ldyBQdWJsaWNLZXkob3duZXJBZGRyZXNzKSxcbiAgICAgIG5ldyBQdWJsaWNLZXkobWludEFkZHJlc3MpLFxuICAgICAgVE9LRU5fMjAyMl9QUk9HUkFNX0lEXG4gICAgKTtcbiAgfSBlbHNlIHtcbiAgICBhc3NvY2lhdGVkVG9rZW5BY2NvdW50SW5zdHJ1Y3Rpb24gPSBjcmVhdGVBc3NvY2lhdGVkVG9rZW5BY2NvdW50SW5zdHJ1Y3Rpb24oXG4gICAgICBuZXcgUHVibGljS2V5KHBheWVyQWRkcmVzcyksXG4gICAgICBuZXcgUHVibGljS2V5KGF0YUFkZHJlc3MpLFxuICAgICAgbmV3IFB1YmxpY0tleShvd25lckFkZHJlc3MpLFxuICAgICAgbmV3IFB1YmxpY0tleShtaW50QWRkcmVzcylcbiAgICApO1xuICB9XG4gIHJldHVybiBbYXNzb2NpYXRlZFRva2VuQWNjb3VudEluc3RydWN0aW9uXTtcbn1cblxuLyoqXG4gKiBDb25zdHJ1Y3QgQ2xvc2UgQVRBIFNvbGFuYSBpbnN0cnVjdGlvbnNcbiAqXG4gKiBAcGFyYW0ge1dhbGxldEluaXR9IGRhdGEgLSB0aGUgZGF0YSB0byBidWlsZCB0aGUgaW5zdHJ1Y3Rpb25cbiAqIEByZXR1cm5zIHtUcmFuc2FjdGlvbkluc3RydWN0aW9uW119IEFuIGFycmF5IGNvbnRhaW5pbmcgQ2xvc2UgQVRBIFNvbGFuYSBpbnN0cnVjdGlvblxuICovXG5mdW5jdGlvbiBjbG9zZUFUQUluc3RydWN0aW9uKGRhdGE6IEF0YUNsb3NlKTogVHJhbnNhY3Rpb25JbnN0cnVjdGlvbltdIHtcbiAgY29uc3Qge1xuICAgIHBhcmFtczogeyBhY2NvdW50QWRkcmVzcywgZGVzdGluYXRpb25BZGRyZXNzLCBhdXRob3JpdHlBZGRyZXNzIH0sXG4gIH0gPSBkYXRhO1xuICBhc3NlcnQoYWNjb3VudEFkZHJlc3MsICdNaXNzaW5nIGFjY291bnRBZGRyZXNzIHBhcmFtJyk7XG4gIGFzc2VydChkZXN0aW5hdGlvbkFkZHJlc3MsICdNaXNzaW5nIGRlc3RpbmF0aW9uQWRkcmVzcyBwYXJhbScpO1xuICBhc3NlcnQoYXV0aG9yaXR5QWRkcmVzcywgJ01pc3NpbmcgYXV0aG9yaXR5QWRkcmVzcyBwYXJhbScpO1xuXG4gIGNvbnN0IGNsb3NlQXNzb2NpYXRlZFRva2VuQWNjb3VudEluc3RydWN0aW9uID0gY3JlYXRlQ2xvc2VBY2NvdW50SW5zdHJ1Y3Rpb24oXG4gICAgbmV3IFB1YmxpY0tleShhY2NvdW50QWRkcmVzcyksXG4gICAgbmV3IFB1YmxpY0tleShkZXN0aW5hdGlvbkFkZHJlc3MpLFxuICAgIG5ldyBQdWJsaWNLZXkoYXV0aG9yaXR5QWRkcmVzcylcbiAgKTtcbiAgcmV0dXJuIFtjbG9zZUFzc29jaWF0ZWRUb2tlbkFjY291bnRJbnN0cnVjdGlvbl07XG59XG5cbi8qKlxuICogQ29uc3RydWN0IFN0YWtpbmcgQWNjb3VudCBBdXRob3JpemUgU29sYW5hIGluc3RydWN0aW9uc1xuICpcbiAqIEBwYXJhbSB7U3Rha2luZ0F1dGhvcml6ZX0gZGF0YSAtIHRoZSBkYXRhIHRvIGJ1aWxkIHRoZSBpbnN0cnVjdGlvblxuICogQHJldHVybnMge1RyYW5zYWN0aW9uSW5zdHJ1Y3Rpb25bXX0gQW4gYXJyYXkgY29udGFpbmluZyBTdGFraW5nIEFjY291bnQgQXV0aG9yaXplIGluc3RydWN0aW9uc1xuICovXG5mdW5jdGlvbiBzdGFraW5nQXV0aG9yaXplSW5zdHJ1Y3Rpb24oZGF0YTogU3Rha2luZ0F1dGhvcml6ZSk6IFRyYW5zYWN0aW9uSW5zdHJ1Y3Rpb25bXSB7XG4gIGNvbnN0IHtcbiAgICBwYXJhbXM6IHsgc3Rha2luZ0FkZHJlc3MsIG9sZEF1dGhvcml6ZUFkZHJlc3MsIG5ld0F1dGhvcml6ZUFkZHJlc3MsIG5ld1dpdGhkcmF3QWRkcmVzcyB9LFxuICB9ID0gZGF0YTtcbiAgYXNzZXJ0KHN0YWtpbmdBZGRyZXNzLCAnTWlzc2luZyBzdGFraW5nQWRkcmVzcyBwYXJhbScpO1xuICBhc3NlcnQob2xkQXV0aG9yaXplQWRkcmVzcywgJ01pc3Npbmcgb2xkQXV0aG9yaXplQWRkcmVzcyBwYXJhbScpO1xuICBhc3NlcnQobmV3QXV0aG9yaXplQWRkcmVzcywgJ01pc3NpbmcgbmV3QXV0aG9yaXplQWRkcmVzcyBwYXJhbScpO1xuICBhc3NlcnQobmV3V2l0aGRyYXdBZGRyZXNzLCAnTWlzc2luZyBuZXdXaXRoZHJhd0FkZHJlc3MgcGFyYW0nKTtcblxuICBjb25zdCB0eCA9IG5ldyBUcmFuc2FjdGlvbigpO1xuXG4gIGNvbnN0IGF1dGhvcml6ZVN0YWtpbmcgPSBTdGFrZVByb2dyYW0uYXV0aG9yaXplKHtcbiAgICBzdGFrZVB1YmtleTogbmV3IFB1YmxpY0tleShzdGFraW5nQWRkcmVzcyksXG4gICAgYXV0aG9yaXplZFB1YmtleTogbmV3IFB1YmxpY0tleShvbGRBdXRob3JpemVBZGRyZXNzKSxcbiAgICBuZXdBdXRob3JpemVkUHVia2V5OiBuZXcgUHVibGljS2V5KG5ld0F1dGhvcml6ZUFkZHJlc3MpLFxuICAgIHN0YWtlQXV0aG9yaXphdGlvblR5cGU6IFN0YWtlQXV0aG9yaXphdGlvbkxheW91dC5TdGFrZXIsXG4gIH0pO1xuXG4gIGNvbnN0IGF1dGhvcml6ZVdpdGhkcmF3ID0gU3Rha2VQcm9ncmFtLmF1dGhvcml6ZSh7XG4gICAgc3Rha2VQdWJrZXk6IG5ldyBQdWJsaWNLZXkoc3Rha2luZ0FkZHJlc3MpLFxuICAgIGF1dGhvcml6ZWRQdWJrZXk6IG5ldyBQdWJsaWNLZXkob2xkQXV0aG9yaXplQWRkcmVzcyksXG4gICAgbmV3QXV0aG9yaXplZFB1YmtleTogbmV3IFB1YmxpY0tleShuZXdBdXRob3JpemVBZGRyZXNzKSxcbiAgICBzdGFrZUF1dGhvcml6YXRpb25UeXBlOiBTdGFrZUF1dGhvcml6YXRpb25MYXlvdXQuV2l0aGRyYXdlcixcbiAgICBjdXN0b2RpYW5QdWJrZXk6IG5ldyBQdWJsaWNLZXkobmV3V2l0aGRyYXdBZGRyZXNzKSxcbiAgfSk7XG4gIHR4LmFkZChhdXRob3JpemVTdGFraW5nKTtcbiAgdHguYWRkKGF1dGhvcml6ZVdpdGhkcmF3KTtcblxuICByZXR1cm4gdHguaW5zdHJ1Y3Rpb25zO1xufVxuXG4vKipcbiAqIENvbnN0cnVjdCBEZWxlZ2F0ZSBTb2xhbmEgaW5zdHJ1Y3Rpb25zXG4gKlxuICogQHBhcmFtIHtTdGFraW5nQWN0aXZhdGV9IGRhdGEgLSB0aGUgZGF0YSB0byBidWlsZCB0aGUgaW5zdHJ1Y3Rpb25cbiAqIEByZXR1cm5zIHtUcmFuc2FjdGlvbkluc3RydWN0aW9uW119IEFuIGFycmF5IGNvbnRhaW5pbmcgRGVsZWdhdGUgU29sYW5hIGluc3RydWN0aW9uc1xuICovXG5mdW5jdGlvbiBzdGFraW5nRGVsZWdhdGVJbnN0cnVjdGlvbihkYXRhOiBTdGFraW5nRGVsZWdhdGUpOiBUcmFuc2FjdGlvbkluc3RydWN0aW9uW10ge1xuICBjb25zdCB7XG4gICAgcGFyYW1zOiB7IGZyb21BZGRyZXNzLCBzdGFraW5nQWRkcmVzcywgdmFsaWRhdG9yIH0sXG4gIH0gPSBkYXRhO1xuICBhc3NlcnQoZnJvbUFkZHJlc3MsICdNaXNzaW5nIGZyb21BZGRyZXNzIHBhcmFtJyk7XG4gIGFzc2VydChzdGFraW5nQWRkcmVzcywgJ01pc3Npbmcgc3Rha2luZ0FkZHJlc3MgcGFyYW0nKTtcbiAgYXNzZXJ0KHZhbGlkYXRvciwgJ01pc3NpbmcgdmFsaWRhdG9yIHBhcmFtJyk7XG4gIGNvbnN0IHR4ID0gbmV3IFRyYW5zYWN0aW9uKCk7XG4gIGNvbnN0IGRlbGVnYXRlU3Rha2luZyA9IFN0YWtlUHJvZ3JhbS5kZWxlZ2F0ZSh7XG4gICAgc3Rha2VQdWJrZXk6IG5ldyBQdWJsaWNLZXkoc3Rha2luZ0FkZHJlc3MpLFxuICAgIGF1dGhvcml6ZWRQdWJrZXk6IG5ldyBQdWJsaWNLZXkoZnJvbUFkZHJlc3MpLFxuICAgIHZvdGVQdWJrZXk6IG5ldyBQdWJsaWNLZXkodmFsaWRhdG9yKSxcbiAgfSk7XG4gIHR4LmFkZChkZWxlZ2F0ZVN0YWtpbmcpO1xuXG4gIHJldHVybiB0eC5pbnN0cnVjdGlvbnM7XG59XG5cbi8qKlxuICogQ29uc3RydWN0IE1pbnRUbyBTb2xhbmEgaW5zdHJ1Y3Rpb25zXG4gKlxuICogQHBhcmFtIHtNaW50VG99IGRhdGEgLSB0aGUgZGF0YSB0byBidWlsZCB0aGUgaW5zdHJ1Y3Rpb25cbiAqIEByZXR1cm5zIHtUcmFuc2FjdGlvbkluc3RydWN0aW9uW119IEFuIGFycmF5IGNvbnRhaW5pbmcgTWludFRvIFNvbGFuYSBpbnN0cnVjdGlvbnNcbiAqL1xuZnVuY3Rpb24gbWludFRvSW5zdHJ1Y3Rpb24oZGF0YTogTWludFRvKTogVHJhbnNhY3Rpb25JbnN0cnVjdGlvbltdIHtcbiAgY29uc3Qge1xuICAgIHBhcmFtczogeyBtaW50QWRkcmVzcywgZGVzdGluYXRpb25BZGRyZXNzLCBhdXRob3JpdHlBZGRyZXNzLCBhbW91bnQsIHByb2dyYW1JZCB9LFxuICB9ID0gZGF0YTtcbiAgYXNzZXJ0KG1pbnRBZGRyZXNzLCAnTWlzc2luZyBtaW50QWRkcmVzcyBwYXJhbScpO1xuICBhc3NlcnQoZGVzdGluYXRpb25BZGRyZXNzLCAnTWlzc2luZyBkZXN0aW5hdGlvbkFkZHJlc3MgcGFyYW0nKTtcbiAgYXNzZXJ0KGF1dGhvcml0eUFkZHJlc3MsICdNaXNzaW5nIGF1dGhvcml0eUFkZHJlc3MgcGFyYW0nKTtcbiAgYXNzZXJ0KGFtb3VudCwgJ01pc3NpbmcgYW1vdW50IHBhcmFtJyk7XG5cbiAgY29uc3QgbWludCA9IG5ldyBQdWJsaWNLZXkobWludEFkZHJlc3MpO1xuICBjb25zdCBkZXN0aW5hdGlvbiA9IG5ldyBQdWJsaWNLZXkoZGVzdGluYXRpb25BZGRyZXNzKTtcbiAgY29uc3QgYXV0aG9yaXR5ID0gbmV3IFB1YmxpY0tleShhdXRob3JpdHlBZGRyZXNzKTtcblxuICBsZXQgbWludFRvSW5zdHI6IFRyYW5zYWN0aW9uSW5zdHJ1Y3Rpb247XG4gIGlmIChwcm9ncmFtSWQgJiYgcHJvZ3JhbUlkID09PSBUT0tFTl8yMDIyX1BST0dSQU1fSUQudG9TdHJpbmcoKSkge1xuICAgIG1pbnRUb0luc3RyID0gY3JlYXRlTWludFRvSW5zdHJ1Y3Rpb24obWludCwgZGVzdGluYXRpb24sIGF1dGhvcml0eSwgQmlnSW50KGFtb3VudCksIFtdLCBUT0tFTl8yMDIyX1BST0dSQU1fSUQpO1xuICB9IGVsc2Uge1xuICAgIG1pbnRUb0luc3RyID0gY3JlYXRlTWludFRvSW5zdHJ1Y3Rpb24obWludCwgZGVzdGluYXRpb24sIGF1dGhvcml0eSwgQmlnSW50KGFtb3VudCkpO1xuICB9XG5cbiAgcmV0dXJuIFttaW50VG9JbnN0cl07XG59XG5cbi8qKlxuICogQ29uc3RydWN0IEJ1cm4gU29sYW5hIGluc3RydWN0aW9uc1xuICpcbiAqIEBwYXJhbSB7QnVybn0gZGF0YSAtIHRoZSBkYXRhIHRvIGJ1aWxkIHRoZSBpbnN0cnVjdGlvblxuICogQHJldHVybnMge1RyYW5zYWN0aW9uSW5zdHJ1Y3Rpb25bXX0gQW4gYXJyYXkgY29udGFpbmluZyBCdXJuIFNvbGFuYSBpbnN0cnVjdGlvbnNcbiAqL1xuZnVuY3Rpb24gYnVybkluc3RydWN0aW9uKGRhdGE6IEJ1cm4pOiBUcmFuc2FjdGlvbkluc3RydWN0aW9uW10ge1xuICBjb25zdCB7XG4gICAgcGFyYW1zOiB7IG1pbnRBZGRyZXNzLCBhY2NvdW50QWRkcmVzcywgYXV0aG9yaXR5QWRkcmVzcywgYW1vdW50LCBwcm9ncmFtSWQgfSxcbiAgfSA9IGRhdGE7XG4gIGFzc2VydChtaW50QWRkcmVzcywgJ01pc3NpbmcgbWludEFkZHJlc3MgcGFyYW0nKTtcbiAgYXNzZXJ0KGFjY291bnRBZGRyZXNzLCAnTWlzc2luZyBhY2NvdW50QWRkcmVzcyBwYXJhbScpO1xuICBhc3NlcnQoYXV0aG9yaXR5QWRkcmVzcywgJ01pc3NpbmcgYXV0aG9yaXR5QWRkcmVzcyBwYXJhbScpO1xuICBhc3NlcnQoYW1vdW50LCAnTWlzc2luZyBhbW91bnQgcGFyYW0nKTtcblxuICBjb25zdCBtaW50ID0gbmV3IFB1YmxpY0tleShtaW50QWRkcmVzcyk7XG4gIGNvbnN0IGFjY291bnQgPSBuZXcgUHVibGljS2V5KGFjY291bnRBZGRyZXNzKTtcbiAgY29uc3QgYXV0aG9yaXR5ID0gbmV3IFB1YmxpY0tleShhdXRob3JpdHlBZGRyZXNzKTtcblxuICBsZXQgYnVybkluc3RyOiBUcmFuc2FjdGlvbkluc3RydWN0aW9uO1xuICBpZiAocHJvZ3JhbUlkICYmIHByb2dyYW1JZCA9PT0gVE9LRU5fMjAyMl9QUk9HUkFNX0lELnRvU3RyaW5nKCkpIHtcbiAgICBidXJuSW5zdHIgPSBjcmVhdGVCdXJuSW5zdHJ1Y3Rpb24oYWNjb3VudCwgbWludCwgYXV0aG9yaXR5LCBCaWdJbnQoYW1vdW50KSwgW10sIFRPS0VOXzIwMjJfUFJPR1JBTV9JRCk7XG4gIH0gZWxzZSB7XG4gICAgYnVybkluc3RyID0gY3JlYXRlQnVybkluc3RydWN0aW9uKGFjY291bnQsIG1pbnQsIGF1dGhvcml0eSwgQmlnSW50KGFtb3VudCkpO1xuICB9XG5cbiAgcmV0dXJuIFtidXJuSW5zdHJdO1xufVxuXG4vKipcbiAqIFByb2Nlc3MgY3VzdG9tIGluc3RydWN0aW9uIC0gY29udmVydHMgdG8gVHJhbnNhY3Rpb25JbnN0cnVjdGlvblxuICogSGFuZGxlcyBjb252ZXJzaW9uIGZyb20gc3RyaW5nLWJhc2VkIGZvcm1hdCB0byBUcmFuc2FjdGlvbkluc3RydWN0aW9uIGZvcm1hdFxuICpcbiAqIEBwYXJhbSB7Q3VzdG9tSW5zdHJ1Y3Rpb259IGRhdGEgLSB0aGUgZGF0YSBjb250YWluaW5nIHRoZSBjdXN0b20gaW5zdHJ1Y3Rpb25cbiAqIEByZXR1cm5zIHtUcmFuc2FjdGlvbkluc3RydWN0aW9uW119IEFuIGFycmF5IGNvbnRhaW5pbmcgdGhlIGN1c3RvbSBpbnN0cnVjdGlvblxuICovXG5mdW5jdGlvbiBjdXN0b21JbnN0cnVjdGlvbihkYXRhOiBJbnN0cnVjdGlvblBhcmFtcyk6IFRyYW5zYWN0aW9uSW5zdHJ1Y3Rpb25bXSB7XG4gIGNvbnN0IHsgcGFyYW1zIH0gPSBkYXRhIGFzIEN1c3RvbUluc3RydWN0aW9uO1xuICBhc3NlcnQocGFyYW1zLnByb2dyYW1JZCwgJ01pc3NpbmcgcHJvZ3JhbUlkIGluIGN1c3RvbSBpbnN0cnVjdGlvbicpO1xuICBhc3NlcnQocGFyYW1zLmtleXMgJiYgQXJyYXkuaXNBcnJheShwYXJhbXMua2V5cyksICdNaXNzaW5nIG9yIGludmFsaWQga2V5cyBpbiBjdXN0b20gaW5zdHJ1Y3Rpb24nKTtcbiAgYXNzZXJ0KHBhcmFtcy5kYXRhICE9PSB1bmRlZmluZWQsICdNaXNzaW5nIGRhdGEgaW4gY3VzdG9tIGluc3RydWN0aW9uJyk7XG5cbiAgLy8gQ29udmVydCBzdHJpbmcgZGF0YSB0byBCdWZmZXJcbiAgbGV0IGRhdGFCdWZmZXI6IEJ1ZmZlcjtcblxuICBpZiAoaXNWYWxpZEJhc2U2NChwYXJhbXMuZGF0YSkpIHtcbiAgICBkYXRhQnVmZmVyID0gQnVmZmVyLmZyb20ocGFyYW1zLmRhdGEsICdiYXNlNjQnKTtcbiAgfSBlbHNlIGlmIChpc1ZhbGlkSGV4KHBhcmFtcy5kYXRhKSkge1xuICAgIGRhdGFCdWZmZXIgPSBCdWZmZXIuZnJvbShwYXJhbXMuZGF0YSwgJ2hleCcpO1xuICB9IGVsc2Uge1xuICAgIC8vIEZhbGxiYWNrIHRvIFVURi04XG4gICAgZGF0YUJ1ZmZlciA9IEJ1ZmZlci5mcm9tKHBhcmFtcy5kYXRhLCAndXRmOCcpO1xuICB9XG5cbiAgLy8gQ3JlYXRlIGEgbmV3IFRyYW5zYWN0aW9uSW5zdHJ1Y3Rpb24gd2l0aCB0aGUgY29udmVydGVkIGRhdGFcbiAgY29uc3QgY29udmVydGVkSW5zdHJ1Y3Rpb24gPSBuZXcgVHJhbnNhY3Rpb25JbnN0cnVjdGlvbih7XG4gICAgcHJvZ3JhbUlkOiBuZXcgUHVibGljS2V5KHBhcmFtcy5wcm9ncmFtSWQpLFxuICAgIGtleXM6IHBhcmFtcy5rZXlzLm1hcCgoa2V5KSA9PiAoe1xuICAgICAgcHVia2V5OiBuZXcgUHVibGljS2V5KGtleS5wdWJrZXkpLFxuICAgICAgaXNTaWduZXI6IGtleS5pc1NpZ25lcixcbiAgICAgIGlzV3JpdGFibGU6IGtleS5pc1dyaXRhYmxlLFxuICAgIH0pKSxcbiAgICBkYXRhOiBkYXRhQnVmZmVyLFxuICB9KTtcblxuICByZXR1cm4gW2NvbnZlcnRlZEluc3RydWN0aW9uXTtcbn1cblxuZnVuY3Rpb24gdXBzZXJ0QWNjb3VudE1ldGEoa2V5czogQWNjb3VudE1ldGFbXSwgbWV0YTogQWNjb3VudE1ldGEpOiB2b2lkIHtcbiAgY29uc3QgZXhpc3RpbmcgPSBrZXlzLmZpbmQoKGFjY291bnQpID0+IGFjY291bnQucHVia2V5LmVxdWFscyhtZXRhLnB1YmtleSkpO1xuICBpZiAoZXhpc3RpbmcpIHtcbiAgICBleGlzdGluZy5pc1dyaXRhYmxlID0gZXhpc3RpbmcuaXNXcml0YWJsZSB8fCBtZXRhLmlzV3JpdGFibGU7XG4gICAgZXhpc3RpbmcuaXNTaWduZXIgPSBleGlzdGluZy5pc1NpZ25lciB8fCBtZXRhLmlzU2lnbmVyO1xuICB9IGVsc2Uge1xuICAgIGtleXMucHVzaChtZXRhKTtcbiAgfVxufVxuXG5mdW5jdGlvbiBidWlsZFN0YXRpY1RyYW5zZmVySG9va0FjY291bnRzKHRyYW5zZmVySG9vazogVHJhbnNmZXJIb29rQ29uZmlnKTogQWNjb3VudE1ldGFbXSB7XG4gIGNvbnN0IG1ldGFzOiBBY2NvdW50TWV0YVtdID0gW107XG4gIGlmICh0cmFuc2Zlckhvb2suZXh0cmFBY2NvdW50TWV0YXM/Lmxlbmd0aCkge1xuICAgIGZvciAoY29uc3QgbWV0YSBvZiB0cmFuc2Zlckhvb2suZXh0cmFBY2NvdW50TWV0YXMpIHtcbiAgICAgIG1ldGFzLnB1c2goe1xuICAgICAgICBwdWJrZXk6IG5ldyBQdWJsaWNLZXkobWV0YS5wdWJrZXkpLFxuICAgICAgICBpc1NpZ25lcjogbWV0YS5pc1NpZ25lcixcbiAgICAgICAgaXNXcml0YWJsZTogbWV0YS5pc1dyaXRhYmxlLFxuICAgICAgfSk7XG4gICAgfVxuICB9XG4gIHJldHVybiBtZXRhcztcbn1cblxuZnVuY3Rpb24gYWRkVHJhbnNmZXJIb29rQWNjb3VudHMoaW5zdHJ1Y3Rpb246IFRyYW5zYWN0aW9uSW5zdHJ1Y3Rpb24sIHRyYW5zZmVySG9vazogVHJhbnNmZXJIb29rQ29uZmlnKTogdm9pZCB7XG4gIGNvbnN0IGV4dHJhTWV0YXMgPSBidWlsZFN0YXRpY1RyYW5zZmVySG9va0FjY291bnRzKHRyYW5zZmVySG9vayk7XG4gIGZvciAoY29uc3QgbWV0YSBvZiBleHRyYU1ldGFzKSB7XG4gICAgdXBzZXJ0QWNjb3VudE1ldGEoaW5zdHJ1Y3Rpb24ua2V5cywgbWV0YSk7XG4gIH1cbn1cbiJdfQ==