@bitgo-beta/utxo-staking 1.1.1-beta.9 → 1.1.1-beta.900

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 (139) hide show
  1. package/dist/cjs/scripts/babylon-sync.d.ts +2 -0
  2. package/dist/cjs/scripts/babylon-sync.d.ts.map +1 -0
  3. package/dist/cjs/scripts/babylon-sync.js +126 -0
  4. package/dist/cjs/src/babylon/delegationMessage.d.ts +38 -0
  5. package/dist/cjs/src/babylon/delegationMessage.d.ts.map +1 -0
  6. package/dist/cjs/src/babylon/delegationMessage.js +285 -0
  7. package/dist/cjs/src/babylon/descriptor.d.ts +48 -0
  8. package/dist/cjs/src/babylon/descriptor.d.ts.map +1 -0
  9. package/dist/cjs/src/babylon/descriptor.js +97 -0
  10. package/dist/cjs/src/babylon/index.d.ts +8 -0
  11. package/dist/cjs/src/babylon/index.d.ts.map +1 -0
  12. package/dist/cjs/src/babylon/index.js +51 -0
  13. package/dist/cjs/src/babylon/network.d.ts +7 -0
  14. package/dist/cjs/src/babylon/network.d.ts.map +1 -0
  15. package/dist/cjs/src/babylon/network.js +66 -0
  16. package/dist/cjs/src/babylon/params.mainnet.json +152 -0
  17. package/dist/cjs/src/babylon/params.testnet.json +212 -0
  18. package/dist/cjs/src/babylon/parseDescriptor.d.ts +26 -0
  19. package/dist/cjs/src/babylon/parseDescriptor.d.ts.map +1 -0
  20. package/dist/cjs/src/babylon/parseDescriptor.js +159 -0
  21. package/dist/cjs/src/babylon/stakingManager.d.ts +6 -0
  22. package/dist/cjs/src/babylon/stakingManager.d.ts.map +1 -0
  23. package/dist/cjs/src/babylon/stakingManager.js +120 -0
  24. package/dist/cjs/src/babylon/stakingParams.d.ts +40 -0
  25. package/dist/cjs/src/babylon/stakingParams.d.ts.map +1 -0
  26. package/dist/cjs/src/babylon/stakingParams.js +132 -0
  27. package/dist/cjs/src/babylon/undelegation/UndelegationResponse.d.ts +24 -0
  28. package/dist/cjs/src/babylon/undelegation/UndelegationResponse.d.ts.map +1 -0
  29. package/dist/cjs/src/babylon/undelegation/UndelegationResponse.js +55 -0
  30. package/dist/cjs/src/babylon/undelegation/index.d.ts +3 -0
  31. package/dist/cjs/src/babylon/undelegation/index.d.ts.map +1 -0
  32. package/dist/{src → cjs/src/babylon/undelegation}/index.js +3 -4
  33. package/dist/cjs/src/babylon/undelegation/unbonding.d.ts +16 -0
  34. package/dist/cjs/src/babylon/undelegation/unbonding.d.ts.map +1 -0
  35. package/dist/cjs/src/babylon/undelegation/unbonding.js +111 -0
  36. package/dist/{src → cjs/src}/coreDao/descriptor.d.ts +4 -4
  37. package/dist/cjs/src/coreDao/descriptor.d.ts.map +1 -0
  38. package/dist/cjs/src/coreDao/descriptor.js +38 -0
  39. package/dist/cjs/src/coreDao/index.d.ts.map +1 -0
  40. package/dist/{src → cjs/src}/coreDao/index.js +1 -1
  41. package/dist/{src → cjs/src}/coreDao/opReturn.d.ts +5 -5
  42. package/dist/cjs/src/coreDao/opReturn.d.ts.map +1 -0
  43. package/dist/cjs/src/coreDao/opReturn.js +183 -0
  44. package/dist/{src → cjs/src}/coreDao/transaction.d.ts +16 -9
  45. package/dist/cjs/src/coreDao/transaction.d.ts.map +1 -0
  46. package/dist/cjs/src/coreDao/transaction.js +34 -0
  47. package/dist/cjs/src/index.d.ts +3 -0
  48. package/dist/cjs/src/index.d.ts.map +1 -0
  49. package/dist/cjs/src/index.js +39 -0
  50. package/dist/cjs/test/unit/babylon/bug71.d.ts +2 -0
  51. package/dist/cjs/test/unit/babylon/bug71.d.ts.map +1 -0
  52. package/dist/cjs/test/unit/babylon/bug71.js +108 -0
  53. package/dist/cjs/test/unit/babylon/key.utils.d.ts +6 -0
  54. package/dist/cjs/test/unit/babylon/key.utils.d.ts.map +1 -0
  55. package/dist/cjs/test/unit/babylon/key.utils.js +68 -0
  56. package/dist/cjs/test/unit/babylon/transactions.d.ts +2 -0
  57. package/dist/cjs/test/unit/babylon/transactions.d.ts.map +1 -0
  58. package/dist/cjs/test/unit/babylon/transactions.js +338 -0
  59. package/dist/cjs/test/unit/babylon/undelegation.d.ts +2 -0
  60. package/dist/cjs/test/unit/babylon/undelegation.d.ts.map +1 -0
  61. package/dist/cjs/test/unit/babylon/undelegation.js +156 -0
  62. package/dist/cjs/test/unit/babylon/vendor.utils.d.ts +13 -0
  63. package/dist/cjs/test/unit/babylon/vendor.utils.d.ts.map +1 -0
  64. package/dist/cjs/test/unit/babylon/vendor.utils.js +78 -0
  65. package/dist/cjs/test/unit/coreDao/descriptor.d.ts +2 -0
  66. package/dist/cjs/test/unit/coreDao/descriptor.d.ts.map +1 -0
  67. package/dist/cjs/test/unit/coreDao/descriptor.js +144 -0
  68. package/dist/cjs/test/unit/coreDao/opReturn.d.ts +2 -0
  69. package/dist/cjs/test/unit/coreDao/opReturn.d.ts.map +1 -0
  70. package/dist/cjs/test/unit/coreDao/opReturn.js +275 -0
  71. package/dist/cjs/test/unit/coreDao/utils.d.ts +5 -0
  72. package/dist/cjs/test/unit/coreDao/utils.d.ts.map +1 -0
  73. package/dist/cjs/test/unit/coreDao/utils.js +54 -0
  74. package/dist/cjs/test/unit/fixtures.utils.d.ts +9 -0
  75. package/dist/cjs/test/unit/fixtures.utils.d.ts.map +1 -0
  76. package/dist/cjs/test/unit/fixtures.utils.js +91 -0
  77. package/dist/cjs/tsconfig.tsbuildinfo +1 -0
  78. package/dist/esm/babylon/delegationMessage.d.ts +38 -0
  79. package/dist/esm/babylon/delegationMessage.d.ts.map +1 -0
  80. package/dist/esm/babylon/delegationMessage.js +239 -0
  81. package/dist/esm/babylon/descriptor.d.ts +48 -0
  82. package/dist/esm/babylon/descriptor.d.ts.map +1 -0
  83. package/dist/esm/babylon/descriptor.js +91 -0
  84. package/dist/esm/babylon/index.d.ts +8 -0
  85. package/dist/esm/babylon/index.d.ts.map +1 -0
  86. package/dist/esm/babylon/index.js +13 -0
  87. package/dist/esm/babylon/network.d.ts +7 -0
  88. package/dist/esm/babylon/network.d.ts.map +1 -0
  89. package/dist/esm/babylon/network.js +29 -0
  90. package/dist/esm/babylon/params.mainnet.json +152 -0
  91. package/dist/esm/babylon/params.testnet.json +212 -0
  92. package/dist/esm/babylon/parseDescriptor.d.ts +26 -0
  93. package/dist/esm/babylon/parseDescriptor.d.ts.map +1 -0
  94. package/dist/esm/babylon/parseDescriptor.js +155 -0
  95. package/dist/esm/babylon/stakingManager.d.ts +6 -0
  96. package/dist/esm/babylon/stakingManager.d.ts.map +1 -0
  97. package/dist/esm/babylon/stakingManager.js +83 -0
  98. package/dist/esm/babylon/stakingParams.d.ts +40 -0
  99. package/dist/esm/babylon/stakingParams.d.ts.map +1 -0
  100. package/dist/esm/babylon/stakingParams.js +86 -0
  101. package/dist/esm/babylon/undelegation/UndelegationResponse.d.ts +24 -0
  102. package/dist/esm/babylon/undelegation/UndelegationResponse.d.ts.map +1 -0
  103. package/dist/esm/babylon/undelegation/UndelegationResponse.js +18 -0
  104. package/dist/esm/babylon/undelegation/index.d.ts +3 -0
  105. package/dist/esm/babylon/undelegation/index.d.ts.map +1 -0
  106. package/dist/esm/babylon/undelegation/index.js +3 -0
  107. package/dist/esm/babylon/undelegation/unbonding.d.ts +16 -0
  108. package/dist/esm/babylon/undelegation/unbonding.d.ts.map +1 -0
  109. package/dist/esm/babylon/undelegation/unbonding.js +70 -0
  110. package/dist/esm/coreDao/descriptor.d.ts +18 -0
  111. package/dist/esm/coreDao/descriptor.d.ts.map +1 -0
  112. package/dist/esm/coreDao/descriptor.js +35 -0
  113. package/dist/esm/coreDao/index.d.ts +4 -0
  114. package/dist/esm/coreDao/index.js +4 -0
  115. package/dist/esm/coreDao/opReturn.d.ts +41 -0
  116. package/dist/esm/coreDao/opReturn.d.ts.map +1 -0
  117. package/dist/esm/coreDao/opReturn.js +175 -0
  118. package/dist/esm/coreDao/transaction.d.ts +28 -0
  119. package/dist/esm/coreDao/transaction.d.ts.map +1 -0
  120. package/dist/esm/coreDao/transaction.js +30 -0
  121. package/dist/esm/index.d.ts +3 -0
  122. package/dist/{src → esm}/index.d.ts.map +1 -1
  123. package/dist/esm/index.js +3 -0
  124. package/package.json +42 -12
  125. package/.eslintignore +0 -5
  126. package/.mocharc.yml +0 -8
  127. package/CHANGELOG.md +0 -24
  128. package/dist/src/coreDao/descriptor.d.ts.map +0 -1
  129. package/dist/src/coreDao/descriptor.js +0 -31
  130. package/dist/src/coreDao/opReturn.d.ts.map +0 -1
  131. package/dist/src/coreDao/opReturn.js +0 -175
  132. package/dist/src/coreDao/transaction.d.ts.map +0 -1
  133. package/dist/src/coreDao/transaction.js +0 -27
  134. package/dist/src/index.d.ts +0 -3
  135. package/dist/src/transaction.d.ts +0 -34
  136. package/dist/src/transaction.d.ts.map +0 -1
  137. package/dist/src/transaction.js +0 -55
  138. /package/dist/{src → cjs/src}/coreDao/index.d.ts +0 -0
  139. /package/dist/{src → esm}/coreDao/index.d.ts.map +0 -0
@@ -1,175 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.toString = exports.parseCoreDaoOpReturnOutputScript = exports.createCoreDaoOpReturnOutputScript = exports.decodeTimelock = exports.encodeTimelock = exports.CORE_DAO_SATOSHI_PLUS_IDENTIFIER = exports.CORE_DAO_MAINNET_CHAIN_ID = exports.CORE_DAO_TESTNET_CHAIN_ID = void 0;
4
- const utxo_lib_1 = require("@bitgo-beta/utxo-lib");
5
- // Source: https://docs.coredao.org/docs/Learn/products/btc-staking/design
6
- exports.CORE_DAO_TESTNET_CHAIN_ID = Buffer.from('045b', 'hex');
7
- exports.CORE_DAO_MAINNET_CHAIN_ID = Buffer.from('045c', 'hex');
8
- exports.CORE_DAO_SATOSHI_PLUS_IDENTIFIER = Buffer.from('5341542b', 'hex');
9
- // https://github.com/bitcoin/bitcoin/blob/5961b23898ee7c0af2626c46d5d70e80136578d3/src/script/script.h#L47
10
- const OP_RETURN_IDENTIFIER = Buffer.from('6a', 'hex');
11
- function encodeTimelock(timelock) {
12
- const buff = Buffer.alloc(4);
13
- buff.writeUInt32LE(timelock);
14
- return buff;
15
- }
16
- exports.encodeTimelock = encodeTimelock;
17
- function decodeTimelock(buffer) {
18
- if (buffer.length !== 4) {
19
- throw new Error('Invalid timelock buffer length');
20
- }
21
- return buffer.readUInt32LE();
22
- }
23
- exports.decodeTimelock = decodeTimelock;
24
- /**
25
- * Create a CoreDAO OP_RETURN output script
26
- *
27
- * @param version Version of the OP_RETURN
28
- * @param chainId Chain ID
29
- * @param delegator Delegator address
30
- * @param validator Validator address
31
- * @param fee Fee for relayer
32
- * @param redeemScript Redeem script of the staking output
33
- * @param timelock Timelock for the staking output
34
- * @returns Buffer OP_RETURN buffer
35
- */
36
- function createCoreDaoOpReturnOutputScript({ version, chainId, delegator, validator, fee, ...rest }) {
37
- /**
38
- * As of v2, this is the construction of the OP_RETURN:
39
- * Source: https://docs.coredao.org/docs/Learn/products/btc-staking/design#op_return-output
40
- *
41
- * The OP_RETURN output should contain all staking information in order, and be composed in the following format:
42
- *
43
- * Satoshi Plus Identifier: (SAT+) 4 bytes
44
- * Version: (0x01) 1 byte
45
- * Chain ID: (0x045b (1115) for Core Testnet and 0x045c (1116) for Core Mainnet) 2 bytes
46
- * Delegator: The Core address to receive rewards, 20 bytes
47
- * Validator: The Core validator address to stake to, 20 bytes
48
- * Fee: Fee for relayer, 1 byte, range [0,255], measured in CORE
49
- * (Optional) RedeemScript
50
- * (Optional) Timelock: 4 bytes
51
- *
52
- * Either RedeemScript or Timelock must be available, the purpose is to allow relayer to
53
- * obtain the RedeemScript and submit transactions on Core. If a RedeemScript is provided,
54
- * relayer will use it directly. Otherwise, relayer will construct the redeem script based
55
- * on the timelock and the information in the transaction inputs.
56
- *
57
- * Note that any length > 80 bytes wont be relayed by nodes and therefore we will throw an error.
58
- */
59
- if (version < 0 || version > 255) {
60
- throw new Error('Invalid version - out of range');
61
- }
62
- const versionBuffer = Buffer.alloc(1, version);
63
- if (!(chainId.equals(exports.CORE_DAO_TESTNET_CHAIN_ID) || chainId.equals(exports.CORE_DAO_MAINNET_CHAIN_ID))) {
64
- throw new Error('Invalid chain ID');
65
- }
66
- if (delegator.length !== 20) {
67
- throw new Error('Invalid delegator address');
68
- }
69
- if (validator.length !== 20) {
70
- throw new Error('Invalid validator address');
71
- }
72
- if (fee < 0 || fee > 255) {
73
- throw new Error('Invalid fee - out of range');
74
- }
75
- const feeBuffer = Buffer.alloc(1, fee);
76
- if (feeBuffer.length !== 1) {
77
- throw new Error('Invalid fee');
78
- }
79
- const redeemScriptBuffer = 'redeemScript' in rest ? rest.redeemScript : Buffer.from([]);
80
- if ('timelock' in rest && (rest.timelock < 0 || rest.timelock > 4294967295)) {
81
- throw new Error('Invalid timelock - out of range');
82
- }
83
- // encode the number into a 4-byte buffer
84
- // if timelock is provided, write it into 32-bit little-endian
85
- const timelockBuffer = 'timelock' in rest ? encodeTimelock(rest.timelock) : Buffer.from([]);
86
- const data = Buffer.concat([
87
- exports.CORE_DAO_SATOSHI_PLUS_IDENTIFIER,
88
- versionBuffer,
89
- chainId,
90
- delegator,
91
- validator,
92
- feeBuffer,
93
- redeemScriptBuffer,
94
- timelockBuffer,
95
- ]);
96
- if (data.length > 80) {
97
- throw new Error('OP_RETURN outputs cannot have a length larger than 80 bytes');
98
- }
99
- const payment = utxo_lib_1.payments.embed({
100
- data: [data],
101
- network: chainId.equals(exports.CORE_DAO_TESTNET_CHAIN_ID) ? utxo_lib_1.networks.testnet : utxo_lib_1.networks.bitcoin,
102
- });
103
- if (!payment.output) {
104
- throw new Error('Unable to create OP_RETURN output');
105
- }
106
- return payment.output;
107
- }
108
- exports.createCoreDaoOpReturnOutputScript = createCoreDaoOpReturnOutputScript;
109
- /**
110
- * Parse a CoreDAO OP_RETURN output script into the constituent parts
111
- * @param script
112
- * @returns OpReturnParams
113
- */
114
- function parseCoreDaoOpReturnOutputScript(script) {
115
- if (!script.subarray(0, 1).equals(OP_RETURN_IDENTIFIER)) {
116
- throw new Error('First byte must be an OP_RETURN');
117
- }
118
- const payment = utxo_lib_1.payments.embed({
119
- output: script,
120
- });
121
- const data = payment.data;
122
- if (!data || data.length !== 1) {
123
- throw new Error('Invalid OP_RETURN output');
124
- }
125
- const dataBuffer = data[0];
126
- if (dataBuffer.length > 80) {
127
- throw new Error(`OP_RETURN outputs cannot have a length larger than 80 bytes`);
128
- }
129
- let offset = 0;
130
- // Decode satoshi+ identifier
131
- if (!dataBuffer.subarray(offset, offset + 4).equals(exports.CORE_DAO_SATOSHI_PLUS_IDENTIFIER)) {
132
- throw new Error('Invalid satoshi+ identifier');
133
- }
134
- offset += 4;
135
- // Decode version
136
- const version = dataBuffer[offset];
137
- offset += 1;
138
- // Decode chainId
139
- const chainId = Buffer.from(dataBuffer.subarray(offset, offset + 2));
140
- if (!(chainId.equals(exports.CORE_DAO_TESTNET_CHAIN_ID) || chainId.equals(exports.CORE_DAO_MAINNET_CHAIN_ID))) {
141
- throw new Error(`Invalid ChainID: ${chainId.toString('hex')}. Must be either 0x045b (testnet) or 0x045c (mainnet).`);
142
- }
143
- offset += 2;
144
- // Decode delegator
145
- const delegator = Buffer.from(dataBuffer.subarray(offset, offset + 20));
146
- offset += 20;
147
- // Decode validator
148
- const validator = Buffer.from(dataBuffer.subarray(offset, offset + 20));
149
- offset += 20;
150
- // Decode fee
151
- const fee = dataBuffer[offset];
152
- offset += 1;
153
- const baseParams = { version, chainId, delegator, validator, fee };
154
- // Decode redeemScript or timelock
155
- if (offset === dataBuffer.length - 4) {
156
- return { ...baseParams, timelock: decodeTimelock(dataBuffer.subarray(offset)) };
157
- }
158
- else {
159
- return { ...baseParams, redeemScript: Buffer.from(dataBuffer.subarray(offset)) };
160
- }
161
- }
162
- exports.parseCoreDaoOpReturnOutputScript = parseCoreDaoOpReturnOutputScript;
163
- function toString(params) {
164
- return JSON.stringify({
165
- version: params.version,
166
- chainId: params.chainId.toString('hex'),
167
- delegator: params.delegator.toString('hex'),
168
- validator: params.validator.toString('hex'),
169
- fee: params.fee,
170
- ...('redeemScript' in params ? { redeemScript: params.redeemScript.toString('hex') } : {}),
171
- ...('timelock' in params ? { timelock: params.timelock } : {}),
172
- });
173
- }
174
- exports.toString = toString;
175
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"opReturn.js","sourceRoot":"","sources":["../../../src/coreDao/opReturn.ts"],"names":[],"mappings":"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","sourcesContent":["import { payments, networks } from '@bitgo-beta/utxo-lib';\n\n// Source: https://docs.coredao.org/docs/Learn/products/btc-staking/design\nexport const CORE_DAO_TESTNET_CHAIN_ID = Buffer.from('045b', 'hex');\nexport const CORE_DAO_MAINNET_CHAIN_ID = Buffer.from('045c', 'hex');\nexport const CORE_DAO_SATOSHI_PLUS_IDENTIFIER = Buffer.from('5341542b', 'hex');\n// https://github.com/bitcoin/bitcoin/blob/5961b23898ee7c0af2626c46d5d70e80136578d3/src/script/script.h#L47\nconst OP_RETURN_IDENTIFIER = Buffer.from('6a', 'hex');\n\nexport function encodeTimelock(timelock: number): Buffer {\n  const buff = Buffer.alloc(4);\n  buff.writeUInt32LE(timelock);\n  return buff;\n}\n\nexport function decodeTimelock(buffer: Buffer): number {\n  if (buffer.length !== 4) {\n    throw new Error('Invalid timelock buffer length');\n  }\n  return buffer.readUInt32LE();\n}\n\ntype BaseParams = {\n  version: number;\n  chainId: Buffer;\n  delegator: Buffer;\n  validator: Buffer;\n  fee: number;\n};\n\nexport type OpReturnParams = BaseParams & ({ redeemScript: Buffer } | { timelock: number });\n\n/**\n * Create a CoreDAO OP_RETURN output script\n *\n * @param version Version of the OP_RETURN\n * @param chainId Chain ID\n * @param delegator Delegator address\n * @param validator Validator address\n * @param fee Fee for relayer\n * @param redeemScript Redeem script of the staking output\n * @param timelock Timelock for the staking output\n * @returns Buffer OP_RETURN buffer\n */\nexport function createCoreDaoOpReturnOutputScript({\n  version,\n  chainId,\n  delegator,\n  validator,\n  fee,\n  ...rest\n}: OpReturnParams): Buffer {\n  /**\n   * As of v2, this is the construction of the OP_RETURN:\n   * Source: https://docs.coredao.org/docs/Learn/products/btc-staking/design#op_return-output\n   *\n   * The OP_RETURN output should contain all staking information in order, and be composed in the following format:\n   *\n   * Satoshi Plus Identifier: (SAT+) 4 bytes\n   * Version: (0x01) 1 byte\n   * Chain ID: (0x045b (1115) for Core Testnet and 0x045c (1116) for Core Mainnet) 2 bytes\n   * Delegator: The Core address to receive rewards, 20 bytes\n   * Validator: The Core validator address to stake to, 20 bytes\n   * Fee: Fee for relayer, 1 byte, range [0,255], measured in CORE\n   * (Optional) RedeemScript\n   * (Optional) Timelock: 4 bytes\n   *\n   * Either RedeemScript or Timelock must be available, the purpose is to allow relayer to\n   * obtain the RedeemScript and submit transactions on Core. If a RedeemScript is provided,\n   * relayer will use it directly. Otherwise, relayer will construct the redeem script based\n   * on the timelock and the information in the transaction inputs.\n   *\n   * Note that any length > 80 bytes wont be relayed by nodes and therefore we will throw an error.\n   */\n  if (version < 0 || version > 255) {\n    throw new Error('Invalid version - out of range');\n  }\n  const versionBuffer = Buffer.alloc(1, version);\n\n  if (!(chainId.equals(CORE_DAO_TESTNET_CHAIN_ID) || chainId.equals(CORE_DAO_MAINNET_CHAIN_ID))) {\n    throw new Error('Invalid chain ID');\n  }\n\n  if (delegator.length !== 20) {\n    throw new Error('Invalid delegator address');\n  }\n\n  if (validator.length !== 20) {\n    throw new Error('Invalid validator address');\n  }\n\n  if (fee < 0 || fee > 255) {\n    throw new Error('Invalid fee - out of range');\n  }\n  const feeBuffer = Buffer.alloc(1, fee);\n\n  if (feeBuffer.length !== 1) {\n    throw new Error('Invalid fee');\n  }\n\n  const redeemScriptBuffer = 'redeemScript' in rest ? rest.redeemScript : Buffer.from([]);\n  if ('timelock' in rest && (rest.timelock < 0 || rest.timelock > 4294967295)) {\n    throw new Error('Invalid timelock - out of range');\n  }\n\n  // encode the number into a 4-byte buffer\n  // if timelock is provided, write it into 32-bit little-endian\n  const timelockBuffer = 'timelock' in rest ? encodeTimelock(rest.timelock) : Buffer.from([]);\n  const data = Buffer.concat([\n    CORE_DAO_SATOSHI_PLUS_IDENTIFIER,\n    versionBuffer,\n    chainId,\n    delegator,\n    validator,\n    feeBuffer,\n    redeemScriptBuffer,\n    timelockBuffer,\n  ]);\n  if (data.length > 80) {\n    throw new Error('OP_RETURN outputs cannot have a length larger than 80 bytes');\n  }\n\n  const payment = payments.embed({\n    data: [data],\n    network: chainId.equals(CORE_DAO_TESTNET_CHAIN_ID) ? networks.testnet : networks.bitcoin,\n  });\n  if (!payment.output) {\n    throw new Error('Unable to create OP_RETURN output');\n  }\n\n  return payment.output;\n}\n\n/**\n * Parse a CoreDAO OP_RETURN output script into the constituent parts\n * @param script\n * @returns OpReturnParams\n */\nexport function parseCoreDaoOpReturnOutputScript(script: Buffer): OpReturnParams {\n  if (!script.subarray(0, 1).equals(OP_RETURN_IDENTIFIER)) {\n    throw new Error('First byte must be an OP_RETURN');\n  }\n\n  const payment = payments.embed({\n    output: script,\n  });\n  const data = payment.data;\n  if (!data || data.length !== 1) {\n    throw new Error('Invalid OP_RETURN output');\n  }\n  const dataBuffer = data[0];\n  if (dataBuffer.length > 80) {\n    throw new Error(`OP_RETURN outputs cannot have a length larger than 80 bytes`);\n  }\n  let offset = 0;\n\n  // Decode satoshi+ identifier\n  if (!dataBuffer.subarray(offset, offset + 4).equals(CORE_DAO_SATOSHI_PLUS_IDENTIFIER)) {\n    throw new Error('Invalid satoshi+ identifier');\n  }\n  offset += 4;\n\n  // Decode version\n  const version = dataBuffer[offset];\n  offset += 1;\n\n  // Decode chainId\n  const chainId = Buffer.from(dataBuffer.subarray(offset, offset + 2));\n  if (!(chainId.equals(CORE_DAO_TESTNET_CHAIN_ID) || chainId.equals(CORE_DAO_MAINNET_CHAIN_ID))) {\n    throw new Error(\n      `Invalid ChainID: ${chainId.toString('hex')}. Must be either 0x045b (testnet) or 0x045c (mainnet).`\n    );\n  }\n  offset += 2;\n\n  // Decode delegator\n  const delegator = Buffer.from(dataBuffer.subarray(offset, offset + 20));\n  offset += 20;\n\n  // Decode validator\n  const validator = Buffer.from(dataBuffer.subarray(offset, offset + 20));\n  offset += 20;\n\n  // Decode fee\n  const fee = dataBuffer[offset];\n  offset += 1;\n\n  const baseParams = { version, chainId, delegator, validator, fee };\n\n  // Decode redeemScript or timelock\n  if (offset === dataBuffer.length - 4) {\n    return { ...baseParams, timelock: decodeTimelock(dataBuffer.subarray(offset)) };\n  } else {\n    return { ...baseParams, redeemScript: Buffer.from(dataBuffer.subarray(offset)) };\n  }\n}\n\nexport function toString(params: OpReturnParams): string {\n  return JSON.stringify({\n    version: params.version,\n    chainId: params.chainId.toString('hex'),\n    delegator: params.delegator.toString('hex'),\n    validator: params.validator.toString('hex'),\n    fee: params.fee,\n    ...('redeemScript' in params ? { redeemScript: params.redeemScript.toString('hex') } : {}),\n    ...('timelock' in params ? { timelock: params.timelock } : {}),\n  });\n}\n"]}
@@ -1 +0,0 @@
1
- {"version":3,"file":"transaction.d.ts","sourceRoot":"","sources":["../../../src/coreDao/transaction.ts"],"names":[],"mappings":";;AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AAEpD,OAAO,EAAqC,cAAc,EAAE,MAAM,YAAY,CAAC;AAE/E;;;;;;;GAOG;AACH,wBAAgB,oBAAoB,CAClC,aAAa,EAAE;IACb,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,EAAE,UAAU,CAAC;IACvB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,EACD,cAAc,EAAE,cAAc,GAC7B;IAAE,MAAM,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,EAAE,CAgBtC"}
@@ -1,27 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.createStakingOutputs = void 0;
4
- const opReturn_1 = require("./opReturn");
5
- /**
6
- * Create the staking outputs for a CoreDAO staking transaction. This is the ordering
7
- * in which to add into the transaction.
8
- * @param stakingParams how to create the timelocked stake output
9
- * @param stakingParams.descriptor if stakingParams.index is not provided, then this is assumed to be a `definite` descriptor.
10
- * If stakingParams.index is provided, then this is assumed to be a `derivable` descriptor.
11
- * @param opReturnParams to create the OP_RETURN output
12
- */
13
- function createStakingOutputs(stakingParams, opReturnParams) {
14
- if (stakingParams.descriptor.hasWildcard() && stakingParams.index === undefined) {
15
- throw new Error('Cannot create staking outputs with a wildcard descriptor and no derivation index');
16
- }
17
- const outputScript = Buffer.from(stakingParams.index === undefined
18
- ? stakingParams.descriptor.scriptPubkey()
19
- : stakingParams.descriptor.atDerivationIndex(stakingParams.index).scriptPubkey());
20
- const opReturnScript = (0, opReturn_1.createCoreDaoOpReturnOutputScript)(opReturnParams);
21
- return [
22
- { script: outputScript, amount: stakingParams.amount },
23
- { script: opReturnScript, amount: BigInt(0) },
24
- ];
25
- }
26
- exports.createStakingOutputs = createStakingOutputs;
27
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNhY3Rpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29yZURhby90cmFuc2FjdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFFQSx5Q0FBK0U7QUFFL0U7Ozs7Ozs7R0FPRztBQUNILFNBQWdCLG9CQUFvQixDQUNsQyxhQUlDLEVBQ0QsY0FBOEI7SUFFOUIsSUFBSSxhQUFhLENBQUMsVUFBVSxDQUFDLFdBQVcsRUFBRSxJQUFJLGFBQWEsQ0FBQyxLQUFLLEtBQUssU0FBUyxFQUFFO1FBQy9FLE1BQU0sSUFBSSxLQUFLLENBQUMsa0ZBQWtGLENBQUMsQ0FBQztLQUNyRztJQUVELE1BQU0sWUFBWSxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQzlCLGFBQWEsQ0FBQyxLQUFLLEtBQUssU0FBUztRQUMvQixDQUFDLENBQUMsYUFBYSxDQUFDLFVBQVUsQ0FBQyxZQUFZLEVBQUU7UUFDekMsQ0FBQyxDQUFDLGFBQWEsQ0FBQyxVQUFVLENBQUMsaUJBQWlCLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxDQUFDLFlBQVksRUFBRSxDQUNuRixDQUFDO0lBQ0YsTUFBTSxjQUFjLEdBQUcsSUFBQSw0Q0FBaUMsRUFBQyxjQUFjLENBQUMsQ0FBQztJQUV6RSxPQUFPO1FBQ0wsRUFBRSxNQUFNLEVBQUUsWUFBWSxFQUFFLE1BQU0sRUFBRSxhQUFhLENBQUMsTUFBTSxFQUFFO1FBQ3RELEVBQUUsTUFBTSxFQUFFLGNBQWMsRUFBRSxNQUFNLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFO0tBQzlDLENBQUM7QUFDSixDQUFDO0FBdkJELG9EQXVCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERlc2NyaXB0b3IgfSBmcm9tICdAYml0Z28vd2FzbS1taW5pc2NyaXB0JztcblxuaW1wb3J0IHsgY3JlYXRlQ29yZURhb09wUmV0dXJuT3V0cHV0U2NyaXB0LCBPcFJldHVyblBhcmFtcyB9IGZyb20gJy4vb3BSZXR1cm4nO1xuXG4vKipcbiAqIENyZWF0ZSB0aGUgc3Rha2luZyBvdXRwdXRzIGZvciBhIENvcmVEQU8gc3Rha2luZyB0cmFuc2FjdGlvbi4gVGhpcyBpcyB0aGUgb3JkZXJpbmdcbiAqIGluIHdoaWNoIHRvIGFkZCBpbnRvIHRoZSB0cmFuc2FjdGlvbi5cbiAqIEBwYXJhbSBzdGFraW5nUGFyYW1zIGhvdyB0byBjcmVhdGUgdGhlIHRpbWVsb2NrZWQgc3Rha2Ugb3V0cHV0XG4gKiBAcGFyYW0gc3Rha2luZ1BhcmFtcy5kZXNjcmlwdG9yIGlmIHN0YWtpbmdQYXJhbXMuaW5kZXggaXMgbm90IHByb3ZpZGVkLCB0aGVuIHRoaXMgaXMgYXNzdW1lZCB0byBiZSBhIGBkZWZpbml0ZWAgZGVzY3JpcHRvci5cbiAqIElmIHN0YWtpbmdQYXJhbXMuaW5kZXggaXMgcHJvdmlkZWQsIHRoZW4gdGhpcyBpcyBhc3N1bWVkIHRvIGJlIGEgYGRlcml2YWJsZWAgZGVzY3JpcHRvci5cbiAqIEBwYXJhbSBvcFJldHVyblBhcmFtcyB0byBjcmVhdGUgdGhlIE9QX1JFVFVSTiBvdXRwdXRcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVN0YWtpbmdPdXRwdXRzKFxuICBzdGFraW5nUGFyYW1zOiB7XG4gICAgYW1vdW50OiBiaWdpbnQ7XG4gICAgZGVzY3JpcHRvcjogRGVzY3JpcHRvcjtcbiAgICBpbmRleD86IG51bWJlcjtcbiAgfSxcbiAgb3BSZXR1cm5QYXJhbXM6IE9wUmV0dXJuUGFyYW1zXG4pOiB7IHNjcmlwdDogQnVmZmVyOyBhbW91bnQ6IGJpZ2ludCB9W10ge1xuICBpZiAoc3Rha2luZ1BhcmFtcy5kZXNjcmlwdG9yLmhhc1dpbGRjYXJkKCkgJiYgc3Rha2luZ1BhcmFtcy5pbmRleCA9PT0gdW5kZWZpbmVkKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdDYW5ub3QgY3JlYXRlIHN0YWtpbmcgb3V0cHV0cyB3aXRoIGEgd2lsZGNhcmQgZGVzY3JpcHRvciBhbmQgbm8gZGVyaXZhdGlvbiBpbmRleCcpO1xuICB9XG5cbiAgY29uc3Qgb3V0cHV0U2NyaXB0ID0gQnVmZmVyLmZyb20oXG4gICAgc3Rha2luZ1BhcmFtcy5pbmRleCA9PT0gdW5kZWZpbmVkXG4gICAgICA/IHN0YWtpbmdQYXJhbXMuZGVzY3JpcHRvci5zY3JpcHRQdWJrZXkoKVxuICAgICAgOiBzdGFraW5nUGFyYW1zLmRlc2NyaXB0b3IuYXREZXJpdmF0aW9uSW5kZXgoc3Rha2luZ1BhcmFtcy5pbmRleCkuc2NyaXB0UHVia2V5KClcbiAgKTtcbiAgY29uc3Qgb3BSZXR1cm5TY3JpcHQgPSBjcmVhdGVDb3JlRGFvT3BSZXR1cm5PdXRwdXRTY3JpcHQob3BSZXR1cm5QYXJhbXMpO1xuXG4gIHJldHVybiBbXG4gICAgeyBzY3JpcHQ6IG91dHB1dFNjcmlwdCwgYW1vdW50OiBzdGFraW5nUGFyYW1zLmFtb3VudCB9LFxuICAgIHsgc2NyaXB0OiBvcFJldHVyblNjcmlwdCwgYW1vdW50OiBCaWdJbnQoMCkgfSxcbiAgXTtcbn1cbiJdfQ==
@@ -1,3 +0,0 @@
1
- export * as coreDao from './coreDao';
2
- export * from './transaction';
3
- //# sourceMappingURL=index.d.ts.map
@@ -1,34 +0,0 @@
1
- /// <reference types="node" />
2
- /// <reference types="node" />
3
- import * as utxolib from '@bitgo-beta/utxo-lib';
4
- /**
5
- * Build a staking transaction for a wallet that assumes 2-of-3 multisig for the inputs
6
- *
7
- * Given the inputs and the staking outputs, we will create the PSBT with the desired fee rate.
8
- * We always add the change address as the last output.
9
- *
10
- * @param rootWalletKeys
11
- * @param unspents
12
- * @param createStakingOutputs
13
- * @param changeAddressInfo
14
- * @param feeRateSatKB
15
- * @param network
16
- */
17
- export declare function buildFixedWalletStakingPsbt({ rootWalletKeys, unspents, outputs, changeAddressInfo, feeRateSatKB, network, skipNonWitnessUtxo, dustAmount, }: {
18
- rootWalletKeys: utxolib.bitgo.RootWalletKeys;
19
- unspents: utxolib.bitgo.WalletUnspent<bigint>[];
20
- outputs: {
21
- script: Buffer;
22
- value: bigint;
23
- }[];
24
- changeAddressInfo: {
25
- chain: utxolib.bitgo.ChainCode;
26
- index: number;
27
- address: string;
28
- };
29
- feeRateSatKB: number;
30
- network: utxolib.Network;
31
- skipNonWitnessUtxo?: boolean;
32
- dustAmount?: bigint;
33
- }): utxolib.bitgo.UtxoPsbt;
34
- //# sourceMappingURL=transaction.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"transaction.d.ts","sourceRoot":"","sources":["../../src/transaction.ts"],"names":[],"mappings":";;AAAA,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAGhD;;;;;;;;;;;;GAYG;AACH,wBAAgB,2BAA2B,CAAC,EAC1C,cAAc,EACd,QAAQ,EACR,OAAO,EACP,iBAAiB,EACjB,YAAY,EACZ,OAAO,EACP,kBAAkB,EAClB,UAAsB,GACvB,EAAE;IACD,cAAc,EAAE,OAAO,CAAC,KAAK,CAAC,cAAc,CAAC;IAC7C,QAAQ,EAAE,OAAO,CAAC,KAAK,CAAC,aAAa,CAAC,MAAM,CAAC,EAAE,CAAC;IAChD,OAAO,EAAE;QACP,MAAM,EAAE,MAAM,CAAC;QACf,KAAK,EAAE,MAAM,CAAC;KACf,EAAE,CAAC;IACJ,iBAAiB,EAAE;QACjB,KAAK,EAAE,OAAO,CAAC,KAAK,CAAC,SAAS,CAAC;QAC/B,KAAK,EAAE,MAAM,CAAC;QACd,OAAO,EAAE,MAAM,CAAC;KACjB,CAAC;IACF,YAAY,EAAE,MAAM,CAAC;IACrB,OAAO,EAAE,OAAO,CAAC,OAAO,CAAC;IACzB,kBAAkB,CAAC,EAAE,OAAO,CAAC;IAC7B,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB,GAAG,OAAO,CAAC,KAAK,CAAC,QAAQ,CA0DzB"}
@@ -1,55 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.buildFixedWalletStakingPsbt = void 0;
4
- const utxolib = require("@bitgo-beta/utxo-lib");
5
- const unspents_1 = require("@bitgo-beta/unspents");
6
- /**
7
- * Build a staking transaction for a wallet that assumes 2-of-3 multisig for the inputs
8
- *
9
- * Given the inputs and the staking outputs, we will create the PSBT with the desired fee rate.
10
- * We always add the change address as the last output.
11
- *
12
- * @param rootWalletKeys
13
- * @param unspents
14
- * @param createStakingOutputs
15
- * @param changeAddressInfo
16
- * @param feeRateSatKB
17
- * @param network
18
- */
19
- function buildFixedWalletStakingPsbt({ rootWalletKeys, unspents, outputs, changeAddressInfo, feeRateSatKB, network, skipNonWitnessUtxo, dustAmount = BigInt(0), }) {
20
- if (feeRateSatKB < 1000) {
21
- throw new Error('Fee rate must be at least 1 sat/vbyte');
22
- }
23
- if (unspents.length === 0 || outputs.length === 0) {
24
- throw new Error('Must have at least one input and one output');
25
- }
26
- // Check the change address info
27
- const changeScript = utxolib.bitgo.outputScripts.createOutputScript2of3(rootWalletKeys.deriveForChainAndIndex(changeAddressInfo.chain, changeAddressInfo.index).publicKeys, utxolib.bitgo.scriptTypeForChain(changeAddressInfo.chain), network).scriptPubKey;
28
- if (!changeScript.equals(utxolib.addressFormat.toOutputScriptTryFormats(changeAddressInfo.address, network))) {
29
- throw new Error('Change address info does not match the derived change script');
30
- }
31
- const psbt = utxolib.bitgo.createPsbtForNetwork({ network });
32
- utxolib.bitgo.addXpubsToPsbt(psbt, rootWalletKeys);
33
- const inputAmount = unspents.reduce((sum, unspent) => sum + unspent.value, BigInt(0));
34
- const outputAmount = outputs.reduce((sum, output) => sum + output.value, BigInt(0));
35
- unspents.forEach((unspent) => utxolib.bitgo.addWalletUnspentToPsbt(psbt, unspent, rootWalletKeys, 'user', 'bitgo', {
36
- isReplaceableByFee: true,
37
- skipNonWitnessUtxo,
38
- }));
39
- outputs.forEach((output) => psbt.addOutput(output));
40
- const fee = Math.ceil((unspents_1.Dimensions.fromPsbt(psbt)
41
- .plus(unspents_1.Dimensions.fromOutput({ script: changeScript }))
42
- .getVSize() *
43
- feeRateSatKB) /
44
- 1000);
45
- const changeAmount = inputAmount - (outputAmount + BigInt(fee));
46
- if (changeAmount < BigInt(0)) {
47
- throw new Error(`Input amount ${inputAmount.toString()} cannot cover the staking amount ${outputAmount} and the fee: ${fee}`);
48
- }
49
- if (changeAmount > dustAmount) {
50
- utxolib.bitgo.addWalletOutputToPsbt(psbt, rootWalletKeys, changeAddressInfo.chain, changeAddressInfo.index, changeAmount);
51
- }
52
- return psbt;
53
- }
54
- exports.buildFixedWalletStakingPsbt = buildFixedWalletStakingPsbt;
55
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNhY3Rpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdHJhbnNhY3Rpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsZ0RBQWdEO0FBQ2hELG1EQUFrRDtBQUVsRDs7Ozs7Ozs7Ozs7O0dBWUc7QUFDSCxTQUFnQiwyQkFBMkIsQ0FBQyxFQUMxQyxjQUFjLEVBQ2QsUUFBUSxFQUNSLE9BQU8sRUFDUCxpQkFBaUIsRUFDakIsWUFBWSxFQUNaLE9BQU8sRUFDUCxrQkFBa0IsRUFDbEIsVUFBVSxHQUFHLE1BQU0sQ0FBQyxDQUFDLENBQUMsR0FpQnZCO0lBQ0MsSUFBSSxZQUFZLEdBQUcsSUFBSSxFQUFFO1FBQ3ZCLE1BQU0sSUFBSSxLQUFLLENBQUMsdUNBQXVDLENBQUMsQ0FBQztLQUMxRDtJQUNELElBQUksUUFBUSxDQUFDLE1BQU0sS0FBSyxDQUFDLElBQUksT0FBTyxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUU7UUFDakQsTUFBTSxJQUFJLEtBQUssQ0FBQyw2Q0FBNkMsQ0FBQyxDQUFDO0tBQ2hFO0lBRUQsZ0NBQWdDO0lBQ2hDLE1BQU0sWUFBWSxHQUFHLE9BQU8sQ0FBQyxLQUFLLENBQUMsYUFBYSxDQUFDLHNCQUFzQixDQUNyRSxjQUFjLENBQUMsc0JBQXNCLENBQUMsaUJBQWlCLENBQUMsS0FBSyxFQUFFLGlCQUFpQixDQUFDLEtBQUssQ0FBQyxDQUFDLFVBQVUsRUFDbEcsT0FBTyxDQUFDLEtBQUssQ0FBQyxrQkFBa0IsQ0FBQyxpQkFBaUIsQ0FBQyxLQUFLLENBQUMsRUFDekQsT0FBTyxDQUNSLENBQUMsWUFBWSxDQUFDO0lBQ2YsSUFBSSxDQUFDLFlBQVksQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQyx3QkFBd0IsQ0FBQyxpQkFBaUIsQ0FBQyxPQUFPLEVBQUUsT0FBTyxDQUFDLENBQUMsRUFBRTtRQUM1RyxNQUFNLElBQUksS0FBSyxDQUFDLDhEQUE4RCxDQUFDLENBQUM7S0FDakY7SUFFRCxNQUFNLElBQUksR0FBRyxPQUFPLENBQUMsS0FBSyxDQUFDLG9CQUFvQixDQUFDLEVBQUUsT0FBTyxFQUFFLENBQUMsQ0FBQztJQUM3RCxPQUFPLENBQUMsS0FBSyxDQUFDLGNBQWMsQ0FBQyxJQUFJLEVBQUUsY0FBYyxDQUFDLENBQUM7SUFFbkQsTUFBTSxXQUFXLEdBQUcsUUFBUSxDQUFDLE1BQU0sQ0FBQyxDQUFDLEdBQUcsRUFBRSxPQUFPLEVBQUUsRUFBRSxDQUFDLEdBQUcsR0FBRyxPQUFPLENBQUMsS0FBSyxFQUFFLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ3RGLE1BQU0sWUFBWSxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQyxHQUFHLEVBQUUsTUFBTSxFQUFFLEVBQUUsQ0FBQyxHQUFHLEdBQUcsTUFBTSxDQUFDLEtBQUssRUFBRSxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUVwRixRQUFRLENBQUMsT0FBTyxDQUFDLENBQUMsT0FBTyxFQUFFLEVBQUUsQ0FDM0IsT0FBTyxDQUFDLEtBQUssQ0FBQyxzQkFBc0IsQ0FBQyxJQUFJLEVBQUUsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLEVBQUUsT0FBTyxFQUFFO1FBQ25GLGtCQUFrQixFQUFFLElBQUk7UUFDeEIsa0JBQWtCO0tBQ25CLENBQUMsQ0FDSCxDQUFDO0lBQ0YsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDLE1BQU0sRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDO0lBRXBELE1BQU0sR0FBRyxHQUFHLElBQUksQ0FBQyxJQUFJLENBQ25CLENBQUMscUJBQVUsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDO1NBQ3ZCLElBQUksQ0FBQyxxQkFBVSxDQUFDLFVBQVUsQ0FBQyxFQUFFLE1BQU0sRUFBRSxZQUFZLEVBQUUsQ0FBQyxDQUFDO1NBQ3JELFFBQVEsRUFBRTtRQUNYLFlBQVksQ0FBQztRQUNiLElBQUksQ0FDUCxDQUFDO0lBRUYsTUFBTSxZQUFZLEdBQUcsV0FBVyxHQUFHLENBQUMsWUFBWSxHQUFHLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDO0lBQ2hFLElBQUksWUFBWSxHQUFHLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRTtRQUM1QixNQUFNLElBQUksS0FBSyxDQUNiLGdCQUFnQixXQUFXLENBQUMsUUFBUSxFQUFFLG9DQUFvQyxZQUFZLGtCQUFrQixHQUFHLEVBQUUsQ0FDOUcsQ0FBQztLQUNIO0lBRUQsSUFBSSxZQUFZLEdBQUcsVUFBVSxFQUFFO1FBQzdCLE9BQU8sQ0FBQyxLQUFLLENBQUMscUJBQXFCLENBQ2pDLElBQUksRUFDSixjQUFjLEVBQ2QsaUJBQWlCLENBQUMsS0FBSyxFQUN2QixpQkFBaUIsQ0FBQyxLQUFLLEVBQ3ZCLFlBQVksQ0FDYixDQUFDO0tBQ0g7SUFFRCxPQUFPLElBQUksQ0FBQztBQUNkLENBQUM7QUFuRkQsa0VBbUZDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgdXR4b2xpYiBmcm9tICdAYml0Z28tYmV0YS91dHhvLWxpYic7XG5pbXBvcnQgeyBEaW1lbnNpb25zIH0gZnJvbSAnQGJpdGdvLWJldGEvdW5zcGVudHMnO1xuXG4vKipcbiAqIEJ1aWxkIGEgc3Rha2luZyB0cmFuc2FjdGlvbiBmb3IgYSB3YWxsZXQgdGhhdCBhc3N1bWVzIDItb2YtMyBtdWx0aXNpZyBmb3IgdGhlIGlucHV0c1xuICpcbiAqIEdpdmVuIHRoZSBpbnB1dHMgYW5kIHRoZSBzdGFraW5nIG91dHB1dHMsIHdlIHdpbGwgY3JlYXRlIHRoZSBQU0JUIHdpdGggdGhlIGRlc2lyZWQgZmVlIHJhdGUuXG4gKiBXZSBhbHdheXMgYWRkIHRoZSBjaGFuZ2UgYWRkcmVzcyBhcyB0aGUgbGFzdCBvdXRwdXQuXG4gKlxuICogQHBhcmFtIHJvb3RXYWxsZXRLZXlzXG4gKiBAcGFyYW0gdW5zcGVudHNcbiAqIEBwYXJhbSBjcmVhdGVTdGFraW5nT3V0cHV0c1xuICogQHBhcmFtIGNoYW5nZUFkZHJlc3NJbmZvXG4gKiBAcGFyYW0gZmVlUmF0ZVNhdEtCXG4gKiBAcGFyYW0gbmV0d29ya1xuICovXG5leHBvcnQgZnVuY3Rpb24gYnVpbGRGaXhlZFdhbGxldFN0YWtpbmdQc2J0KHtcbiAgcm9vdFdhbGxldEtleXMsXG4gIHVuc3BlbnRzLFxuICBvdXRwdXRzLFxuICBjaGFuZ2VBZGRyZXNzSW5mbyxcbiAgZmVlUmF0ZVNhdEtCLFxuICBuZXR3b3JrLFxuICBza2lwTm9uV2l0bmVzc1V0eG8sXG4gIGR1c3RBbW91bnQgPSBCaWdJbnQoMCksXG59OiB7XG4gIHJvb3RXYWxsZXRLZXlzOiB1dHhvbGliLmJpdGdvLlJvb3RXYWxsZXRLZXlzO1xuICB1bnNwZW50czogdXR4b2xpYi5iaXRnby5XYWxsZXRVbnNwZW50PGJpZ2ludD5bXTtcbiAgb3V0cHV0czoge1xuICAgIHNjcmlwdDogQnVmZmVyO1xuICAgIHZhbHVlOiBiaWdpbnQ7XG4gIH1bXTtcbiAgY2hhbmdlQWRkcmVzc0luZm86IHtcbiAgICBjaGFpbjogdXR4b2xpYi5iaXRnby5DaGFpbkNvZGU7XG4gICAgaW5kZXg6IG51bWJlcjtcbiAgICBhZGRyZXNzOiBzdHJpbmc7XG4gIH07XG4gIGZlZVJhdGVTYXRLQjogbnVtYmVyO1xuICBuZXR3b3JrOiB1dHhvbGliLk5ldHdvcms7XG4gIHNraXBOb25XaXRuZXNzVXR4bz86IGJvb2xlYW47XG4gIGR1c3RBbW91bnQ/OiBiaWdpbnQ7XG59KTogdXR4b2xpYi5iaXRnby5VdHhvUHNidCB7XG4gIGlmIChmZWVSYXRlU2F0S0IgPCAxMDAwKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdGZWUgcmF0ZSBtdXN0IGJlIGF0IGxlYXN0IDEgc2F0L3ZieXRlJyk7XG4gIH1cbiAgaWYgKHVuc3BlbnRzLmxlbmd0aCA9PT0gMCB8fCBvdXRwdXRzLmxlbmd0aCA9PT0gMCkge1xuICAgIHRocm93IG5ldyBFcnJvcignTXVzdCBoYXZlIGF0IGxlYXN0IG9uZSBpbnB1dCBhbmQgb25lIG91dHB1dCcpO1xuICB9XG5cbiAgLy8gQ2hlY2sgdGhlIGNoYW5nZSBhZGRyZXNzIGluZm9cbiAgY29uc3QgY2hhbmdlU2NyaXB0ID0gdXR4b2xpYi5iaXRnby5vdXRwdXRTY3JpcHRzLmNyZWF0ZU91dHB1dFNjcmlwdDJvZjMoXG4gICAgcm9vdFdhbGxldEtleXMuZGVyaXZlRm9yQ2hhaW5BbmRJbmRleChjaGFuZ2VBZGRyZXNzSW5mby5jaGFpbiwgY2hhbmdlQWRkcmVzc0luZm8uaW5kZXgpLnB1YmxpY0tleXMsXG4gICAgdXR4b2xpYi5iaXRnby5zY3JpcHRUeXBlRm9yQ2hhaW4oY2hhbmdlQWRkcmVzc0luZm8uY2hhaW4pLFxuICAgIG5ldHdvcmtcbiAgKS5zY3JpcHRQdWJLZXk7XG4gIGlmICghY2hhbmdlU2NyaXB0LmVxdWFscyh1dHhvbGliLmFkZHJlc3NGb3JtYXQudG9PdXRwdXRTY3JpcHRUcnlGb3JtYXRzKGNoYW5nZUFkZHJlc3NJbmZvLmFkZHJlc3MsIG5ldHdvcmspKSkge1xuICAgIHRocm93IG5ldyBFcnJvcignQ2hhbmdlIGFkZHJlc3MgaW5mbyBkb2VzIG5vdCBtYXRjaCB0aGUgZGVyaXZlZCBjaGFuZ2Ugc2NyaXB0Jyk7XG4gIH1cblxuICBjb25zdCBwc2J0ID0gdXR4b2xpYi5iaXRnby5jcmVhdGVQc2J0Rm9yTmV0d29yayh7IG5ldHdvcmsgfSk7XG4gIHV0eG9saWIuYml0Z28uYWRkWHB1YnNUb1BzYnQocHNidCwgcm9vdFdhbGxldEtleXMpO1xuXG4gIGNvbnN0IGlucHV0QW1vdW50ID0gdW5zcGVudHMucmVkdWNlKChzdW0sIHVuc3BlbnQpID0+IHN1bSArIHVuc3BlbnQudmFsdWUsIEJpZ0ludCgwKSk7XG4gIGNvbnN0IG91dHB1dEFtb3VudCA9IG91dHB1dHMucmVkdWNlKChzdW0sIG91dHB1dCkgPT4gc3VtICsgb3V0cHV0LnZhbHVlLCBCaWdJbnQoMCkpO1xuXG4gIHVuc3BlbnRzLmZvckVhY2goKHVuc3BlbnQpID0+XG4gICAgdXR4b2xpYi5iaXRnby5hZGRXYWxsZXRVbnNwZW50VG9Qc2J0KHBzYnQsIHVuc3BlbnQsIHJvb3RXYWxsZXRLZXlzLCAndXNlcicsICdiaXRnbycsIHtcbiAgICAgIGlzUmVwbGFjZWFibGVCeUZlZTogdHJ1ZSxcbiAgICAgIHNraXBOb25XaXRuZXNzVXR4byxcbiAgICB9KVxuICApO1xuICBvdXRwdXRzLmZvckVhY2goKG91dHB1dCkgPT4gcHNidC5hZGRPdXRwdXQob3V0cHV0KSk7XG5cbiAgY29uc3QgZmVlID0gTWF0aC5jZWlsKFxuICAgIChEaW1lbnNpb25zLmZyb21Qc2J0KHBzYnQpXG4gICAgICAucGx1cyhEaW1lbnNpb25zLmZyb21PdXRwdXQoeyBzY3JpcHQ6IGNoYW5nZVNjcmlwdCB9KSlcbiAgICAgIC5nZXRWU2l6ZSgpICpcbiAgICAgIGZlZVJhdGVTYXRLQikgL1xuICAgICAgMTAwMFxuICApO1xuXG4gIGNvbnN0IGNoYW5nZUFtb3VudCA9IGlucHV0QW1vdW50IC0gKG91dHB1dEFtb3VudCArIEJpZ0ludChmZWUpKTtcbiAgaWYgKGNoYW5nZUFtb3VudCA8IEJpZ0ludCgwKSkge1xuICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgIGBJbnB1dCBhbW91bnQgJHtpbnB1dEFtb3VudC50b1N0cmluZygpfSBjYW5ub3QgY292ZXIgdGhlIHN0YWtpbmcgYW1vdW50ICR7b3V0cHV0QW1vdW50fSBhbmQgIHRoZSBmZWU6ICR7ZmVlfWBcbiAgICApO1xuICB9XG5cbiAgaWYgKGNoYW5nZUFtb3VudCA+IGR1c3RBbW91bnQpIHtcbiAgICB1dHhvbGliLmJpdGdvLmFkZFdhbGxldE91dHB1dFRvUHNidChcbiAgICAgIHBzYnQsXG4gICAgICByb290V2FsbGV0S2V5cyxcbiAgICAgIGNoYW5nZUFkZHJlc3NJbmZvLmNoYWluLFxuICAgICAgY2hhbmdlQWRkcmVzc0luZm8uaW5kZXgsXG4gICAgICBjaGFuZ2VBbW91bnRcbiAgICApO1xuICB9XG5cbiAgcmV0dXJuIHBzYnQ7XG59XG4iXX0=
File without changes
File without changes