@bitgo-beta/utxo-staking 1.1.1-beta.34 → 1.1.1-beta.340
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.
- package/dist/src/babylon/delegationMessage.d.ts +38 -0
- package/dist/src/babylon/delegationMessage.d.ts.map +1 -0
- package/dist/src/babylon/delegationMessage.js +261 -0
- package/dist/src/babylon/descriptor.d.ts +29 -0
- package/dist/src/babylon/descriptor.d.ts.map +1 -0
- package/dist/src/babylon/descriptor.js +78 -0
- package/dist/src/babylon/index.d.ts +5 -0
- package/dist/src/babylon/index.d.ts.map +1 -0
- package/dist/src/babylon/index.js +48 -0
- package/dist/src/babylon/network.d.ts +7 -0
- package/dist/src/babylon/network.d.ts.map +1 -0
- package/dist/src/babylon/network.js +66 -0
- package/dist/src/babylon/params.mainnet.json +118 -0
- package/dist/src/babylon/params.testnet.json +205 -0
- package/dist/src/babylon/stakingManager.d.ts +6 -0
- package/dist/src/babylon/stakingManager.d.ts.map +1 -0
- package/dist/src/babylon/stakingManager.js +116 -0
- package/dist/src/babylon/stakingParams.d.ts +39 -0
- package/dist/src/babylon/stakingParams.d.ts.map +1 -0
- package/dist/src/babylon/stakingParams.js +131 -0
- package/dist/src/coreDao/descriptor.d.ts +4 -2
- package/dist/src/coreDao/descriptor.d.ts.map +1 -1
- package/dist/src/coreDao/descriptor.js +11 -3
- package/dist/src/coreDao/opReturn.d.ts +1 -0
- package/dist/src/coreDao/opReturn.d.ts.map +1 -1
- package/dist/src/coreDao/opReturn.js +5 -2
- package/dist/src/coreDao/transaction.d.ts +15 -6
- package/dist/src/coreDao/transaction.d.ts.map +1 -1
- package/dist/src/coreDao/transaction.js +12 -4
- package/dist/src/index.d.ts +1 -0
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +26 -3
- package/dist/src/transaction.d.ts.map +1 -1
- package/dist/src/transaction.js +37 -2
- package/package.json +20 -7
- package/.eslintignore +0 -5
- package/.mocharc.yml +0 -8
- package/CHANGELOG.md +0 -43
|
@@ -0,0 +1,131 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
36
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
37
|
+
};
|
|
38
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
|
+
exports.testnetFinalityProvider0 = exports.testnetStakingParams = exports.mainnetStakingParams = exports.getBabylonParamByBtcHeight = exports.getBabylonParamByVersion = void 0;
|
|
40
|
+
exports.toVersionedParams = toVersionedParams;
|
|
41
|
+
exports.getStakingParams = getStakingParams;
|
|
42
|
+
exports.getDescriptorBuilderForParams = getDescriptorBuilderForParams;
|
|
43
|
+
exports.getDescriptorProviderForStakingParams = getDescriptorProviderForStakingParams;
|
|
44
|
+
exports.getTestnetDescriptorBuilder = getTestnetDescriptorBuilder;
|
|
45
|
+
const t = __importStar(require("io-ts"));
|
|
46
|
+
const tt = __importStar(require("io-ts-types"));
|
|
47
|
+
const Either_1 = require("fp-ts/Either");
|
|
48
|
+
const PathReporter_1 = require("io-ts/lib/PathReporter");
|
|
49
|
+
const babylonlabs_io_btc_staking_ts_1 = require("@bitgo-beta/babylonlabs-io-btc-staking-ts");
|
|
50
|
+
var babylonlabs_io_btc_staking_ts_2 = require("@bitgo-beta/babylonlabs-io-btc-staking-ts");
|
|
51
|
+
Object.defineProperty(exports, "getBabylonParamByVersion", { enumerable: true, get: function () { return babylonlabs_io_btc_staking_ts_2.getBabylonParamByVersion; } });
|
|
52
|
+
Object.defineProperty(exports, "getBabylonParamByBtcHeight", { enumerable: true, get: function () { return babylonlabs_io_btc_staking_ts_2.getBabylonParamByBtcHeight; } });
|
|
53
|
+
const descriptor_1 = require("./descriptor");
|
|
54
|
+
const params_mainnet_json_1 = __importDefault(require("./params.mainnet.json"));
|
|
55
|
+
const params_testnet_json_1 = __importDefault(require("./params.testnet.json"));
|
|
56
|
+
const network_1 = require("./network");
|
|
57
|
+
const BabylonParamsJSON = t.type({
|
|
58
|
+
covenant_pks: t.array(t.string),
|
|
59
|
+
covenant_quorum: t.number,
|
|
60
|
+
min_staking_value_sat: tt.NumberFromString,
|
|
61
|
+
max_staking_value_sat: tt.NumberFromString,
|
|
62
|
+
min_staking_time_blocks: t.number,
|
|
63
|
+
max_staking_time_blocks: t.number,
|
|
64
|
+
slashing_pk_script: t.string,
|
|
65
|
+
min_slashing_tx_fee_sat: tt.NumberFromString,
|
|
66
|
+
slashing_rate: t.string,
|
|
67
|
+
unbonding_time_blocks: t.number,
|
|
68
|
+
unbonding_fee_sat: tt.NumberFromString,
|
|
69
|
+
min_commission_rate: tt.NumberFromString,
|
|
70
|
+
delegation_creation_base_gas_fee: tt.NumberFromString,
|
|
71
|
+
allow_list_expiration_height: tt.NumberFromString,
|
|
72
|
+
btc_activation_height: t.number,
|
|
73
|
+
});
|
|
74
|
+
function toVersionedParams(ps) {
|
|
75
|
+
return ps.map((p, version) => ({
|
|
76
|
+
version,
|
|
77
|
+
btcActivationHeight: p.btc_activation_height,
|
|
78
|
+
covenantNoCoordPks: p.covenant_pks,
|
|
79
|
+
covenantQuorum: p.covenant_quorum,
|
|
80
|
+
unbondingTime: p.unbonding_time_blocks,
|
|
81
|
+
unbondingFeeSat: p.unbonding_fee_sat,
|
|
82
|
+
maxStakingAmountSat: p.max_staking_value_sat,
|
|
83
|
+
minStakingAmountSat: p.min_staking_value_sat,
|
|
84
|
+
maxStakingTimeBlocks: p.max_staking_time_blocks,
|
|
85
|
+
minStakingTimeBlocks: p.min_staking_time_blocks,
|
|
86
|
+
slashing: {
|
|
87
|
+
slashingPkScriptHex: Buffer.from(p.slashing_pk_script, 'base64').toString('hex'),
|
|
88
|
+
slashingRate: parseFloat(p.slashing_rate),
|
|
89
|
+
minSlashingTxFeeSat: p.min_slashing_tx_fee_sat,
|
|
90
|
+
},
|
|
91
|
+
}));
|
|
92
|
+
}
|
|
93
|
+
function toVersionedParamsFromJson(jsonParams) {
|
|
94
|
+
return toVersionedParams(jsonParams.map((p) => {
|
|
95
|
+
const result = t.type({ params: BabylonParamsJSON }).decode(p);
|
|
96
|
+
if ((0, Either_1.isLeft)(result)) {
|
|
97
|
+
const msg = PathReporter_1.PathReporter.report(result).join('\n');
|
|
98
|
+
throw new Error(`Invalid testnet params: ${msg}`);
|
|
99
|
+
}
|
|
100
|
+
return result.right.params;
|
|
101
|
+
}));
|
|
102
|
+
}
|
|
103
|
+
exports.mainnetStakingParams = Object.freeze(toVersionedParamsFromJson(params_mainnet_json_1.default));
|
|
104
|
+
exports.testnetStakingParams = Object.freeze(toVersionedParamsFromJson(params_testnet_json_1.default));
|
|
105
|
+
function getStakingParams(network) {
|
|
106
|
+
switch ((0, network_1.toBabylonNetwork)(network)) {
|
|
107
|
+
case 'mainnet':
|
|
108
|
+
return [...exports.mainnetStakingParams];
|
|
109
|
+
case 'testnet':
|
|
110
|
+
return [...exports.testnetStakingParams];
|
|
111
|
+
default:
|
|
112
|
+
throw new Error('Unsupported network');
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
// Source: https://btcstaking.testnet.babylonlabs.io/ "Babylon Foundation 0"
|
|
116
|
+
exports.testnetFinalityProvider0 = Buffer.from('d23c2c25e1fcf8fd1c21b9a402c19e2e309e531e45e92fb1e9805b6056b0cc76', 'hex');
|
|
117
|
+
function getDescriptorBuilderForParams(userKey, finalityProviderKeys, stakingTimelock, params) {
|
|
118
|
+
if (!Buffer.isBuffer(userKey)) {
|
|
119
|
+
userKey = userKey.publicKey;
|
|
120
|
+
}
|
|
121
|
+
return new descriptor_1.BabylonDescriptorBuilder(userKey, finalityProviderKeys, params.covenantNoCoordPks.map((pk) => Buffer.from(pk, 'hex')), params.covenantQuorum, stakingTimelock, params.unbondingTime);
|
|
122
|
+
}
|
|
123
|
+
function getDescriptorProviderForStakingParams(stakerBtcInfo, stakingInput, stakingParams) {
|
|
124
|
+
const userKey = Buffer.from(stakerBtcInfo.publicKeyNoCoordHex, 'hex');
|
|
125
|
+
const finalityProviderKey = Buffer.from(stakingInput.finalityProviderPkNoCoordHex, 'hex');
|
|
126
|
+
return getDescriptorBuilderForParams(userKey, [finalityProviderKey], stakingInput.stakingTimelock, stakingParams);
|
|
127
|
+
}
|
|
128
|
+
function getTestnetDescriptorBuilder(userKey, { finalityProviderKeys = [exports.testnetFinalityProvider0], params = (0, babylonlabs_io_btc_staking_ts_1.getBabylonParamByVersion)(5, getStakingParams('testnet')), stakingTimelock = params.minStakingTimeBlocks, } = {}) {
|
|
129
|
+
return getDescriptorBuilderForParams(userKey, finalityProviderKeys, stakingTimelock, params);
|
|
130
|
+
}
|
|
131
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stakingParams.js","sourceRoot":"","sources":["../../../src/babylon/stakingParams.ts"],"names":[],"mappings":"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","sourcesContent":["import * as t from 'io-ts';\nimport * as tt from 'io-ts-types';\nimport { isLeft } from 'fp-ts/Either';\nimport { PathReporter } from 'io-ts/lib/PathReporter';\nimport * as utxolib from '@bitgo-beta/utxo-lib';\nimport {\n  getBabylonParamByVersion,\n  StakerInfo,\n  StakingInputs,\n  StakingParams,\n  VersionedStakingParams,\n} from '@bitgo-beta/babylonlabs-io-btc-staking-ts';\nexport { getBabylonParamByVersion, getBabylonParamByBtcHeight } from '@bitgo-beta/babylonlabs-io-btc-staking-ts';\n\nimport { BabylonDescriptorBuilder } from './descriptor';\nimport jsonMainnetParams from './params.mainnet.json';\nimport jsonTestnetParams from './params.testnet.json';\nimport { BabylonNetworkLike, toBabylonNetwork } from './network';\n\nconst BabylonParamsJSON = t.type({\n  covenant_pks: t.array(t.string),\n  covenant_quorum: t.number,\n  min_staking_value_sat: tt.NumberFromString,\n  max_staking_value_sat: tt.NumberFromString,\n  min_staking_time_blocks: t.number,\n  max_staking_time_blocks: t.number,\n  slashing_pk_script: t.string,\n  min_slashing_tx_fee_sat: tt.NumberFromString,\n  slashing_rate: t.string,\n  unbonding_time_blocks: t.number,\n  unbonding_fee_sat: tt.NumberFromString,\n  min_commission_rate: tt.NumberFromString,\n  delegation_creation_base_gas_fee: tt.NumberFromString,\n  allow_list_expiration_height: tt.NumberFromString,\n  btc_activation_height: t.number,\n});\n\ntype BabylonParamsJSON = t.TypeOf<typeof BabylonParamsJSON>;\n\nexport function toVersionedParams(ps: BabylonParamsJSON[]): VersionedStakingParams[] {\n  return ps.map((p, version) => ({\n    version,\n    btcActivationHeight: p.btc_activation_height,\n    covenantNoCoordPks: p.covenant_pks,\n    covenantQuorum: p.covenant_quorum,\n    unbondingTime: p.unbonding_time_blocks,\n    unbondingFeeSat: p.unbonding_fee_sat,\n    maxStakingAmountSat: p.max_staking_value_sat,\n    minStakingAmountSat: p.min_staking_value_sat,\n    maxStakingTimeBlocks: p.max_staking_time_blocks,\n    minStakingTimeBlocks: p.min_staking_time_blocks,\n    slashing: {\n      slashingPkScriptHex: Buffer.from(p.slashing_pk_script, 'base64').toString('hex'),\n      slashingRate: parseFloat(p.slashing_rate),\n      minSlashingTxFeeSat: p.min_slashing_tx_fee_sat,\n    },\n  }));\n}\n\nfunction toVersionedParamsFromJson(jsonParams: unknown[]): VersionedStakingParams[] {\n  return toVersionedParams(\n    jsonParams.map((p): BabylonParamsJSON => {\n      const result = t.type({ params: BabylonParamsJSON }).decode(p);\n      if (isLeft(result)) {\n        const msg = PathReporter.report(result).join('\\n');\n        throw new Error(`Invalid testnet params: ${msg}`);\n      }\n      return result.right.params;\n    })\n  );\n}\n\nexport const mainnetStakingParams: readonly VersionedStakingParams[] = Object.freeze(\n  toVersionedParamsFromJson(jsonMainnetParams)\n);\n\nexport const testnetStakingParams: readonly VersionedStakingParams[] = Object.freeze(\n  toVersionedParamsFromJson(jsonTestnetParams)\n);\n\nexport function getStakingParams(network: BabylonNetworkLike): VersionedStakingParams[] {\n  switch (toBabylonNetwork(network)) {\n    case 'mainnet':\n      return [...mainnetStakingParams];\n    case 'testnet':\n      return [...testnetStakingParams];\n    default:\n      throw new Error('Unsupported network');\n  }\n}\n\n// Source: https://btcstaking.testnet.babylonlabs.io/ \"Babylon Foundation 0\"\nexport const testnetFinalityProvider0 = Buffer.from(\n  'd23c2c25e1fcf8fd1c21b9a402c19e2e309e531e45e92fb1e9805b6056b0cc76',\n  'hex'\n);\n\ntype DescriptorStakingParams = Pick<\n  StakingParams,\n  'covenantNoCoordPks' | 'covenantQuorum' | 'minStakingTimeBlocks' | 'unbondingTime'\n>;\n\nexport function getDescriptorBuilderForParams(\n  userKey: utxolib.BIP32Interface | utxolib.ECPairInterface | Buffer,\n  finalityProviderKeys: Buffer[],\n  stakingTimelock: number,\n  params: DescriptorStakingParams\n): BabylonDescriptorBuilder {\n  if (!Buffer.isBuffer(userKey)) {\n    userKey = userKey.publicKey;\n  }\n  return new BabylonDescriptorBuilder(\n    userKey,\n    finalityProviderKeys,\n    params.covenantNoCoordPks.map((pk) => Buffer.from(pk, 'hex')),\n    params.covenantQuorum,\n    stakingTimelock,\n    params.unbondingTime\n  );\n}\n\nexport function getDescriptorProviderForStakingParams(\n  stakerBtcInfo: Pick<StakerInfo, 'publicKeyNoCoordHex'>,\n  stakingInput: StakingInputs,\n  stakingParams: DescriptorStakingParams\n): BabylonDescriptorBuilder {\n  const userKey = Buffer.from(stakerBtcInfo.publicKeyNoCoordHex, 'hex');\n  const finalityProviderKey = Buffer.from(stakingInput.finalityProviderPkNoCoordHex, 'hex');\n  return getDescriptorBuilderForParams(userKey, [finalityProviderKey], stakingInput.stakingTimelock, stakingParams);\n}\n\nexport function getTestnetDescriptorBuilder(\n  userKey: utxolib.BIP32Interface | utxolib.ECPairInterface | Buffer,\n  {\n    finalityProviderKeys = [testnetFinalityProvider0],\n    params = getBabylonParamByVersion(5, getStakingParams('testnet')),\n    stakingTimelock = params.minStakingTimeBlocks,\n  }: {\n    finalityProviderKeys?: Buffer[];\n    params?: StakingParams;\n    stakingTimelock?: number;\n  } = {}\n): BabylonDescriptorBuilder {\n  return getDescriptorBuilderForParams(userKey, finalityProviderKeys, stakingTimelock, params);\n}\n"]}
|
|
@@ -1,8 +1,10 @@
|
|
|
1
1
|
import { BIP32Interface } from '@bitgo-beta/utxo-lib';
|
|
2
2
|
/**
|
|
3
|
-
* Script type for a descriptor.
|
|
3
|
+
* Script type for a descriptor.
|
|
4
|
+
*
|
|
5
|
+
* See https://docs.coredao.org/docs/Learn/products/btc-staking/design#p2shp2wsh-output
|
|
4
6
|
*/
|
|
5
|
-
export type ScriptType = 'sh' | 'sh-wsh';
|
|
7
|
+
export type ScriptType = 'sh' | 'sh-wsh' | 'wsh';
|
|
6
8
|
/**
|
|
7
9
|
* Create a multi-sig descriptor to produce a coredao staking address
|
|
8
10
|
* @param scriptType segwit or legacy
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"descriptor.d.ts","sourceRoot":"","sources":["../../../src/coreDao/descriptor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;
|
|
1
|
+
{"version":3,"file":"descriptor.d.ts","sourceRoot":"","sources":["../../../src/coreDao/descriptor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAGtD;;;;GAIG;AACH,MAAM,MAAM,UAAU,GAAG,IAAI,GAAG,QAAQ,GAAG,KAAK,CAAC;AASjD;;;;;;;;GAQG;AACH,wBAAgB,wBAAwB,CACtC,UAAU,EAAE,UAAU,EACtB,QAAQ,EAAE,MAAM,EAChB,CAAC,EAAE,MAAM,EACT,WAAW,EAAE,CAAC,cAAc,GAAG,MAAM,CAAC,EAAE,EACxC,QAAQ,UAAO,GACd,MAAM,CAmBR"}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.createMultiSigDescriptor = createMultiSigDescriptor;
|
|
4
|
+
const wasm_miniscript_1 = require("@bitgo/wasm-miniscript");
|
|
4
5
|
function asDescriptorKey(key, neutered) {
|
|
5
6
|
if (Buffer.isBuffer(key)) {
|
|
6
7
|
return key.toString('hex');
|
|
@@ -24,7 +25,14 @@ function createMultiSigDescriptor(scriptType, locktime, m, orderedKeys, neutered
|
|
|
24
25
|
throw new Error(`locktime (${locktime}) must be greater than 0`);
|
|
25
26
|
}
|
|
26
27
|
const keys = orderedKeys.map((key) => asDescriptorKey(key, neutered));
|
|
27
|
-
const inner =
|
|
28
|
-
|
|
28
|
+
const inner = { and_v: [{ 'r:after': locktime }, { multi: [m, ...keys] }] };
|
|
29
|
+
switch (scriptType) {
|
|
30
|
+
case 'sh':
|
|
31
|
+
return wasm_miniscript_1.ast.formatNode({ sh: inner });
|
|
32
|
+
case 'sh-wsh':
|
|
33
|
+
return wasm_miniscript_1.ast.formatNode({ sh: { wsh: inner } });
|
|
34
|
+
case 'wsh':
|
|
35
|
+
return wasm_miniscript_1.ast.formatNode({ wsh: inner });
|
|
36
|
+
}
|
|
29
37
|
}
|
|
30
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVzY3JpcHRvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb3JlRGFvL2Rlc2NyaXB0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUEwQkEsNERBeUJDO0FBbERELDREQUE2QztBQVM3QyxTQUFTLGVBQWUsQ0FBQyxHQUE0QixFQUFFLFFBQWlCO0lBQ3RFLElBQUksTUFBTSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDO1FBQ3pCLE9BQU8sR0FBRyxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUM3QixDQUFDO0lBQ0QsT0FBTyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLFFBQVEsRUFBRSxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxRQUFRLEVBQUUsR0FBRyxJQUFJLENBQUM7QUFDN0QsQ0FBQztBQUVEOzs7Ozs7OztHQVFHO0FBQ0gsU0FBZ0Isd0JBQXdCLENBQ3RDLFVBQXNCLEVBQ3RCLFFBQWdCLEVBQ2hCLENBQVMsRUFDVCxXQUF3QyxFQUN4QyxRQUFRLEdBQUcsSUFBSTtJQUVmLElBQUksQ0FBQyxHQUFHLFdBQVcsQ0FBQyxNQUFNLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDO1FBQ3BDLE1BQU0sSUFBSSxLQUFLLENBQ2IsTUFBTSxDQUFDLHVEQUF1RCxXQUFXLENBQUMsTUFBTSxzQkFBc0IsQ0FDdkcsQ0FBQztJQUNKLENBQUM7SUFDRCxJQUFJLFFBQVEsSUFBSSxDQUFDLEVBQUUsQ0FBQztRQUNsQixNQUFNLElBQUksS0FBSyxDQUFDLGFBQWEsUUFBUSwwQkFBMEIsQ0FBQyxDQUFDO0lBQ25FLENBQUM7SUFDRCxNQUFNLElBQUksR0FBRyxXQUFXLENBQUMsR0FBRyxDQUFDLENBQUMsR0FBRyxFQUFFLEVBQUUsQ0FBQyxlQUFlLENBQUMsR0FBRyxFQUFFLFFBQVEsQ0FBQyxDQUFDLENBQUM7SUFDdEUsTUFBTSxLQUFLLEdBQXVCLEVBQUUsS0FBSyxFQUFFLENBQUMsRUFBRSxTQUFTLEVBQUUsUUFBUSxFQUFFLEVBQUUsRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDLEVBQUUsR0FBRyxJQUFJLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQztJQUNoRyxRQUFRLFVBQVUsRUFBRSxDQUFDO1FBQ25CLEtBQUssSUFBSTtZQUNQLE9BQU8scUJBQUcsQ0FBQyxVQUFVLENBQUMsRUFBRSxFQUFFLEVBQUUsS0FBSyxFQUFFLENBQUMsQ0FBQztRQUN2QyxLQUFLLFFBQVE7WUFDWCxPQUFPLHFCQUFHLENBQUMsVUFBVSxDQUFDLEVBQUUsRUFBRSxFQUFFLEVBQUUsR0FBRyxFQUFFLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUNoRCxLQUFLLEtBQUs7WUFDUixPQUFPLHFCQUFHLENBQUMsVUFBVSxDQUFDLEVBQUUsR0FBRyxFQUFFLEtBQUssRUFBRSxDQUFDLENBQUM7SUFDMUMsQ0FBQztBQUNILENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCSVAzMkludGVyZmFjZSB9IGZyb20gJ0BiaXRnby1iZXRhL3V0eG8tbGliJztcbmltcG9ydCB7IGFzdCB9IGZyb20gJ0BiaXRnby93YXNtLW1pbmlzY3JpcHQnO1xuXG4vKipcbiAqIFNjcmlwdCB0eXBlIGZvciBhIGRlc2NyaXB0b3IuXG4gKlxuICogU2VlIGh0dHBzOi8vZG9jcy5jb3JlZGFvLm9yZy9kb2NzL0xlYXJuL3Byb2R1Y3RzL2J0Yy1zdGFraW5nL2Rlc2lnbiNwMnNocDJ3c2gtb3V0cHV0XG4gKi9cbmV4cG9ydCB0eXBlIFNjcmlwdFR5cGUgPSAnc2gnIHwgJ3NoLXdzaCcgfCAnd3NoJztcblxuZnVuY3Rpb24gYXNEZXNjcmlwdG9yS2V5KGtleTogQklQMzJJbnRlcmZhY2UgfCBCdWZmZXIsIG5ldXRlcmVkOiBib29sZWFuKTogc3RyaW5nIHtcbiAgaWYgKEJ1ZmZlci5pc0J1ZmZlcihrZXkpKSB7XG4gICAgcmV0dXJuIGtleS50b1N0cmluZygnaGV4Jyk7XG4gIH1cbiAgcmV0dXJuIChuZXV0ZXJlZCA/IGtleS5uZXV0ZXJlZCgpIDoga2V5KS50b0Jhc2U1OCgpICsgJy8qJztcbn1cblxuLyoqXG4gKiBDcmVhdGUgYSBtdWx0aS1zaWcgZGVzY3JpcHRvciB0byBwcm9kdWNlIGEgY29yZWRhbyBzdGFraW5nIGFkZHJlc3NcbiAqIEBwYXJhbSBzY3JpcHRUeXBlIHNlZ3dpdCBvciBsZWdhY3lcbiAqIEBwYXJhbSBsb2NrdGltZSBsb2NrdGltZSBmb3IgQ0xUVlxuICogQHBhcmFtIG0gVG90YWwgbnVtYmVyIG9mIGtleXMgcmVxdWlyZWQgdG8gdW5sb2NrXG4gKiBAcGFyYW0gb3JkZXJlZEtleXMgSWYgQmlwMzJJbnRlcmZhY2VzLCB0aGVzZSBhcmUgeHBydnMgb3IgeHB1YnMgYW5kIGFyZSBkZXJpdmFibGUuXG4gKiAgICAgICAgICAgICAgICAgICAgSWYgdGhleSBhcmUgYnVmZmVycywgdGhlbiB0aGV5IGFyZSBwdWIvcHJ2IGtleXMgYW5kIGFyZSBub3QgZGVyaXZhYmxlLlxuICogQHBhcmFtIG5ldXRlcmVkIElmIHRydWUsIG5ldXRlciB0aGUga2V5cy4gRGVmYXVsdCB0byB0cnVlXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVNdWx0aVNpZ0Rlc2NyaXB0b3IoXG4gIHNjcmlwdFR5cGU6IFNjcmlwdFR5cGUsXG4gIGxvY2t0aW1lOiBudW1iZXIsXG4gIG06IG51bWJlcixcbiAgb3JkZXJlZEtleXM6IChCSVAzMkludGVyZmFjZSB8IEJ1ZmZlcilbXSxcbiAgbmV1dGVyZWQgPSB0cnVlXG4pOiBzdHJpbmcge1xuICBpZiAobSA+IG9yZGVyZWRLZXlzLmxlbmd0aCB8fCBtIDwgMSkge1xuICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgIGBtICgke219KSBtdXN0IGJlIGxlc3MgdGhhbiBvciBlcXVhbCB0byB0aGUgbnVtYmVyIG9mIGtleXMgKCR7b3JkZXJlZEtleXMubGVuZ3RofSkgYW5kIGdyZWF0ZXIgdGhhbiAwYFxuICAgICk7XG4gIH1cbiAgaWYgKGxvY2t0aW1lIDw9IDApIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoYGxvY2t0aW1lICgke2xvY2t0aW1lfSkgbXVzdCBiZSBncmVhdGVyIHRoYW4gMGApO1xuICB9XG4gIGNvbnN0IGtleXMgPSBvcmRlcmVkS2V5cy5tYXAoKGtleSkgPT4gYXNEZXNjcmlwdG9yS2V5KGtleSwgbmV1dGVyZWQpKTtcbiAgY29uc3QgaW5uZXI6IGFzdC5NaW5pc2NyaXB0Tm9kZSA9IHsgYW5kX3Y6IFt7ICdyOmFmdGVyJzogbG9ja3RpbWUgfSwgeyBtdWx0aTogW20sIC4uLmtleXNdIH1dIH07XG4gIHN3aXRjaCAoc2NyaXB0VHlwZSkge1xuICAgIGNhc2UgJ3NoJzpcbiAgICAgIHJldHVybiBhc3QuZm9ybWF0Tm9kZSh7IHNoOiBpbm5lciB9KTtcbiAgICBjYXNlICdzaC13c2gnOlxuICAgICAgcmV0dXJuIGFzdC5mb3JtYXROb2RlKHsgc2g6IHsgd3NoOiBpbm5lciB9IH0pO1xuICAgIGNhc2UgJ3dzaCc6XG4gICAgICByZXR1cm4gYXN0LmZvcm1hdE5vZGUoeyB3c2g6IGlubmVyIH0pO1xuICB9XG59XG4iXX0=
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
export declare const CORE_DAO_DEVNET_CHAIN_ID: Buffer<ArrayBuffer>;
|
|
2
|
+
export declare const CORE_DAO_TESTNET2_CHAIN_ID: Buffer<ArrayBuffer>;
|
|
2
3
|
export declare const CORE_DAO_TESTNET_CHAIN_ID: Buffer<ArrayBuffer>;
|
|
3
4
|
export declare const CORE_DAO_MAINNET_CHAIN_ID: Buffer<ArrayBuffer>;
|
|
4
5
|
export declare const CORE_DAO_SATOSHI_PLUS_IDENTIFIER: Buffer<ArrayBuffer>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"opReturn.d.ts","sourceRoot":"","sources":["../../../src/coreDao/opReturn.ts"],"names":[],"mappings":"AAGA,eAAO,MAAM,wBAAwB,qBAA6B,CAAC;AACnE,eAAO,MAAM,yBAAyB,qBAA6B,CAAC;AACpE,eAAO,MAAM,yBAAyB,qBAA6B,CAAC;AACpE,eAAO,MAAM,gCAAgC,qBAAiC,CAAC;AAI/E,wBAAgB,cAAc,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,CAIvD;AAED,wBAAgB,cAAc,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,CAKrD;AAED,KAAK,UAAU,GAAG;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;IAClB,GAAG,EAAE,MAAM,CAAC;CACb,CAAC;AAEF,MAAM,MAAM,cAAc,GAAG,UAAU,GAAG,CAAC;IAAE,YAAY,EAAE,MAAM,CAAA;CAAE,GAAG;IAAE,QAAQ,EAAE,MAAM,CAAA;CAAE,CAAC,CAAC;AAE5F;;;;;;;;;;;GAWG;AACH,wBAAgB,iCAAiC,CAAC,EAChD,OAAO,EACP,OAAO,EACP,SAAS,EACT,SAAS,EACT,GAAG,EACH,GAAG,IAAI,EACR,EAAE,cAAc,GAAG,MAAM,
|
|
1
|
+
{"version":3,"file":"opReturn.d.ts","sourceRoot":"","sources":["../../../src/coreDao/opReturn.ts"],"names":[],"mappings":"AAGA,eAAO,MAAM,wBAAwB,qBAA6B,CAAC;AACnE,eAAO,MAAM,0BAA0B,qBAA6B,CAAC;AACrE,eAAO,MAAM,yBAAyB,qBAA6B,CAAC;AACpE,eAAO,MAAM,yBAAyB,qBAA6B,CAAC;AACpE,eAAO,MAAM,gCAAgC,qBAAiC,CAAC;AAI/E,wBAAgB,cAAc,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,CAIvD;AAED,wBAAgB,cAAc,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,CAKrD;AAED,KAAK,UAAU,GAAG;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;IAClB,GAAG,EAAE,MAAM,CAAC;CACb,CAAC;AAEF,MAAM,MAAM,cAAc,GAAG,UAAU,GAAG,CAAC;IAAE,YAAY,EAAE,MAAM,CAAA;CAAE,GAAG;IAAE,QAAQ,EAAE,MAAM,CAAA;CAAE,CAAC,CAAC;AAE5F;;;;;;;;;;;GAWG;AACH,wBAAgB,iCAAiC,CAAC,EAChD,OAAO,EACP,OAAO,EACP,SAAS,EACT,SAAS,EACT,GAAG,EACH,GAAG,IAAI,EACR,EAAE,cAAc,GAAG,MAAM,CAuFzB;AAED;;;;GAIG;AACH,wBAAgB,gCAAgC,CAAC,MAAM,EAAE,MAAM,GAAG,cAAc,CAkE/E;AAED,wBAAgB,QAAQ,CAAC,MAAM,EAAE,cAAc,GAAG,MAAM,CAUvD"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.CORE_DAO_SATOSHI_PLUS_IDENTIFIER = exports.CORE_DAO_MAINNET_CHAIN_ID = exports.CORE_DAO_TESTNET_CHAIN_ID = exports.CORE_DAO_DEVNET_CHAIN_ID = void 0;
|
|
3
|
+
exports.CORE_DAO_SATOSHI_PLUS_IDENTIFIER = exports.CORE_DAO_MAINNET_CHAIN_ID = exports.CORE_DAO_TESTNET_CHAIN_ID = exports.CORE_DAO_TESTNET2_CHAIN_ID = exports.CORE_DAO_DEVNET_CHAIN_ID = void 0;
|
|
4
4
|
exports.encodeTimelock = encodeTimelock;
|
|
5
5
|
exports.decodeTimelock = decodeTimelock;
|
|
6
6
|
exports.createCoreDaoOpReturnOutputScript = createCoreDaoOpReturnOutputScript;
|
|
@@ -9,6 +9,7 @@ exports.toString = toString;
|
|
|
9
9
|
const utxo_lib_1 = require("@bitgo-beta/utxo-lib");
|
|
10
10
|
// Source: https://docs.coredao.org/docs/Learn/products/btc-staking/design
|
|
11
11
|
exports.CORE_DAO_DEVNET_CHAIN_ID = Buffer.from('0458', 'hex');
|
|
12
|
+
exports.CORE_DAO_TESTNET2_CHAIN_ID = Buffer.from('045a', 'hex');
|
|
12
13
|
exports.CORE_DAO_TESTNET_CHAIN_ID = Buffer.from('045b', 'hex');
|
|
13
14
|
exports.CORE_DAO_MAINNET_CHAIN_ID = Buffer.from('045c', 'hex');
|
|
14
15
|
exports.CORE_DAO_SATOSHI_PLUS_IDENTIFIER = Buffer.from('5341542b', 'hex');
|
|
@@ -65,6 +66,7 @@ function createCoreDaoOpReturnOutputScript({ version, chainId, delegator, valida
|
|
|
65
66
|
}
|
|
66
67
|
const versionBuffer = Buffer.alloc(1, version);
|
|
67
68
|
if (!(chainId.equals(exports.CORE_DAO_TESTNET_CHAIN_ID) ||
|
|
69
|
+
chainId.equals(exports.CORE_DAO_TESTNET2_CHAIN_ID) ||
|
|
68
70
|
chainId.equals(exports.CORE_DAO_MAINNET_CHAIN_ID) ||
|
|
69
71
|
chainId.equals(exports.CORE_DAO_DEVNET_CHAIN_ID))) {
|
|
70
72
|
throw new Error('Invalid chain ID');
|
|
@@ -144,6 +146,7 @@ function parseCoreDaoOpReturnOutputScript(script) {
|
|
|
144
146
|
const chainId = Buffer.from(dataBuffer.subarray(offset, offset + 2));
|
|
145
147
|
if (!(chainId.equals(exports.CORE_DAO_DEVNET_CHAIN_ID) ||
|
|
146
148
|
chainId.equals(exports.CORE_DAO_TESTNET_CHAIN_ID) ||
|
|
149
|
+
chainId.equals(exports.CORE_DAO_TESTNET2_CHAIN_ID) ||
|
|
147
150
|
chainId.equals(exports.CORE_DAO_MAINNET_CHAIN_ID))) {
|
|
148
151
|
throw new Error(`Invalid ChainID: ${chainId.toString('hex')}. Must be either 0x0458 (devnet), 0x045b (testnet), or 0x045c (mainnet).`);
|
|
149
152
|
}
|
|
@@ -177,4 +180,4 @@ function toString(params) {
|
|
|
177
180
|
...('timelock' in params ? { timelock: params.timelock } : {}),
|
|
178
181
|
});
|
|
179
182
|
}
|
|
180
|
-
//# 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_DEVNET_CHAIN_ID = Buffer.from('0458', 'hex');\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 (\n    !(\n      chainId.equals(CORE_DAO_TESTNET_CHAIN_ID) ||\n      chainId.equals(CORE_DAO_MAINNET_CHAIN_ID) ||\n      chainId.equals(CORE_DAO_DEVNET_CHAIN_ID)\n    )\n  ) {\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_DEVNET_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 (\n    !(\n      chainId.equals(CORE_DAO_DEVNET_CHAIN_ID) ||\n      chainId.equals(CORE_DAO_TESTNET_CHAIN_ID) ||\n      chainId.equals(CORE_DAO_MAINNET_CHAIN_ID)\n    )\n  ) {\n    throw new Error(\n      `Invalid ChainID: ${chainId.toString(\n        'hex'\n      )}. Must be either 0x0458 (devnet), 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"]}
|
|
183
|
+
//# 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_DEVNET_CHAIN_ID = Buffer.from('0458', 'hex');\nexport const CORE_DAO_TESTNET2_CHAIN_ID = Buffer.from('045a', 'hex');\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 (\n    !(\n      chainId.equals(CORE_DAO_TESTNET_CHAIN_ID) ||\n      chainId.equals(CORE_DAO_TESTNET2_CHAIN_ID) ||\n      chainId.equals(CORE_DAO_MAINNET_CHAIN_ID) ||\n      chainId.equals(CORE_DAO_DEVNET_CHAIN_ID)\n    )\n  ) {\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_DEVNET_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 (\n    !(\n      chainId.equals(CORE_DAO_DEVNET_CHAIN_ID) ||\n      chainId.equals(CORE_DAO_TESTNET_CHAIN_ID) ||\n      chainId.equals(CORE_DAO_TESTNET2_CHAIN_ID) ||\n      chainId.equals(CORE_DAO_MAINNET_CHAIN_ID)\n    )\n  ) {\n    throw new Error(\n      `Invalid ChainID: ${chainId.toString(\n        'hex'\n      )}. Must be either 0x0458 (devnet), 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,5 +1,11 @@
|
|
|
1
|
+
import { Output } from '@bitgo-beta/utxo-core';
|
|
1
2
|
import { Descriptor } from '@bitgo/wasm-miniscript';
|
|
2
3
|
import { OpReturnParams } from './opReturn';
|
|
4
|
+
type StakingParams = {
|
|
5
|
+
amount: bigint;
|
|
6
|
+
descriptor: Descriptor;
|
|
7
|
+
index?: number;
|
|
8
|
+
};
|
|
3
9
|
/**
|
|
4
10
|
* Create the staking outputs for a CoreDAO staking transaction. This is the ordering
|
|
5
11
|
* in which to add into the transaction.
|
|
@@ -8,12 +14,15 @@ import { OpReturnParams } from './opReturn';
|
|
|
8
14
|
* If stakingParams.index is provided, then this is assumed to be a `derivable` descriptor.
|
|
9
15
|
* @param opReturnParams to create the OP_RETURN output
|
|
10
16
|
*/
|
|
11
|
-
export declare function
|
|
12
|
-
|
|
13
|
-
descriptor: Descriptor;
|
|
14
|
-
index?: number;
|
|
15
|
-
}, opReturnParams: OpReturnParams): {
|
|
17
|
+
export declare function createStakingOutputsCore(stakingParams: StakingParams, opReturnParams: OpReturnParams): Output<bigint>[];
|
|
18
|
+
type LegacyOutput = {
|
|
16
19
|
script: Buffer;
|
|
17
20
|
amount: bigint;
|
|
18
|
-
}
|
|
21
|
+
};
|
|
22
|
+
/**
|
|
23
|
+
* @see createStakingOutputsCore
|
|
24
|
+
* @deprecated - use createStakingOutputsCore instead
|
|
25
|
+
*/
|
|
26
|
+
export declare function createStakingOutputs(stakingParams: StakingParams, opReturnParams: OpReturnParams): LegacyOutput[];
|
|
27
|
+
export {};
|
|
19
28
|
//# sourceMappingURL=transaction.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
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
|
|
1
|
+
{"version":3,"file":"transaction.d.ts","sourceRoot":"","sources":["../../../src/coreDao/transaction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAC/C,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AAEpD,OAAO,EAAqC,cAAc,EAAE,MAAM,YAAY,CAAC;AAE/E,KAAK,aAAa,GAAG;IACnB,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,EAAE,UAAU,CAAC;IACvB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CAAC;AAEF;;;;;;;GAOG;AACH,wBAAgB,wBAAwB,CACtC,aAAa,EAAE,aAAa,EAC5B,cAAc,EAAE,cAAc,GAC7B,MAAM,CAAC,MAAM,CAAC,EAAE,CAgBlB;AAED,KAAK,YAAY,GAAG;IAClB,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC;AAEF;;;GAGG;AACH,wBAAgB,oBAAoB,CAAC,aAAa,EAAE,aAAa,EAAE,cAAc,EAAE,cAAc,GAAG,YAAY,EAAE,CAEjH"}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createStakingOutputsCore = createStakingOutputsCore;
|
|
3
4
|
exports.createStakingOutputs = createStakingOutputs;
|
|
4
5
|
const opReturn_1 = require("./opReturn");
|
|
5
6
|
/**
|
|
@@ -10,7 +11,7 @@ const opReturn_1 = require("./opReturn");
|
|
|
10
11
|
* If stakingParams.index is provided, then this is assumed to be a `derivable` descriptor.
|
|
11
12
|
* @param opReturnParams to create the OP_RETURN output
|
|
12
13
|
*/
|
|
13
|
-
function
|
|
14
|
+
function createStakingOutputsCore(stakingParams, opReturnParams) {
|
|
14
15
|
if (stakingParams.descriptor.hasWildcard() && stakingParams.index === undefined) {
|
|
15
16
|
throw new Error('Cannot create staking outputs with a wildcard descriptor and no derivation index');
|
|
16
17
|
}
|
|
@@ -19,8 +20,15 @@ function createStakingOutputs(stakingParams, opReturnParams) {
|
|
|
19
20
|
: stakingParams.descriptor.atDerivationIndex(stakingParams.index).scriptPubkey());
|
|
20
21
|
const opReturnScript = (0, opReturn_1.createCoreDaoOpReturnOutputScript)(opReturnParams);
|
|
21
22
|
return [
|
|
22
|
-
{ script: outputScript,
|
|
23
|
-
{ script: opReturnScript,
|
|
23
|
+
{ script: outputScript, value: stakingParams.amount },
|
|
24
|
+
{ script: opReturnScript, value: BigInt(0) },
|
|
24
25
|
];
|
|
25
26
|
}
|
|
26
|
-
|
|
27
|
+
/**
|
|
28
|
+
* @see createStakingOutputsCore
|
|
29
|
+
* @deprecated - use createStakingOutputsCore instead
|
|
30
|
+
*/
|
|
31
|
+
function createStakingOutputs(stakingParams, opReturnParams) {
|
|
32
|
+
return createStakingOutputsCore(stakingParams, opReturnParams).map(({ value, ...o }) => ({ ...o, amount: value }));
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNhY3Rpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29yZURhby90cmFuc2FjdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQW1CQSw0REFtQkM7QUFXRCxvREFFQztBQWhERCx5Q0FBK0U7QUFRL0U7Ozs7Ozs7R0FPRztBQUNILFNBQWdCLHdCQUF3QixDQUN0QyxhQUE0QixFQUM1QixjQUE4QjtJQUU5QixJQUFJLGFBQWEsQ0FBQyxVQUFVLENBQUMsV0FBVyxFQUFFLElBQUksYUFBYSxDQUFDLEtBQUssS0FBSyxTQUFTLEVBQUUsQ0FBQztRQUNoRixNQUFNLElBQUksS0FBSyxDQUFDLGtGQUFrRixDQUFDLENBQUM7SUFDdEcsQ0FBQztJQUVELE1BQU0sWUFBWSxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQzlCLGFBQWEsQ0FBQyxLQUFLLEtBQUssU0FBUztRQUMvQixDQUFDLENBQUMsYUFBYSxDQUFDLFVBQVUsQ0FBQyxZQUFZLEVBQUU7UUFDekMsQ0FBQyxDQUFDLGFBQWEsQ0FBQyxVQUFVLENBQUMsaUJBQWlCLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxDQUFDLFlBQVksRUFBRSxDQUNuRixDQUFDO0lBQ0YsTUFBTSxjQUFjLEdBQUcsSUFBQSw0Q0FBaUMsRUFBQyxjQUFjLENBQUMsQ0FBQztJQUV6RSxPQUFPO1FBQ0wsRUFBRSxNQUFNLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxhQUFhLENBQUMsTUFBTSxFQUFFO1FBQ3JELEVBQUUsTUFBTSxFQUFFLGNBQWMsRUFBRSxLQUFLLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFO0tBQzdDLENBQUM7QUFDSixDQUFDO0FBT0Q7OztHQUdHO0FBQ0gsU0FBZ0Isb0JBQW9CLENBQUMsYUFBNEIsRUFBRSxjQUE4QjtJQUMvRixPQUFPLHdCQUF3QixDQUFDLGFBQWEsRUFBRSxjQUFjLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxFQUFFLEtBQUssRUFBRSxHQUFHLENBQUMsRUFBRSxFQUFFLEVBQUUsQ0FBQyxDQUFDLEVBQUUsR0FBRyxDQUFDLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxDQUFDLENBQUMsQ0FBQztBQUNySCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgT3V0cHV0IH0gZnJvbSAnQGJpdGdvLWJldGEvdXR4by1jb3JlJztcbmltcG9ydCB7IERlc2NyaXB0b3IgfSBmcm9tICdAYml0Z28vd2FzbS1taW5pc2NyaXB0JztcblxuaW1wb3J0IHsgY3JlYXRlQ29yZURhb09wUmV0dXJuT3V0cHV0U2NyaXB0LCBPcFJldHVyblBhcmFtcyB9IGZyb20gJy4vb3BSZXR1cm4nO1xuXG50eXBlIFN0YWtpbmdQYXJhbXMgPSB7XG4gIGFtb3VudDogYmlnaW50O1xuICBkZXNjcmlwdG9yOiBEZXNjcmlwdG9yO1xuICBpbmRleD86IG51bWJlcjtcbn07XG5cbi8qKlxuICogQ3JlYXRlIHRoZSBzdGFraW5nIG91dHB1dHMgZm9yIGEgQ29yZURBTyBzdGFraW5nIHRyYW5zYWN0aW9uLiBUaGlzIGlzIHRoZSBvcmRlcmluZ1xuICogaW4gd2hpY2ggdG8gYWRkIGludG8gdGhlIHRyYW5zYWN0aW9uLlxuICogQHBhcmFtIHN0YWtpbmdQYXJhbXMgaG93IHRvIGNyZWF0ZSB0aGUgdGltZWxvY2tlZCBzdGFrZSBvdXRwdXRcbiAqIEBwYXJhbSBzdGFraW5nUGFyYW1zLmRlc2NyaXB0b3IgaWYgc3Rha2luZ1BhcmFtcy5pbmRleCBpcyBub3QgcHJvdmlkZWQsIHRoZW4gdGhpcyBpcyBhc3N1bWVkIHRvIGJlIGEgYGRlZmluaXRlYCBkZXNjcmlwdG9yLlxuICogSWYgc3Rha2luZ1BhcmFtcy5pbmRleCBpcyBwcm92aWRlZCwgdGhlbiB0aGlzIGlzIGFzc3VtZWQgdG8gYmUgYSBgZGVyaXZhYmxlYCBkZXNjcmlwdG9yLlxuICogQHBhcmFtIG9wUmV0dXJuUGFyYW1zIHRvIGNyZWF0ZSB0aGUgT1BfUkVUVVJOIG91dHB1dFxuICovXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlU3Rha2luZ091dHB1dHNDb3JlKFxuICBzdGFraW5nUGFyYW1zOiBTdGFraW5nUGFyYW1zLFxuICBvcFJldHVyblBhcmFtczogT3BSZXR1cm5QYXJhbXNcbik6IE91dHB1dDxiaWdpbnQ+W10ge1xuICBpZiAoc3Rha2luZ1BhcmFtcy5kZXNjcmlwdG9yLmhhc1dpbGRjYXJkKCkgJiYgc3Rha2luZ1BhcmFtcy5pbmRleCA9PT0gdW5kZWZpbmVkKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdDYW5ub3QgY3JlYXRlIHN0YWtpbmcgb3V0cHV0cyB3aXRoIGEgd2lsZGNhcmQgZGVzY3JpcHRvciBhbmQgbm8gZGVyaXZhdGlvbiBpbmRleCcpO1xuICB9XG5cbiAgY29uc3Qgb3V0cHV0U2NyaXB0ID0gQnVmZmVyLmZyb20oXG4gICAgc3Rha2luZ1BhcmFtcy5pbmRleCA9PT0gdW5kZWZpbmVkXG4gICAgICA/IHN0YWtpbmdQYXJhbXMuZGVzY3JpcHRvci5zY3JpcHRQdWJrZXkoKVxuICAgICAgOiBzdGFraW5nUGFyYW1zLmRlc2NyaXB0b3IuYXREZXJpdmF0aW9uSW5kZXgoc3Rha2luZ1BhcmFtcy5pbmRleCkuc2NyaXB0UHVia2V5KClcbiAgKTtcbiAgY29uc3Qgb3BSZXR1cm5TY3JpcHQgPSBjcmVhdGVDb3JlRGFvT3BSZXR1cm5PdXRwdXRTY3JpcHQob3BSZXR1cm5QYXJhbXMpO1xuXG4gIHJldHVybiBbXG4gICAgeyBzY3JpcHQ6IG91dHB1dFNjcmlwdCwgdmFsdWU6IHN0YWtpbmdQYXJhbXMuYW1vdW50IH0sXG4gICAgeyBzY3JpcHQ6IG9wUmV0dXJuU2NyaXB0LCB2YWx1ZTogQmlnSW50KDApIH0sXG4gIF07XG59XG5cbnR5cGUgTGVnYWN5T3V0cHV0ID0ge1xuICBzY3JpcHQ6IEJ1ZmZlcjtcbiAgYW1vdW50OiBiaWdpbnQ7XG59O1xuXG4vKipcbiAqIEBzZWUgY3JlYXRlU3Rha2luZ091dHB1dHNDb3JlXG4gKiBAZGVwcmVjYXRlZCAtIHVzZSBjcmVhdGVTdGFraW5nT3V0cHV0c0NvcmUgaW5zdGVhZFxuICovXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlU3Rha2luZ091dHB1dHMoc3Rha2luZ1BhcmFtczogU3Rha2luZ1BhcmFtcywgb3BSZXR1cm5QYXJhbXM6IE9wUmV0dXJuUGFyYW1zKTogTGVnYWN5T3V0cHV0W10ge1xuICByZXR1cm4gY3JlYXRlU3Rha2luZ091dHB1dHNDb3JlKHN0YWtpbmdQYXJhbXMsIG9wUmV0dXJuUGFyYW1zKS5tYXAoKHsgdmFsdWUsIC4uLm8gfSkgPT4gKHsgLi4ubywgYW1vdW50OiB2YWx1ZSB9KSk7XG59XG4iXX0=
|
package/dist/src/index.d.ts
CHANGED
package/dist/src/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,OAAO,MAAM,WAAW,CAAC;AAErC,cAAc,eAAe,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,OAAO,MAAM,WAAW,CAAC;AACrC,OAAO,KAAK,OAAO,MAAM,WAAW,CAAC;AAErC,cAAc,eAAe,CAAC"}
|
package/dist/src/index.js
CHANGED
|
@@ -10,11 +10,34 @@ var __createBinding = (this && this.__createBinding) || (Object.create ? (functi
|
|
|
10
10
|
if (k2 === undefined) k2 = k;
|
|
11
11
|
o[k2] = m[k];
|
|
12
12
|
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
13
35
|
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
36
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
37
|
};
|
|
16
38
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
-
exports.coreDao = void 0;
|
|
18
|
-
exports.coreDao = require("./coreDao");
|
|
39
|
+
exports.babylon = exports.coreDao = void 0;
|
|
40
|
+
exports.coreDao = __importStar(require("./coreDao"));
|
|
41
|
+
exports.babylon = __importStar(require("./babylon"));
|
|
19
42
|
__exportStar(require("./transaction"), exports);
|
|
20
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
43
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEscURBQXFDO0FBQ3JDLHFEQUFxQztBQUVyQyxnREFBOEIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBhcyBjb3JlRGFvIGZyb20gJy4vY29yZURhbyc7XG5leHBvcnQgKiBhcyBiYWJ5bG9uIGZyb20gJy4vYmFieWxvbic7XG5cbmV4cG9ydCAqIGZyb20gJy4vdHJhbnNhY3Rpb24nO1xuIl19
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"transaction.d.ts","sourceRoot":"","sources":["../../src/transaction.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;
|
|
1
|
+
{"version":3,"file":"transaction.d.ts","sourceRoot":"","sources":["../../src/transaction.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAMhD;;;;;;;;;;;;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"}
|
package/dist/src/transaction.js
CHANGED
|
@@ -1,8 +1,43 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
2
35
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
36
|
exports.buildFixedWalletStakingPsbt = buildFixedWalletStakingPsbt;
|
|
4
|
-
const utxolib = require("@bitgo-beta/utxo-lib");
|
|
37
|
+
const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
|
|
5
38
|
const unspents_1 = require("@bitgo-beta/unspents");
|
|
39
|
+
const bitcoinjslib = __importStar(require("bitcoinjs-lib"));
|
|
40
|
+
bitcoinjslib.initEccLib(utxolib.ecc);
|
|
6
41
|
/**
|
|
7
42
|
* Build a staking transaction for a wallet that assumes 2-of-3 multisig for the inputs
|
|
8
43
|
*
|
|
@@ -51,4 +86,4 @@ function buildFixedWalletStakingPsbt({ rootWalletKeys, unspents, outputs, change
|
|
|
51
86
|
}
|
|
52
87
|
return psbt;
|
|
53
88
|
}
|
|
54
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
89
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNhY3Rpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdHJhbnNhY3Rpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFtQkEsa0VBbUZDO0FBdEdELDhEQUFnRDtBQUNoRCxtREFBa0Q7QUFDbEQsNERBQThDO0FBRTlDLFlBQVksQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0FBRXJDOzs7Ozs7Ozs7Ozs7R0FZRztBQUNILFNBQWdCLDJCQUEyQixDQUFDLEVBQzFDLGNBQWMsRUFDZCxRQUFRLEVBQ1IsT0FBTyxFQUNQLGlCQUFpQixFQUNqQixZQUFZLEVBQ1osT0FBTyxFQUNQLGtCQUFrQixFQUNsQixVQUFVLEdBQUcsTUFBTSxDQUFDLENBQUMsQ0FBQyxHQWlCdkI7SUFDQyxJQUFJLFlBQVksR0FBRyxJQUFJLEVBQUUsQ0FBQztRQUN4QixNQUFNLElBQUksS0FBSyxDQUFDLHVDQUF1QyxDQUFDLENBQUM7SUFDM0QsQ0FBQztJQUNELElBQUksUUFBUSxDQUFDLE1BQU0sS0FBSyxDQUFDLElBQUksT0FBTyxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUUsQ0FBQztRQUNsRCxNQUFNLElBQUksS0FBSyxDQUFDLDZDQUE2QyxDQUFDLENBQUM7SUFDakUsQ0FBQztJQUVELGdDQUFnQztJQUNoQyxNQUFNLFlBQVksR0FBRyxPQUFPLENBQUMsS0FBSyxDQUFDLGFBQWEsQ0FBQyxzQkFBc0IsQ0FDckUsY0FBYyxDQUFDLHNCQUFzQixDQUFDLGlCQUFpQixDQUFDLEtBQUssRUFBRSxpQkFBaUIsQ0FBQyxLQUFLLENBQUMsQ0FBQyxVQUFVLEVBQ2xHLE9BQU8sQ0FBQyxLQUFLLENBQUMsa0JBQWtCLENBQUMsaUJBQWlCLENBQUMsS0FBSyxDQUFDLEVBQ3pELE9BQU8sQ0FDUixDQUFDLFlBQVksQ0FBQztJQUNmLElBQUksQ0FBQyxZQUFZLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQUMsd0JBQXdCLENBQUMsaUJBQWlCLENBQUMsT0FBTyxFQUFFLE9BQU8sQ0FBQyxDQUFDLEVBQUUsQ0FBQztRQUM3RyxNQUFNLElBQUksS0FBSyxDQUFDLDhEQUE4RCxDQUFDLENBQUM7SUFDbEYsQ0FBQztJQUVELE1BQU0sSUFBSSxHQUFHLE9BQU8sQ0FBQyxLQUFLLENBQUMsb0JBQW9CLENBQUMsRUFBRSxPQUFPLEVBQUUsQ0FBQyxDQUFDO0lBQzdELE9BQU8sQ0FBQyxLQUFLLENBQUMsY0FBYyxDQUFDLElBQUksRUFBRSxjQUFjLENBQUMsQ0FBQztJQUVuRCxNQUFNLFdBQVcsR0FBRyxRQUFRLENBQUMsTUFBTSxDQUFDLENBQUMsR0FBRyxFQUFFLE9BQU8sRUFBRSxFQUFFLENBQUMsR0FBRyxHQUFHLE9BQU8sQ0FBQyxLQUFLLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDdEYsTUFBTSxZQUFZLEdBQUcsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFDLEdBQUcsRUFBRSxNQUFNLEVBQUUsRUFBRSxDQUFDLEdBQUcsR0FBRyxNQUFNLENBQUMsS0FBSyxFQUFFLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBRXBGLFFBQVEsQ0FBQyxPQUFPLENBQUMsQ0FBQyxPQUFPLEVBQUUsRUFBRSxDQUMzQixPQUFPLENBQUMsS0FBSyxDQUFDLHNCQUFzQixDQUFDLElBQUksRUFBRSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sRUFBRSxPQUFPLEVBQUU7UUFDbkYsa0JBQWtCLEVBQUUsSUFBSTtRQUN4QixrQkFBa0I7S0FDbkIsQ0FBQyxDQUNILENBQUM7SUFDRixPQUFPLENBQUMsT0FBTyxDQUFDLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUM7SUFFcEQsTUFBTSxHQUFHLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FDbkIsQ0FBQyxxQkFBVSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUM7U0FDdkIsSUFBSSxDQUFDLHFCQUFVLENBQUMsVUFBVSxDQUFDLEVBQUUsTUFBTSxFQUFFLFlBQVksRUFBRSxDQUFDLENBQUM7U0FDckQsUUFBUSxFQUFFO1FBQ1gsWUFBWSxDQUFDO1FBQ2IsSUFBSSxDQUNQLENBQUM7SUFFRixNQUFNLFlBQVksR0FBRyxXQUFXLEdBQUcsQ0FBQyxZQUFZLEdBQUcsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7SUFDaEUsSUFBSSxZQUFZLEdBQUcsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7UUFDN0IsTUFBTSxJQUFJLEtBQUssQ0FDYixnQkFBZ0IsV0FBVyxDQUFDLFFBQVEsRUFBRSxvQ0FBb0MsWUFBWSxrQkFBa0IsR0FBRyxFQUFFLENBQzlHLENBQUM7SUFDSixDQUFDO0lBRUQsSUFBSSxZQUFZLEdBQUcsVUFBVSxFQUFFLENBQUM7UUFDOUIsT0FBTyxDQUFDLEtBQUssQ0FBQyxxQkFBcUIsQ0FDakMsSUFBSSxFQUNKLGNBQWMsRUFDZCxpQkFBaUIsQ0FBQyxLQUFLLEVBQ3ZCLGlCQUFpQixDQUFDLEtBQUssRUFDdkIsWUFBWSxDQUNiLENBQUM7SUFDSixDQUFDO0lBRUQsT0FBTyxJQUFJLENBQUM7QUFDZCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgdXR4b2xpYiBmcm9tICdAYml0Z28tYmV0YS91dHhvLWxpYic7XG5pbXBvcnQgeyBEaW1lbnNpb25zIH0gZnJvbSAnQGJpdGdvLWJldGEvdW5zcGVudHMnO1xuaW1wb3J0ICogYXMgYml0Y29pbmpzbGliIGZyb20gJ2JpdGNvaW5qcy1saWInO1xuXG5iaXRjb2luanNsaWIuaW5pdEVjY0xpYih1dHhvbGliLmVjYyk7XG5cbi8qKlxuICogQnVpbGQgYSBzdGFraW5nIHRyYW5zYWN0aW9uIGZvciBhIHdhbGxldCB0aGF0IGFzc3VtZXMgMi1vZi0zIG11bHRpc2lnIGZvciB0aGUgaW5wdXRzXG4gKlxuICogR2l2ZW4gdGhlIGlucHV0cyBhbmQgdGhlIHN0YWtpbmcgb3V0cHV0cywgd2Ugd2lsbCBjcmVhdGUgdGhlIFBTQlQgd2l0aCB0aGUgZGVzaXJlZCBmZWUgcmF0ZS5cbiAqIFdlIGFsd2F5cyBhZGQgdGhlIGNoYW5nZSBhZGRyZXNzIGFzIHRoZSBsYXN0IG91dHB1dC5cbiAqXG4gKiBAcGFyYW0gcm9vdFdhbGxldEtleXNcbiAqIEBwYXJhbSB1bnNwZW50c1xuICogQHBhcmFtIGNyZWF0ZVN0YWtpbmdPdXRwdXRzXG4gKiBAcGFyYW0gY2hhbmdlQWRkcmVzc0luZm9cbiAqIEBwYXJhbSBmZWVSYXRlU2F0S0JcbiAqIEBwYXJhbSBuZXR3b3JrXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBidWlsZEZpeGVkV2FsbGV0U3Rha2luZ1BzYnQoe1xuICByb290V2FsbGV0S2V5cyxcbiAgdW5zcGVudHMsXG4gIG91dHB1dHMsXG4gIGNoYW5nZUFkZHJlc3NJbmZvLFxuICBmZWVSYXRlU2F0S0IsXG4gIG5ldHdvcmssXG4gIHNraXBOb25XaXRuZXNzVXR4byxcbiAgZHVzdEFtb3VudCA9IEJpZ0ludCgwKSxcbn06IHtcbiAgcm9vdFdhbGxldEtleXM6IHV0eG9saWIuYml0Z28uUm9vdFdhbGxldEtleXM7XG4gIHVuc3BlbnRzOiB1dHhvbGliLmJpdGdvLldhbGxldFVuc3BlbnQ8YmlnaW50PltdO1xuICBvdXRwdXRzOiB7XG4gICAgc2NyaXB0OiBCdWZmZXI7XG4gICAgdmFsdWU6IGJpZ2ludDtcbiAgfVtdO1xuICBjaGFuZ2VBZGRyZXNzSW5mbzoge1xuICAgIGNoYWluOiB1dHhvbGliLmJpdGdvLkNoYWluQ29kZTtcbiAgICBpbmRleDogbnVtYmVyO1xuICAgIGFkZHJlc3M6IHN0cmluZztcbiAgfTtcbiAgZmVlUmF0ZVNhdEtCOiBudW1iZXI7XG4gIG5ldHdvcms6IHV0eG9saWIuTmV0d29yaztcbiAgc2tpcE5vbldpdG5lc3NVdHhvPzogYm9vbGVhbjtcbiAgZHVzdEFtb3VudD86IGJpZ2ludDtcbn0pOiB1dHhvbGliLmJpdGdvLlV0eG9Qc2J0IHtcbiAgaWYgKGZlZVJhdGVTYXRLQiA8IDEwMDApIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ0ZlZSByYXRlIG11c3QgYmUgYXQgbGVhc3QgMSBzYXQvdmJ5dGUnKTtcbiAgfVxuICBpZiAodW5zcGVudHMubGVuZ3RoID09PSAwIHx8IG91dHB1dHMubGVuZ3RoID09PSAwKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdNdXN0IGhhdmUgYXQgbGVhc3Qgb25lIGlucHV0IGFuZCBvbmUgb3V0cHV0Jyk7XG4gIH1cblxuICAvLyBDaGVjayB0aGUgY2hhbmdlIGFkZHJlc3MgaW5mb1xuICBjb25zdCBjaGFuZ2VTY3JpcHQgPSB1dHhvbGliLmJpdGdvLm91dHB1dFNjcmlwdHMuY3JlYXRlT3V0cHV0U2NyaXB0Mm9mMyhcbiAgICByb290V2FsbGV0S2V5cy5kZXJpdmVGb3JDaGFpbkFuZEluZGV4KGNoYW5nZUFkZHJlc3NJbmZvLmNoYWluLCBjaGFuZ2VBZGRyZXNzSW5mby5pbmRleCkucHVibGljS2V5cyxcbiAgICB1dHhvbGliLmJpdGdvLnNjcmlwdFR5cGVGb3JDaGFpbihjaGFuZ2VBZGRyZXNzSW5mby5jaGFpbiksXG4gICAgbmV0d29ya1xuICApLnNjcmlwdFB1YktleTtcbiAgaWYgKCFjaGFuZ2VTY3JpcHQuZXF1YWxzKHV0eG9saWIuYWRkcmVzc0Zvcm1hdC50b091dHB1dFNjcmlwdFRyeUZvcm1hdHMoY2hhbmdlQWRkcmVzc0luZm8uYWRkcmVzcywgbmV0d29yaykpKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdDaGFuZ2UgYWRkcmVzcyBpbmZvIGRvZXMgbm90IG1hdGNoIHRoZSBkZXJpdmVkIGNoYW5nZSBzY3JpcHQnKTtcbiAgfVxuXG4gIGNvbnN0IHBzYnQgPSB1dHhvbGliLmJpdGdvLmNyZWF0ZVBzYnRGb3JOZXR3b3JrKHsgbmV0d29yayB9KTtcbiAgdXR4b2xpYi5iaXRnby5hZGRYcHVic1RvUHNidChwc2J0LCByb290V2FsbGV0S2V5cyk7XG5cbiAgY29uc3QgaW5wdXRBbW91bnQgPSB1bnNwZW50cy5yZWR1Y2UoKHN1bSwgdW5zcGVudCkgPT4gc3VtICsgdW5zcGVudC52YWx1ZSwgQmlnSW50KDApKTtcbiAgY29uc3Qgb3V0cHV0QW1vdW50ID0gb3V0cHV0cy5yZWR1Y2UoKHN1bSwgb3V0cHV0KSA9PiBzdW0gKyBvdXRwdXQudmFsdWUsIEJpZ0ludCgwKSk7XG5cbiAgdW5zcGVudHMuZm9yRWFjaCgodW5zcGVudCkgPT5cbiAgICB1dHhvbGliLmJpdGdvLmFkZFdhbGxldFVuc3BlbnRUb1BzYnQocHNidCwgdW5zcGVudCwgcm9vdFdhbGxldEtleXMsICd1c2VyJywgJ2JpdGdvJywge1xuICAgICAgaXNSZXBsYWNlYWJsZUJ5RmVlOiB0cnVlLFxuICAgICAgc2tpcE5vbldpdG5lc3NVdHhvLFxuICAgIH0pXG4gICk7XG4gIG91dHB1dHMuZm9yRWFjaCgob3V0cHV0KSA9PiBwc2J0LmFkZE91dHB1dChvdXRwdXQpKTtcblxuICBjb25zdCBmZWUgPSBNYXRoLmNlaWwoXG4gICAgKERpbWVuc2lvbnMuZnJvbVBzYnQocHNidClcbiAgICAgIC5wbHVzKERpbWVuc2lvbnMuZnJvbU91dHB1dCh7IHNjcmlwdDogY2hhbmdlU2NyaXB0IH0pKVxuICAgICAgLmdldFZTaXplKCkgKlxuICAgICAgZmVlUmF0ZVNhdEtCKSAvXG4gICAgICAxMDAwXG4gICk7XG5cbiAgY29uc3QgY2hhbmdlQW1vdW50ID0gaW5wdXRBbW91bnQgLSAob3V0cHV0QW1vdW50ICsgQmlnSW50KGZlZSkpO1xuICBpZiAoY2hhbmdlQW1vdW50IDwgQmlnSW50KDApKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKFxuICAgICAgYElucHV0IGFtb3VudCAke2lucHV0QW1vdW50LnRvU3RyaW5nKCl9IGNhbm5vdCBjb3ZlciB0aGUgc3Rha2luZyBhbW91bnQgJHtvdXRwdXRBbW91bnR9IGFuZCAgdGhlIGZlZTogJHtmZWV9YFxuICAgICk7XG4gIH1cblxuICBpZiAoY2hhbmdlQW1vdW50ID4gZHVzdEFtb3VudCkge1xuICAgIHV0eG9saWIuYml0Z28uYWRkV2FsbGV0T3V0cHV0VG9Qc2J0KFxuICAgICAgcHNidCxcbiAgICAgIHJvb3RXYWxsZXRLZXlzLFxuICAgICAgY2hhbmdlQWRkcmVzc0luZm8uY2hhaW4sXG4gICAgICBjaGFuZ2VBZGRyZXNzSW5mby5pbmRleCxcbiAgICAgIGNoYW5nZUFtb3VudFxuICAgICk7XG4gIH1cblxuICByZXR1cm4gcHNidDtcbn1cbiJdfQ==
|