@bitgo-beta/abstract-lightning 1.0.1-beta.98 → 1.0.1-beta.980
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/abstractLightningCoin.d.ts +3 -2
- package/dist/src/abstractLightningCoin.d.ts.map +1 -1
- package/dist/src/abstractLightningCoin.js +7 -2
- package/dist/src/codecs/api/backup.d.ts +15 -0
- package/dist/src/codecs/api/backup.d.ts.map +1 -0
- package/dist/src/codecs/api/backup.js +47 -0
- package/dist/src/codecs/api/balance.d.ts +132 -0
- package/dist/src/codecs/api/balance.d.ts.map +1 -0
- package/dist/src/codecs/api/balance.js +101 -0
- package/dist/src/codecs/api/index.d.ts +8 -0
- package/dist/src/codecs/api/index.d.ts.map +1 -0
- package/dist/src/codecs/api/index.js +24 -0
- package/dist/src/codecs/api/invoice.d.ts +66 -0
- package/dist/src/codecs/api/invoice.d.ts.map +1 -0
- package/dist/src/codecs/api/invoice.js +102 -0
- package/dist/src/codecs/api/payment.d.ts +107 -0
- package/dist/src/codecs/api/payment.d.ts.map +1 -0
- package/dist/src/codecs/api/payment.js +153 -0
- package/dist/src/codecs/api/transaction.d.ts +138 -0
- package/dist/src/codecs/api/transaction.d.ts.map +1 -0
- package/dist/src/codecs/api/transaction.js +122 -0
- package/dist/src/codecs/api/wallet.d.ts +99 -0
- package/dist/src/codecs/api/wallet.d.ts.map +1 -0
- package/dist/src/codecs/api/wallet.js +103 -0
- package/dist/src/codecs/api/withdraw.d.ts +92 -0
- package/dist/src/codecs/api/withdraw.d.ts.map +1 -0
- package/dist/src/codecs/api/withdraw.js +92 -0
- package/dist/src/codecs/index.d.ts +3 -0
- package/dist/src/codecs/index.d.ts.map +1 -0
- package/dist/src/codecs/index.js +19 -0
- package/dist/src/codecs/shared.d.ts +7 -0
- package/dist/src/codecs/shared.d.ts.map +1 -0
- package/dist/src/codecs/shared.js +42 -0
- package/dist/src/index.d.ts +3 -0
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +4 -1
- package/dist/src/lightning/index.d.ts +5 -0
- package/dist/src/lightning/index.d.ts.map +1 -0
- package/dist/src/lightning/index.js +21 -0
- package/dist/src/lightning/lightningUtils.d.ts +90 -0
- package/dist/src/lightning/lightningUtils.d.ts.map +1 -0
- package/dist/src/lightning/lightningUtils.js +290 -0
- package/dist/src/lightning/parseWithdrawPsbt.d.ts +8 -0
- package/dist/src/lightning/parseWithdrawPsbt.d.ts.map +1 -0
- package/dist/src/lightning/parseWithdrawPsbt.js +155 -0
- package/dist/src/lightning/signableJson.d.ts +17 -0
- package/dist/src/lightning/signableJson.d.ts.map +1 -0
- package/dist/src/lightning/signableJson.js +29 -0
- package/dist/src/lightning/signature.d.ts +22 -0
- package/dist/src/lightning/signature.d.ts.map +1 -0
- package/dist/src/lightning/signature.js +69 -0
- package/dist/src/wallet/custodialLightning.d.ts +7 -0
- package/dist/src/wallet/custodialLightning.d.ts.map +1 -0
- package/dist/src/wallet/custodialLightning.js +14 -0
- package/dist/src/wallet/index.d.ts +5 -0
- package/dist/src/wallet/index.d.ts.map +1 -0
- package/dist/src/wallet/index.js +21 -0
- package/dist/src/wallet/lightning.d.ts +141 -0
- package/dist/src/wallet/lightning.d.ts.map +1 -0
- package/dist/src/wallet/lightning.js +288 -0
- package/dist/src/wallet/selfCustodialLightning.d.ts +32 -0
- package/dist/src/wallet/selfCustodialLightning.d.ts.map +1 -0
- package/dist/src/wallet/selfCustodialLightning.js +131 -0
- package/dist/src/wallet/wallet.d.ts +7 -0
- package/dist/src/wallet/wallet.d.ts.map +1 -0
- package/dist/src/wallet/wallet.js +22 -0
- package/dist/test/unit/lightning/codecs.d.ts +2 -0
- package/dist/test/unit/lightning/codecs.d.ts.map +1 -0
- package/dist/test/unit/lightning/codecs.js +151 -0
- package/dist/test/unit/lightning/createWatchOnlyFixture.d.ts +4 -0
- package/dist/test/unit/lightning/createWatchOnlyFixture.d.ts.map +1 -0
- package/dist/test/unit/lightning/createWatchOnlyFixture.js +1561 -0
- package/dist/test/unit/lightning/lightningUtils.d.ts +2 -0
- package/dist/test/unit/lightning/lightningUtils.d.ts.map +1 -0
- package/dist/test/unit/lightning/lightningUtils.js +123 -0
- package/dist/test/unit/lightning/parseWithdrawPsbt.d.ts +2 -0
- package/dist/test/unit/lightning/parseWithdrawPsbt.d.ts.map +1 -0
- package/dist/test/unit/lightning/parseWithdrawPsbt.js +125 -0
- package/dist/test/unit/lightning/signableJson.d.ts +2 -0
- package/dist/test/unit/lightning/signableJson.d.ts.map +1 -0
- package/dist/test/unit/lightning/signableJson.js +52 -0
- package/dist/test/unit/lightning/signature.d.ts +2 -0
- package/dist/test/unit/lightning/signature.d.ts.map +1 -0
- package/dist/test/unit/lightning/signature.js +91 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/package.json +19 -6
- package/.eslintignore +0 -5
- package/.mocharc.yml +0 -8
- package/CHANGELOG.md +0 -76
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lightningUtils.d.ts","sourceRoot":"","sources":["../../../../test/unit/lightning/lightningUtils.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,123 @@
|
|
|
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
|
+
const assert_1 = __importDefault(require("assert"));
|
|
40
|
+
const macaroon_1 = require("macaroon");
|
|
41
|
+
const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
|
|
42
|
+
const createWatchOnlyFixture_1 = require("./createWatchOnlyFixture");
|
|
43
|
+
const lightning_1 = require("../../../src/lightning");
|
|
44
|
+
const sdkcore = __importStar(require("@bitgo-beta/sdk-core"));
|
|
45
|
+
describe('lightning utils', function () {
|
|
46
|
+
[
|
|
47
|
+
{ name: 'lnbtc', networkName: 'bitcoin' },
|
|
48
|
+
{ name: 'tlnbtc', networkName: 'testnet' },
|
|
49
|
+
].forEach(({ name, networkName }) => {
|
|
50
|
+
describe(`success - coin ${name} and network ${networkName}`, function () {
|
|
51
|
+
it(`isValidLightningNetworkName and getLightningNetwork`, function () {
|
|
52
|
+
(0, assert_1.default)((0, lightning_1.isValidLightningNetworkName)(networkName));
|
|
53
|
+
const network = (0, lightning_1.getLightningNetwork)(networkName);
|
|
54
|
+
assert_1.default.strictEqual(network, utxolib.networks[networkName]);
|
|
55
|
+
});
|
|
56
|
+
it(`isValidLightningNetwork`, function () {
|
|
57
|
+
(0, assert_1.default)((0, lightning_1.isValidLightningNetworkName)(networkName));
|
|
58
|
+
(0, assert_1.default)((0, lightning_1.isValidLightningNetwork)(utxolib.networks[networkName]));
|
|
59
|
+
});
|
|
60
|
+
it(`getStaticsLightningNetwork`, function () {
|
|
61
|
+
assert_1.default.strictEqual((0, lightning_1.getStaticsLightningNetwork)(name).family, 'lnbtc');
|
|
62
|
+
});
|
|
63
|
+
it(`getUtxolibNetwork`, function () {
|
|
64
|
+
assert_1.default.strictEqual((0, lightning_1.getUtxolibNetwork)(name), networkName === 'bitcoin' ? utxolib.networks.bitcoin : utxolib.networks.testnet);
|
|
65
|
+
});
|
|
66
|
+
it(`isLightningCoinName`, function () {
|
|
67
|
+
assert_1.default.strictEqual((0, lightning_1.isLightningCoinName)(name), true);
|
|
68
|
+
assert_1.default.strictEqual((0, lightning_1.isLightningCoinName)('ltc'), false);
|
|
69
|
+
});
|
|
70
|
+
});
|
|
71
|
+
});
|
|
72
|
+
it(`isValidLightningNetworkName should return false for non lightning network name`, function () {
|
|
73
|
+
assert_1.default.strictEqual((0, lightning_1.isValidLightningNetworkName)('litecoin'), false);
|
|
74
|
+
});
|
|
75
|
+
it(`isValidLightningNetwork should return false for non lightning network`, function () {
|
|
76
|
+
assert_1.default.strictEqual((0, lightning_1.isValidLightningNetwork)(utxolib.networks['litecoin']), false);
|
|
77
|
+
});
|
|
78
|
+
it(`getUtxolibNetwork should return fail for invalid lightning coin`, function () {
|
|
79
|
+
assert_1.default.throws(() => {
|
|
80
|
+
(0, lightning_1.getUtxolibNetwork)('ltc');
|
|
81
|
+
}, /ltc is not a lightning coin/);
|
|
82
|
+
});
|
|
83
|
+
it(`createWatchOnly`, function () {
|
|
84
|
+
const watchOnly = (0, lightning_1.createWatchOnly)(createWatchOnlyFixture_1.signerRootKey, utxolib.networks.testnet);
|
|
85
|
+
assert_1.default.deepStrictEqual(watchOnly.accounts, createWatchOnlyFixture_1.accounts);
|
|
86
|
+
assert_1.default.strictEqual(watchOnly.master_key_fingerprint, utxolib.bip32.fromBase58(createWatchOnlyFixture_1.signerRootKey, utxolib.networks.testnet).fingerprint.toString('hex'));
|
|
87
|
+
});
|
|
88
|
+
it(`addIPCaveatToMacaroon`, function () {
|
|
89
|
+
const macaroon = 'AgEDbG5kAvgBAwoQMgU7rDi802Yqg/tHll24nhIBMBoWCgdhZGRyZXNzEgRyZWFkEgV3cml0ZRoTCgRpbmZvEgRyZWFkEgV3cml0ZRoXCghpbnZvaWNlcxIEcmVhZBIFd3JpdGUaIQoIbWFjYXJvb24SCGdlbmVyYXRlEgRyZWFkEgV3cml0ZRoWCgdtZXNzYWdlEgRyZWFkEgV3cml0ZRoXCghvZmZjaGFpbhIEcmVhZBIFd3JpdGUaFgoHb25jaGFpbhIEcmVhZBIFd3JpdGUaFAoFcGVlcnMSBHJlYWQSBXdyaXRlGhgKBnNpZ25lchIIZ2VuZXJhdGUSBHJlYWQAAAYgZKiUvEzxGd2QKGUS+9R5ZWevG09S06fMJUnt+k1XXXQ=';
|
|
90
|
+
const macaroonObj = (0, macaroon_1.importMacaroon)(macaroon).exportJSON();
|
|
91
|
+
assert_1.default.strictEqual(macaroonObj.c, undefined);
|
|
92
|
+
const macaroonWithCaveat = (0, lightning_1.addIPCaveatToMacaroon)(macaroon, '127.0.0.1');
|
|
93
|
+
const macaroonObjWithCaveat = (0, macaroon_1.importMacaroon)(macaroonWithCaveat).exportJSON();
|
|
94
|
+
assert_1.default.strictEqual(macaroonObjWithCaveat.c[0].i, 'ipaddr 127.0.0.1');
|
|
95
|
+
});
|
|
96
|
+
it(`deriveLightningServiceSharedSecret`, function () {
|
|
97
|
+
const userAuthXprv = 'xprv9s21ZrQH143K4NPkV8riiTnFf72MRyQDVHMmmpekGF1w5QkS2MfTei9KXYvrZVMop4zQ4arnzSF7TRp3Cy73AWaDdADiYMCi5qpYW1bUa5m';
|
|
98
|
+
const lightningServicePubKey = (0, lightning_1.getStaticsLightningNetwork)('tlnbtc').lightningServicePubKey;
|
|
99
|
+
const expectedSecret = sdkcore.getSharedSecret(utxolib.bip32.fromBase58(userAuthXprv), Buffer.from(lightningServicePubKey, 'hex'));
|
|
100
|
+
const secret = (0, lightning_1.deriveLightningServiceSharedSecret)('tlnbtc', userAuthXprv);
|
|
101
|
+
assert_1.default.deepStrictEqual(secret, expectedSecret);
|
|
102
|
+
});
|
|
103
|
+
it(`deriveMiddlewareSharedSecret`, function () {
|
|
104
|
+
const userAuthXprv = 'xprv9s21ZrQH143K4NPkV8riiTnFf72MRyQDVHMmmpekGF1w5QkS2MfTei9KXYvrZVMop4zQ4arnzSF7TRp3Cy73AWaDdADiYMCi5qpYW1bUa5m';
|
|
105
|
+
const middlewarePubKey = (0, lightning_1.getStaticsLightningNetwork)('tlnbtc').middlewarePubKey;
|
|
106
|
+
const expectedSecret = sdkcore.getSharedSecret(utxolib.bip32.fromBase58(userAuthXprv), Buffer.from(middlewarePubKey, 'hex'));
|
|
107
|
+
const secret = (0, lightning_1.deriveMiddlewareSharedSecret)('tlnbtc', userAuthXprv);
|
|
108
|
+
assert_1.default.deepStrictEqual(secret, expectedSecret);
|
|
109
|
+
});
|
|
110
|
+
it(`deriveTatSharedSecret`, function () {
|
|
111
|
+
const userXprv = 'xprv9s21ZrQH143K4NPkV8riiTnFf72MRyQDVHMmmpekGF1w5QkS2MfTei9KXYvrZVMop4zQ4arnzSF7TRp3Cy73AWaDdADiYMCi5qpYW1bUa5m';
|
|
112
|
+
const tatPubKey = (0, lightning_1.getStaticsLightningNetwork)('tlnbtc').tatPubKey;
|
|
113
|
+
const expectedSecret = sdkcore.getSharedSecret(utxolib.bip32.fromBase58(userXprv), Buffer.from(tatPubKey, 'hex'));
|
|
114
|
+
const secret = (0, lightning_1.deriveTatSharedSecret)('tlnbtc', userXprv);
|
|
115
|
+
assert_1.default.deepStrictEqual(secret, expectedSecret);
|
|
116
|
+
});
|
|
117
|
+
it(`computeBip32DerivationIndexFromSeed`, function () {
|
|
118
|
+
const seed1 = 'The Times 03/Jan/2009 Chancellor on brink of second bailout for banks.';
|
|
119
|
+
const seed2 = 'The Times 04/Jan/2009 Chancellor on brink of second bailout for banks.';
|
|
120
|
+
assert_1.default.notDeepStrictEqual((0, lightning_1.computeBip32DerivationIndexFromSeed)(seed1), (0, lightning_1.computeBip32DerivationIndexFromSeed)(seed2));
|
|
121
|
+
});
|
|
122
|
+
});
|
|
123
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lightningUtils.js","sourceRoot":"","sources":["../../../../test/unit/lightning/lightningUtils.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\nimport { importMacaroon } from 'macaroon';\nimport * as utxolib from '@bitgo-beta/utxo-lib';\n\nimport { accounts, signerRootKey } from './createWatchOnlyFixture';\nimport {\n  isValidLightningNetworkName,\n  getLightningNetwork,\n  isValidLightningNetwork,\n  getStaticsLightningNetwork,\n  getUtxolibNetwork,\n  isLightningCoinName,\n  createWatchOnly,\n  addIPCaveatToMacaroon,\n  deriveLightningServiceSharedSecret,\n  deriveMiddlewareSharedSecret,\n  deriveTatSharedSecret,\n  computeBip32DerivationIndexFromSeed,\n} from '../../../src/lightning';\n\nimport * as sdkcore from '@bitgo-beta/sdk-core';\n\ndescribe('lightning utils', function () {\n  [\n    { name: 'lnbtc', networkName: 'bitcoin' },\n    { name: 'tlnbtc', networkName: 'testnet' },\n  ].forEach(({ name, networkName }) => {\n    describe(`success - coin ${name} and network ${networkName}`, function () {\n      it(`isValidLightningNetworkName and getLightningNetwork`, function () {\n        assert(isValidLightningNetworkName(networkName));\n        const network = getLightningNetwork(networkName);\n        assert.strictEqual(network, utxolib.networks[networkName]);\n      });\n\n      it(`isValidLightningNetwork`, function () {\n        assert(isValidLightningNetworkName(networkName));\n        assert(isValidLightningNetwork(utxolib.networks[networkName]));\n      });\n\n      it(`getStaticsLightningNetwork`, function () {\n        assert.strictEqual(getStaticsLightningNetwork(name).family, 'lnbtc');\n      });\n\n      it(`getUtxolibNetwork`, function () {\n        assert.strictEqual(\n          getUtxolibNetwork(name),\n          networkName === 'bitcoin' ? utxolib.networks.bitcoin : utxolib.networks.testnet\n        );\n      });\n\n      it(`isLightningCoinName`, function () {\n        assert.strictEqual(isLightningCoinName(name), true);\n        assert.strictEqual(isLightningCoinName('ltc'), false);\n      });\n    });\n  });\n\n  it(`isValidLightningNetworkName should return false for non lightning network name`, function () {\n    assert.strictEqual(isValidLightningNetworkName('litecoin'), false);\n  });\n\n  it(`isValidLightningNetwork should return false for non lightning network`, function () {\n    assert.strictEqual(isValidLightningNetwork(utxolib.networks['litecoin']), false);\n  });\n\n  it(`getUtxolibNetwork should return fail for invalid lightning coin`, function () {\n    assert.throws(() => {\n      getUtxolibNetwork('ltc');\n    }, /ltc is not a lightning coin/);\n  });\n\n  it(`createWatchOnly`, function () {\n    const watchOnly = createWatchOnly(signerRootKey, utxolib.networks.testnet);\n    assert.deepStrictEqual(watchOnly.accounts, accounts);\n    assert.strictEqual(\n      watchOnly.master_key_fingerprint,\n      utxolib.bip32.fromBase58(signerRootKey, utxolib.networks.testnet).fingerprint.toString('hex')\n    );\n  });\n\n  it(`addIPCaveatToMacaroon`, function () {\n    const macaroon =\n      'AgEDbG5kAvgBAwoQMgU7rDi802Yqg/tHll24nhIBMBoWCgdhZGRyZXNzEgRyZWFkEgV3cml0ZRoTCgRpbmZvEgRyZWFkEgV3cml0ZRoXCghpbnZvaWNlcxIEcmVhZBIFd3JpdGUaIQoIbWFjYXJvb24SCGdlbmVyYXRlEgRyZWFkEgV3cml0ZRoWCgdtZXNzYWdlEgRyZWFkEgV3cml0ZRoXCghvZmZjaGFpbhIEcmVhZBIFd3JpdGUaFgoHb25jaGFpbhIEcmVhZBIFd3JpdGUaFAoFcGVlcnMSBHJlYWQSBXdyaXRlGhgKBnNpZ25lchIIZ2VuZXJhdGUSBHJlYWQAAAYgZKiUvEzxGd2QKGUS+9R5ZWevG09S06fMJUnt+k1XXXQ=';\n    const macaroonObj = importMacaroon(macaroon).exportJSON();\n    assert.strictEqual(macaroonObj.c, undefined);\n    const macaroonWithCaveat = addIPCaveatToMacaroon(macaroon, '127.0.0.1');\n    const macaroonObjWithCaveat = importMacaroon(macaroonWithCaveat).exportJSON();\n    assert.strictEqual(macaroonObjWithCaveat.c[0].i, 'ipaddr 127.0.0.1');\n  });\n\n  it(`deriveLightningServiceSharedSecret`, function () {\n    const userAuthXprv =\n      'xprv9s21ZrQH143K4NPkV8riiTnFf72MRyQDVHMmmpekGF1w5QkS2MfTei9KXYvrZVMop4zQ4arnzSF7TRp3Cy73AWaDdADiYMCi5qpYW1bUa5m';\n    const lightningServicePubKey = getStaticsLightningNetwork('tlnbtc').lightningServicePubKey;\n\n    const expectedSecret = sdkcore.getSharedSecret(\n      utxolib.bip32.fromBase58(userAuthXprv),\n      Buffer.from(lightningServicePubKey, 'hex')\n    );\n\n    const secret = deriveLightningServiceSharedSecret('tlnbtc', userAuthXprv);\n\n    assert.deepStrictEqual(secret, expectedSecret);\n  });\n\n  it(`deriveMiddlewareSharedSecret`, function () {\n    const userAuthXprv =\n      'xprv9s21ZrQH143K4NPkV8riiTnFf72MRyQDVHMmmpekGF1w5QkS2MfTei9KXYvrZVMop4zQ4arnzSF7TRp3Cy73AWaDdADiYMCi5qpYW1bUa5m';\n    const middlewarePubKey = getStaticsLightningNetwork('tlnbtc').middlewarePubKey;\n\n    const expectedSecret = sdkcore.getSharedSecret(\n      utxolib.bip32.fromBase58(userAuthXprv),\n      Buffer.from(middlewarePubKey, 'hex')\n    );\n\n    const secret = deriveMiddlewareSharedSecret('tlnbtc', userAuthXprv);\n\n    assert.deepStrictEqual(secret, expectedSecret);\n  });\n\n  it(`deriveTatSharedSecret`, function () {\n    const userXprv =\n      'xprv9s21ZrQH143K4NPkV8riiTnFf72MRyQDVHMmmpekGF1w5QkS2MfTei9KXYvrZVMop4zQ4arnzSF7TRp3Cy73AWaDdADiYMCi5qpYW1bUa5m';\n    const tatPubKey = getStaticsLightningNetwork('tlnbtc').tatPubKey;\n    const expectedSecret = sdkcore.getSharedSecret(utxolib.bip32.fromBase58(userXprv), Buffer.from(tatPubKey, 'hex'));\n    const secret = deriveTatSharedSecret('tlnbtc', userXprv);\n    assert.deepStrictEqual(secret, expectedSecret);\n  });\n\n  it(`computeBip32DerivationIndexFromSeed`, function () {\n    const seed1 = 'The Times 03/Jan/2009 Chancellor on brink of second bailout for banks.';\n    const seed2 = 'The Times 04/Jan/2009 Chancellor on brink of second bailout for banks.';\n    assert.notDeepStrictEqual(computeBip32DerivationIndexFromSeed(seed1), computeBip32DerivationIndexFromSeed(seed2));\n  });\n});\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"parseWithdrawPsbt.d.ts","sourceRoot":"","sources":["../../../../test/unit/lightning/parseWithdrawPsbt.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,125 @@
|
|
|
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
|
+
const src_1 = require("../../../src");
|
|
40
|
+
const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
|
|
41
|
+
const assert_1 = __importDefault(require("assert"));
|
|
42
|
+
describe('parseWithdrawPsbt', () => {
|
|
43
|
+
const unsignedPsbtHex = '70736274ff01007d02000000015e50b8d96cebdc3273d9a100eb68392d980d5b934b8170c80a23488b595268ca0100000000ffffffff02a086010000000000225120379bc88cc15d3605ed9de1b61ff8d65021b650db1151e751a30885ccfcc7d15affa80a000000000016001480a06f2e6b77e817fd5de6e41ea512c563c26cb800000000000100ea02000000000101a158d806735bb7c54e4c701d4f5821cd5342d48d5e1fcbed1169e6e45aa444be0100000000ffffffff02a086010000000000225120379bc88cc15d3605ed9de1b61ff8d65021b650db1151e751a30885ccfcc7d15a6a310c000000000016001478a5d98c7160484b9b00f1782803c58edfc49b9a024730440220407d9162f52371df246dcfa2943d40fbdcb0d4b6768f7682c65193378b2845a60220101c7bc460c93d2976961ac23400f0f10c145efb989a3addb7f03ebaaa2200950121037e17444c85c8b7da07f12fd53cb2ca142c2b4932d0f898649c4b5be0021da0980000000001030401000000220602e57146e5b4762a7ff374adf4072047b67ef115ad46a34189bdeb6a4f88db9b0818000000005400008000000080000000800100000006000000000022020379abbe44004ff7e527bdee3dd8d95e5cd250053f35ee92258b97aa83dfa93c621800000000540000800000008000000080010000005000000000';
|
|
44
|
+
const network = utxolib.networks.testnet;
|
|
45
|
+
const recipients = [
|
|
46
|
+
{
|
|
47
|
+
amountSat: 100000n,
|
|
48
|
+
address: 'tb1px7du3rxpt5mqtmvauxmpl7xk2qsmv5xmz9g7w5drpzzuelx869dqwape7k',
|
|
49
|
+
},
|
|
50
|
+
];
|
|
51
|
+
const accounts = [
|
|
52
|
+
{
|
|
53
|
+
xpub: 'tpubDCmiWMkTJrZ24t1Z6ECR3HyynCyZ9zGsWqhcLh6H4yFK2CDozSszD1pP2Li4Nx1YYtRcvmNbdb3nD1SzFejYtPFfTocTv2EaAgJCg4zpJpA',
|
|
54
|
+
purpose: 49,
|
|
55
|
+
coin_type: 0,
|
|
56
|
+
account: 0,
|
|
57
|
+
},
|
|
58
|
+
{
|
|
59
|
+
xpub: 'tpubDCFN7bsxR9UTKggdH2pmv5HeHGQNiDrJwa1EZFtP9sH5PF28i37FHpoYSYARQkKZ6Mi98pkp7oypDcxFmE4dQGq8jV8Gv3L6gmWBeRwPxkP',
|
|
60
|
+
purpose: 84,
|
|
61
|
+
coin_type: 0,
|
|
62
|
+
account: 0,
|
|
63
|
+
},
|
|
64
|
+
];
|
|
65
|
+
it('should parse a valid withdraw PSBT', () => {
|
|
66
|
+
(0, src_1.validatePsbtForWithdraw)(unsignedPsbtHex, network, recipients, accounts);
|
|
67
|
+
});
|
|
68
|
+
it('should throw for invalid PSBT', () => {
|
|
69
|
+
assert_1.default.throws(() => {
|
|
70
|
+
(0, src_1.validatePsbtForWithdraw)('asdasd', network, recipients, accounts);
|
|
71
|
+
}, /ERR_BUFFER_OUT_OF_BOUNDS/);
|
|
72
|
+
});
|
|
73
|
+
it('should throw for invalid recipient address', () => {
|
|
74
|
+
const differentRecipients = [
|
|
75
|
+
{
|
|
76
|
+
...recipients[0],
|
|
77
|
+
address: 'tb1qxyzxyzxyzxyzxyzxyzxyzxyzxyzxyzxyzxyzxyzxyzxyzxyzxyz',
|
|
78
|
+
},
|
|
79
|
+
];
|
|
80
|
+
assert_1.default.throws(() => {
|
|
81
|
+
(0, src_1.validatePsbtForWithdraw)(unsignedPsbtHex, network, differentRecipients, accounts);
|
|
82
|
+
}, /PSBT output tb1px7du3rxpt5mqtmvauxmpl7xk2qsmv5xmz9g7w5drpzzuelx869dqwape7k with value 100000 does not match any recipient/);
|
|
83
|
+
});
|
|
84
|
+
it('should throw for invalid recipient value', () => {
|
|
85
|
+
const differentRecipients = [
|
|
86
|
+
{
|
|
87
|
+
...recipients[0],
|
|
88
|
+
amountSat: 99999n,
|
|
89
|
+
},
|
|
90
|
+
];
|
|
91
|
+
assert_1.default.throws(() => {
|
|
92
|
+
(0, src_1.validatePsbtForWithdraw)(unsignedPsbtHex, network, differentRecipients, accounts);
|
|
93
|
+
}, /PSBT output tb1px7du3rxpt5mqtmvauxmpl7xk2qsmv5xmz9g7w5drpzzuelx869dqwape7k with value 100000 does not match any recipient/);
|
|
94
|
+
});
|
|
95
|
+
it('should throw for account not found', () => {
|
|
96
|
+
const incompatibleAccounts = [];
|
|
97
|
+
assert_1.default.throws(() => {
|
|
98
|
+
(0, src_1.validatePsbtForWithdraw)(unsignedPsbtHex, network, recipients, incompatibleAccounts);
|
|
99
|
+
}, /Account not found for purpose/);
|
|
100
|
+
});
|
|
101
|
+
it('should throw for invalid pubkey', () => {
|
|
102
|
+
const incompatibleAccounts = [
|
|
103
|
+
{
|
|
104
|
+
...accounts[1],
|
|
105
|
+
xpub: 'tpubDCmiWMkTJrZ24t1Z6ECR3HyynCyZ9zGsWqhcLh6H4yFK2CDozSszD1pP2Li4Nx1YYtRcvmNbdb3nD1SzFejYtPFfTocTv2EaAgJCg4zpJpA',
|
|
106
|
+
},
|
|
107
|
+
];
|
|
108
|
+
assert_1.default.throws(() => {
|
|
109
|
+
(0, src_1.validatePsbtForWithdraw)(unsignedPsbtHex, network, recipients, incompatibleAccounts);
|
|
110
|
+
}, /Derived pubkey does not match for address/);
|
|
111
|
+
});
|
|
112
|
+
it('should throw for invalid purpose', () => {
|
|
113
|
+
const incompatibleAccounts = [
|
|
114
|
+
{
|
|
115
|
+
...accounts[1],
|
|
116
|
+
purpose: 1017,
|
|
117
|
+
},
|
|
118
|
+
];
|
|
119
|
+
const incompatiblePsbt = `70736274ff01007d02000000015e50b8d96cebdc3273d9a100eb68392d980d5b934b8170c80a23488b595268ca0100000000ffffffff02a086010000000000225120379bc88cc15d3605ed9de1b61ff8d65021b650db1151e751a30885ccfcc7d15affa80a000000000016001480a06f2e6b77e817fd5de6e41ea512c563c26cb800000000000100ea02000000000101a158d806735bb7c54e4c701d4f5821cd5342d48d5e1fcbed1169e6e45aa444be0100000000ffffffff02a086010000000000225120379bc88cc15d3605ed9de1b61ff8d65021b650db1151e751a30885ccfcc7d15a6a310c000000000016001478a5d98c7160484b9b00f1782803c58edfc49b9a024730440220407d9162f52371df246dcfa2943d40fbdcb0d4b6768f7682c65193378b2845a60220101c7bc460c93d2976961ac23400f0f10c145efb989a3addb7f03ebaaa2200950121037e17444c85c8b7da07f12fd53cb2ca142c2b4932d0f898649c4b5be0021da0980000000001030401000000220602e57146e5b4762a7ff374adf4072047b67ef115ad46a34189bdeb6a4f88db9b0818000000005400008000000080000000800100000006000000000022020379abbe44004ff7e527bdee3dd8d95e5cd250053f35ee92258b97aa83dfa93c621800000000f90300800000008000000080010000005000000000`;
|
|
120
|
+
assert_1.default.throws(() => {
|
|
121
|
+
(0, src_1.validatePsbtForWithdraw)(incompatiblePsbt, network, recipients, incompatibleAccounts);
|
|
122
|
+
}, /Unsupported purpose/);
|
|
123
|
+
});
|
|
124
|
+
});
|
|
125
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"parseWithdrawPsbt.js","sourceRoot":"","sources":["../../../../test/unit/lightning/parseWithdrawPsbt.ts"],"names":[],"mappings":"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","sourcesContent":["import { validatePsbtForWithdraw } from '../../../src';\nimport * as utxolib from '@bitgo-beta/utxo-lib';\nimport assert from 'assert';\n\ndescribe('parseWithdrawPsbt', () => {\n  const unsignedPsbtHex =\n    '70736274ff01007d02000000015e50b8d96cebdc3273d9a100eb68392d980d5b934b8170c80a23488b595268ca0100000000ffffffff02a086010000000000225120379bc88cc15d3605ed9de1b61ff8d65021b650db1151e751a30885ccfcc7d15affa80a000000000016001480a06f2e6b77e817fd5de6e41ea512c563c26cb800000000000100ea02000000000101a158d806735bb7c54e4c701d4f5821cd5342d48d5e1fcbed1169e6e45aa444be0100000000ffffffff02a086010000000000225120379bc88cc15d3605ed9de1b61ff8d65021b650db1151e751a30885ccfcc7d15a6a310c000000000016001478a5d98c7160484b9b00f1782803c58edfc49b9a024730440220407d9162f52371df246dcfa2943d40fbdcb0d4b6768f7682c65193378b2845a60220101c7bc460c93d2976961ac23400f0f10c145efb989a3addb7f03ebaaa2200950121037e17444c85c8b7da07f12fd53cb2ca142c2b4932d0f898649c4b5be0021da0980000000001030401000000220602e57146e5b4762a7ff374adf4072047b67ef115ad46a34189bdeb6a4f88db9b0818000000005400008000000080000000800100000006000000000022020379abbe44004ff7e527bdee3dd8d95e5cd250053f35ee92258b97aa83dfa93c621800000000540000800000008000000080010000005000000000';\n  const network = utxolib.networks.testnet;\n  const recipients = [\n    {\n      amountSat: 100000n,\n      address: 'tb1px7du3rxpt5mqtmvauxmpl7xk2qsmv5xmz9g7w5drpzzuelx869dqwape7k',\n    },\n  ];\n  const accounts = [\n    {\n      xpub: 'tpubDCmiWMkTJrZ24t1Z6ECR3HyynCyZ9zGsWqhcLh6H4yFK2CDozSszD1pP2Li4Nx1YYtRcvmNbdb3nD1SzFejYtPFfTocTv2EaAgJCg4zpJpA',\n      purpose: 49,\n      coin_type: 0,\n      account: 0,\n    },\n    {\n      xpub: 'tpubDCFN7bsxR9UTKggdH2pmv5HeHGQNiDrJwa1EZFtP9sH5PF28i37FHpoYSYARQkKZ6Mi98pkp7oypDcxFmE4dQGq8jV8Gv3L6gmWBeRwPxkP',\n      purpose: 84,\n      coin_type: 0,\n      account: 0,\n    },\n  ];\n  it('should parse a valid withdraw PSBT', () => {\n    validatePsbtForWithdraw(unsignedPsbtHex, network, recipients, accounts);\n  });\n  it('should throw for invalid PSBT', () => {\n    assert.throws(() => {\n      validatePsbtForWithdraw('asdasd', network, recipients, accounts);\n    }, /ERR_BUFFER_OUT_OF_BOUNDS/);\n  });\n  it('should throw for invalid recipient address', () => {\n    const differentRecipients = [\n      {\n        ...recipients[0],\n        address: 'tb1qxyzxyzxyzxyzxyzxyzxyzxyzxyzxyzxyzxyzxyzxyzxyzxyzxyz',\n      },\n    ];\n    assert.throws(() => {\n      validatePsbtForWithdraw(unsignedPsbtHex, network, differentRecipients, accounts);\n    }, /PSBT output tb1px7du3rxpt5mqtmvauxmpl7xk2qsmv5xmz9g7w5drpzzuelx869dqwape7k with value 100000 does not match any recipient/);\n  });\n  it('should throw for invalid recipient value', () => {\n    const differentRecipients = [\n      {\n        ...recipients[0],\n        amountSat: 99999n,\n      },\n    ];\n    assert.throws(() => {\n      validatePsbtForWithdraw(unsignedPsbtHex, network, differentRecipients, accounts);\n    }, /PSBT output tb1px7du3rxpt5mqtmvauxmpl7xk2qsmv5xmz9g7w5drpzzuelx869dqwape7k with value 100000 does not match any recipient/);\n  });\n  it('should throw for account not found', () => {\n    const incompatibleAccounts = [];\n    assert.throws(() => {\n      validatePsbtForWithdraw(unsignedPsbtHex, network, recipients, incompatibleAccounts);\n    }, /Account not found for purpose/);\n  });\n  it('should throw for invalid pubkey', () => {\n    const incompatibleAccounts = [\n      {\n        ...accounts[1],\n        xpub: 'tpubDCmiWMkTJrZ24t1Z6ECR3HyynCyZ9zGsWqhcLh6H4yFK2CDozSszD1pP2Li4Nx1YYtRcvmNbdb3nD1SzFejYtPFfTocTv2EaAgJCg4zpJpA',\n      },\n    ];\n    assert.throws(() => {\n      validatePsbtForWithdraw(unsignedPsbtHex, network, recipients, incompatibleAccounts);\n    }, /Derived pubkey does not match for address/);\n  });\n  it('should throw for invalid purpose', () => {\n    const incompatibleAccounts = [\n      {\n        ...accounts[1],\n        purpose: 1017,\n      },\n    ];\n    const incompatiblePsbt = `70736274ff01007d02000000015e50b8d96cebdc3273d9a100eb68392d980d5b934b8170c80a23488b595268ca0100000000ffffffff02a086010000000000225120379bc88cc15d3605ed9de1b61ff8d65021b650db1151e751a30885ccfcc7d15affa80a000000000016001480a06f2e6b77e817fd5de6e41ea512c563c26cb800000000000100ea02000000000101a158d806735bb7c54e4c701d4f5821cd5342d48d5e1fcbed1169e6e45aa444be0100000000ffffffff02a086010000000000225120379bc88cc15d3605ed9de1b61ff8d65021b650db1151e751a30885ccfcc7d15a6a310c000000000016001478a5d98c7160484b9b00f1782803c58edfc49b9a024730440220407d9162f52371df246dcfa2943d40fbdcb0d4b6768f7682c65193378b2845a60220101c7bc460c93d2976961ac23400f0f10c145efb989a3addb7f03ebaaa2200950121037e17444c85c8b7da07f12fd53cb2ca142c2b4932d0f898649c4b5be0021da0980000000001030401000000220602e57146e5b4762a7ff374adf4072047b67ef115ad46a34189bdeb6a4f88db9b0818000000005400008000000080000000800100000006000000000022020379abbe44004ff7e527bdee3dd8d95e5cd250053f35ee92258b97aa83dfa93c621800000000f90300800000008000000080010000005000000000`;\n    assert.throws(() => {\n      validatePsbtForWithdraw(incompatiblePsbt, network, recipients, incompatibleAccounts);\n    }, /Unsupported purpose/);\n  });\n});\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"signableJson.d.ts","sourceRoot":"","sources":["../../../../test/unit/lightning/signableJson.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const lightning_1 = require("../../../src/lightning");
|
|
7
|
+
const assert_1 = __importDefault(require("assert"));
|
|
8
|
+
describe('canonicalizeObject', function () {
|
|
9
|
+
it('should return the canonicalized object with sorted keys', function () {
|
|
10
|
+
const input = { b: 1, a: 2 };
|
|
11
|
+
const expected = { a: 2, b: 1 };
|
|
12
|
+
const result = (0, lightning_1.canonicalizeObject)(input);
|
|
13
|
+
assert_1.default.notDeepStrictEqual(JSON.stringify(input), JSON.stringify(expected));
|
|
14
|
+
assert_1.default.deepStrictEqual(JSON.stringify(result), JSON.stringify(expected));
|
|
15
|
+
});
|
|
16
|
+
it('should handle nested objects and sort their keys', function () {
|
|
17
|
+
const input = { b: { d: 4, c: 3 }, a: 2 };
|
|
18
|
+
const expected = { a: 2, b: { c: 3, d: 4 } };
|
|
19
|
+
const result = (0, lightning_1.canonicalizeObject)(input);
|
|
20
|
+
assert_1.default.notDeepStrictEqual(JSON.stringify(input), JSON.stringify(expected));
|
|
21
|
+
assert_1.default.deepStrictEqual(JSON.stringify(result), JSON.stringify(expected));
|
|
22
|
+
});
|
|
23
|
+
it('should handle arrays within objects', function () {
|
|
24
|
+
const input = { b: [3, 2, 1], a: 2 };
|
|
25
|
+
const expected = { a: 2, b: [3, 2, 1] };
|
|
26
|
+
const result = (0, lightning_1.canonicalizeObject)(input);
|
|
27
|
+
assert_1.default.notDeepStrictEqual(JSON.stringify(input), JSON.stringify(expected));
|
|
28
|
+
assert_1.default.deepStrictEqual(JSON.stringify(result), JSON.stringify(expected));
|
|
29
|
+
});
|
|
30
|
+
it('should handle arrays of objects and sort their keys', function () {
|
|
31
|
+
const input = [
|
|
32
|
+
{ b: 2, a: 1 },
|
|
33
|
+
{ d: 4, c: 3 },
|
|
34
|
+
];
|
|
35
|
+
const expected = [
|
|
36
|
+
{ a: 1, b: 2 },
|
|
37
|
+
{ c: 3, d: 4 },
|
|
38
|
+
];
|
|
39
|
+
const result = (0, lightning_1.canonicalizeObject)(input);
|
|
40
|
+
assert_1.default.notDeepStrictEqual(JSON.stringify(input), JSON.stringify(expected));
|
|
41
|
+
assert_1.default.deepStrictEqual(JSON.stringify(result), JSON.stringify(expected));
|
|
42
|
+
});
|
|
43
|
+
it('should return primitive values as is', function () {
|
|
44
|
+
assert_1.default.strictEqual(JSON.stringify((0, lightning_1.canonicalizeObject)(42)), JSON.stringify(42));
|
|
45
|
+
assert_1.default.strictEqual(JSON.stringify((0, lightning_1.canonicalizeObject)('string')), JSON.stringify('string'));
|
|
46
|
+
});
|
|
47
|
+
it('should throw an error for invalid object types', function () {
|
|
48
|
+
assert_1.default.throws(() => (0, lightning_1.canonicalizeObject)(null), /Invalid object type/);
|
|
49
|
+
assert_1.default.throws(() => (0, lightning_1.canonicalizeObject)(undefined), /Invalid object type/);
|
|
50
|
+
});
|
|
51
|
+
});
|
|
52
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lnbmFibGVKc29uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vdGVzdC91bml0L2xpZ2h0bmluZy9zaWduYWJsZUpzb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSxzREFBNEQ7QUFDNUQsb0RBQTRCO0FBRTVCLFFBQVEsQ0FBQyxvQkFBb0IsRUFBRTtJQUM3QixFQUFFLENBQUMseURBQXlELEVBQUU7UUFDNUQsTUFBTSxLQUFLLEdBQUcsRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQztRQUM3QixNQUFNLFFBQVEsR0FBRyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDO1FBQ2hDLE1BQU0sTUFBTSxHQUFHLElBQUEsOEJBQWtCLEVBQUMsS0FBSyxDQUFDLENBQUM7UUFDekMsZ0JBQU0sQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQztRQUMzRSxnQkFBTSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQztJQUMzRSxDQUFDLENBQUMsQ0FBQztJQUVILEVBQUUsQ0FBQyxrREFBa0QsRUFBRTtRQUNyRCxNQUFNLEtBQUssR0FBRyxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQztRQUMxQyxNQUFNLFFBQVEsR0FBRyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQztRQUM3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QUUsQ0FBQyxJQUFBLDhCQUFrQixFQUFDLFNBQWtCLENBQUMsRUFBRSxxQkFBcUIsQ0FBQyxDQUFDO0lBQ3JGLENBQUMsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjYW5vbmljYWxpemVPYmplY3QgfSBmcm9tICcuLi8uLi8uLi9zcmMvbGlnaHRuaW5nJztcbmltcG9ydCBhc3NlcnQgZnJvbSAnYXNzZXJ0JztcblxuZGVzY3JpYmUoJ2Nhbm9uaWNhbGl6ZU9iamVjdCcsIGZ1bmN0aW9uICgpIHtcbiAgaXQoJ3Nob3VsZCByZXR1cm4gdGhlIGNhbm9uaWNhbGl6ZWQgb2JqZWN0IHdpdGggc29ydGVkIGtleXMnLCBmdW5jdGlvbiAoKSB7XG4gICAgY29uc3QgaW5wdXQgPSB7IGI6IDEsIGE6IDIgfTtcbiAgICBjb25zdCBleHBlY3RlZCA9IHsgYTogMiwgYjogMSB9O1xuICAgIGNvbnN0IHJlc3VsdCA9IGNhbm9uaWNhbGl6ZU9iamVjdChpbnB1dCk7XG4gICAgYXNzZXJ0Lm5vdERlZXBTdHJpY3RFcXVhbChKU09OLnN0cmluZ2lmeShpbnB1dCksIEpTT04uc3RyaW5naWZ5KGV4cGVjdGVkKSk7XG4gICAgYXNzZXJ0LmRlZXBTdHJpY3RFcXVhbChKU09OLnN0cmluZ2lmeShyZXN1bHQpLCBKU09OLnN0cmluZ2lmeShleHBlY3RlZCkpO1xuICB9KTtcblxuICBpdCgnc2hvdWxkIGhhbmRsZSBuZXN0ZWQgb2JqZWN0cyBhbmQgc29ydCB0aGVpciBrZXlzJywgZnVuY3Rpb24gKCkge1xuICAgIGNvbnN0IGlucHV0ID0geyBiOiB7IGQ6IDQsIGM6IDMgfSwgYTogMiB9O1xuICAgIGNvbnN0IGV4cGVjdGVkID0geyBhOiAyLCBiOiB7IGM6IDMsIGQ6IDQgfSB9O1xuICAgIGNvbnN0IHJlc3VsdCA9IGNhbm9uaWNhbGl6ZU9iamVjdChpbnB1dCk7XG4gICAgYXNzZXJ0Lm5vdERlZXBTdHJpY3RFcXVhbChKU09OLnN0cmluZ2lmeShpbnB1dCksIEpTT04uc3RyaW5naWZ5KGV4cGVjdGVkKSk7XG4gICAgYXNzZXJ0LmRlZXBTdHJpY3RFcXVhbChKU09OLnN0cmluZ2lmeShyZXN1bHQpLCBKU09OLnN0cmluZ2lmeShleHBlY3RlZCkpO1xuICB9KTtcblxuICBpdCgnc2hvdWxkIGhhbmRsZSBhcnJheXMgd2l0aGluIG9iamVjdHMnLCBmdW5jdGlvbiAoKSB7XG4gICAgY29uc3QgaW5wdXQgPSB7IGI6IFszLCAyLCAxXSwgYTogMiB9O1xuICAgIGNvbnN0IGV4cGVjdGVkID0geyBhOiAyLCBiOiBbMywgMiwgMV0gfTtcbiAgICBjb25zdCByZXN1bHQgPSBjYW5vbmljYWxpemVPYmplY3QoaW5wdXQpO1xuICAgIGFzc2VydC5ub3REZWVwU3RyaWN0RXF1YWwoSlNPTi5zdHJpbmdpZnkoaW5wdXQpLCBKU09OLnN0cmluZ2lmeShleHBlY3RlZCkpO1xuICAgIGFzc2VydC5kZWVwU3RyaWN0RXF1YWwoSlNPTi5zdHJpbmdpZnkocmVzdWx0KSwgSlNPTi5zdHJpbmdpZnkoZXhwZWN0ZWQpKTtcbiAgfSk7XG5cbiAgaXQoJ3Nob3VsZCBoYW5kbGUgYXJyYXlzIG9mIG9iamVjdHMgYW5kIHNvcnQgdGhlaXIga2V5cycsIGZ1bmN0aW9uICgpIHtcbiAgICBjb25zdCBpbnB1dCA9IFtcbiAgICAgIHsgYjogMiwgYTogMSB9LFxuICAgICAgeyBkOiA0LCBjOiAzIH0sXG4gICAgXTtcbiAgICBjb25zdCBleHBlY3RlZCA9IFtcbiAgICAgIHsgYTogMSwgYjogMiB9LFxuICAgICAgeyBjOiAzLCBkOiA0IH0sXG4gICAgXTtcbiAgICBjb25zdCByZXN1bHQgPSBjYW5vbmljYWxpemVPYmplY3QoaW5wdXQpO1xuICAgIGFzc2VydC5ub3REZWVwU3RyaWN0RXF1YWwoSlNPTi5zdHJpbmdpZnkoaW5wdXQpLCBKU09OLnN0cmluZ2lmeShleHBlY3RlZCkpO1xuICAgIGFzc2VydC5kZWVwU3RyaWN0RXF1YWwoSlNPTi5zdHJpbmdpZnkocmVzdWx0KSwgSlNPTi5zdHJpbmdpZnkoZXhwZWN0ZWQpKTtcbiAgfSk7XG5cbiAgaXQoJ3Nob3VsZCByZXR1cm4gcHJpbWl0aXZlIHZhbHVlcyBhcyBpcycsIGZ1bmN0aW9uICgpIHtcbiAgICBhc3NlcnQuc3RyaWN0RXF1YWwoSlNPTi5zdHJpbmdpZnkoY2Fub25pY2FsaXplT2JqZWN0KDQyKSksIEpTT04uc3RyaW5naWZ5KDQyKSk7XG4gICAgYXNzZXJ0LnN0cmljdEVxdWFsKEpTT04uc3RyaW5naWZ5KGNhbm9uaWNhbGl6ZU9iamVjdCgnc3RyaW5nJykpLCBKU09OLnN0cmluZ2lmeSgnc3RyaW5nJykpO1xuICB9KTtcblxuICBpdCgnc2hvdWxkIHRocm93IGFuIGVycm9yIGZvciBpbnZhbGlkIG9iamVjdCB0eXBlcycsIGZ1bmN0aW9uICgpIHtcbiAgICBhc3NlcnQudGhyb3dzKCgpID0+IGNhbm9uaWNhbGl6ZU9iamVjdChudWxsIGFzIG5ldmVyKSwgL0ludmFsaWQgb2JqZWN0IHR5cGUvKTtcbiAgICBhc3NlcnQudGhyb3dzKCgpID0+IGNhbm9uaWNhbGl6ZU9iamVjdCh1bmRlZmluZWQgYXMgbmV2ZXIpLCAvSW52YWxpZCBvYmplY3QgdHlwZS8pO1xuICB9KTtcbn0pO1xuIl19
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"signature.d.ts","sourceRoot":"","sources":["../../../../test/unit/lightning/signature.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,91 @@
|
|
|
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
|
+
const assert_1 = __importDefault(require("assert"));
|
|
40
|
+
const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
|
|
41
|
+
const lightning_1 = require("../../../src/lightning");
|
|
42
|
+
const crypto_1 = __importDefault(require("crypto"));
|
|
43
|
+
function getKey(seed) {
|
|
44
|
+
return utxolib.bip32.fromSeed(crypto_1.default.createHash('sha256').update(seed).digest());
|
|
45
|
+
}
|
|
46
|
+
describe('verifySignature', function () {
|
|
47
|
+
const key = getKey('key');
|
|
48
|
+
const keyPub = key.neutered();
|
|
49
|
+
const wrongKey = getKey('wrongKey');
|
|
50
|
+
it('returns true on valid signature', function () {
|
|
51
|
+
const request = {
|
|
52
|
+
invoice: 'some data',
|
|
53
|
+
};
|
|
54
|
+
const signature = (0, lightning_1.createMessageSignature)(request, key.toBase58());
|
|
55
|
+
const result = (0, lightning_1.verifyMessageSignature)(request, signature, keyPub.toBase58());
|
|
56
|
+
(0, assert_1.default)(result);
|
|
57
|
+
});
|
|
58
|
+
it('returns true on different order', function () {
|
|
59
|
+
const request = {
|
|
60
|
+
invoice: 'some data',
|
|
61
|
+
fee: 123,
|
|
62
|
+
};
|
|
63
|
+
const otherRequest = {
|
|
64
|
+
fee: 123,
|
|
65
|
+
invoice: 'some data',
|
|
66
|
+
};
|
|
67
|
+
const signature = (0, lightning_1.createMessageSignature)(request, key.toBase58());
|
|
68
|
+
const result = (0, lightning_1.verifyMessageSignature)(otherRequest, signature, keyPub.toBase58());
|
|
69
|
+
(0, assert_1.default)(result);
|
|
70
|
+
});
|
|
71
|
+
it('returns false on wrong message', function () {
|
|
72
|
+
const request = {
|
|
73
|
+
invoice: 'some data',
|
|
74
|
+
};
|
|
75
|
+
const wrongRequest = {
|
|
76
|
+
invoice: 'some other data',
|
|
77
|
+
};
|
|
78
|
+
const signature = (0, lightning_1.createMessageSignature)(request, key.toBase58());
|
|
79
|
+
const result = (0, lightning_1.verifyMessageSignature)(wrongRequest, signature, keyPub.toBase58());
|
|
80
|
+
(0, assert_1.default)(!result);
|
|
81
|
+
});
|
|
82
|
+
it('returns false on wrong key', function () {
|
|
83
|
+
const request = {
|
|
84
|
+
invoice: 'some data',
|
|
85
|
+
};
|
|
86
|
+
const signature = (0, lightning_1.createMessageSignature)(request, wrongKey.toBase58());
|
|
87
|
+
const result = (0, lightning_1.verifyMessageSignature)(request, signature, keyPub.toBase58());
|
|
88
|
+
(0, assert_1.default)(!result);
|
|
89
|
+
});
|
|
90
|
+
});
|
|
91
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lnbmF0dXJlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vdGVzdC91bml0L2xpZ2h0bmluZy9zaWduYXR1cmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSxvREFBNEI7QUFFNUIsOERBQWdEO0FBRWhELHNEQUF3RjtBQUN4RixvREFBNEI7QUFPNUIsU0FBUyxNQUFNLENBQUMsSUFBWTtJQUMxQixPQUFPLE9BQU8sQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLGdCQUFNLENBQUMsVUFBVSxDQUFDLFFBQVEsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDO0FBQ25GLENBQUM7QUFFRCxRQUFRLENBQUMsaUJBQWlCLEVBQUU7SUFDMUIsTUFBTSxHQUFHLEdBQUcsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzFCLE1BQU0sTUFBTSxHQUFHLEdBQUcsQ0FBQyxRQUFRLEVBQUUsQ0FBQztJQUM5QixNQUFNLFFBQVEsR0FBRyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUM7SUFFcEMsRUFBRSxDQUFDLGlDQUFpQyxFQUFFO1FBQ3BDLE1BQU0sT0FBTyxHQUFZO1lBQ3ZCLE9BQU8sRUFBRSxXQUFXO1NBQ3JCLENBQUM7UUFDRixNQUFNLFNBQVMsR0FBRyxJQUFBLGtDQUFzQixFQUFDLE9BQU8sRUFBRSxHQUFHLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQztRQUNsRSxNQUFNLE1BQU0sR0FBRyxJQUFBLGtDQUFzQixFQUFDLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxDQUFDLFFBQVEsRUFBRSxDQUFDLENBQUM7UUFDN0UsSUFBQSxnQkFBTSxFQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ2pCLENBQUMsQ0FBQyxDQUFDO0lBRUgsRUFBRSxDQUFDLGlDQUFpQyxFQUFFO1FBQ3BDLE1BQU0sT0FBTyxHQUFZO1lBQ3ZCLE9BQU8sRUFBRSxXQUFXO1lBQ3BCLEdBQUcsRUFBRSxHQUFHO1NBQ1QsQ0FBQztRQUNGLE1BQU0sWUFBWSxHQUFZO1lBQzVCLEdBQUcsRUFBRSxHQUFHO1lBQ1IsT0FBTyxFQUFFLFdBQVc7U0FDckIsQ0FBQztRQUNGLE1BQU0sU0FBUyxHQUFHLElBQUEsa0NBQXNCLEVBQUMsT0FBTyxFQUFFLEdBQUcsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDO1FBQ2xFLE1BQU0sTUFBTSxHQUFHLElBQUEsa0NBQXNCLEVBQUMsWUFBWSxFQUFFLFNBQVMsRUFBRSxNQUFNLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQztRQUNsRixJQUFBLGdCQUFNLEVBQUMsTUFBTSxDQUFDLENBQUM7SUFDakIsQ0FBQyxDQUFDLENBQUM7SUFFSCxFQUFFLENBQUMsZ0NBQWdDLEVBQUU7UUFDbkMsTUFBTSxPQUFPLEdBQVk7WUFDdkIsT0FBTyxFQUFFLFdBQVc7U0FDckIsQ0FBQztRQUNGLE1BQU0sWUFBWSxHQUFZO1lBQzVCLE9BQU8sRUFBRSxpQkFBaUI7U0FDM0IsQ0FBQztRQUNGLE1BQU0sU0FBUyxHQUFHLElBQUEsa0NBQXNCLEVBQUMsT0FBTyxFQUFFLEdBQUcsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDO1FBQ2xFLE1BQU0sTUFBTSxHQUFHLElBQUEsa0NBQXNCLEVBQUMsWUFBWSxFQUFFLFNBQVMsRUFBRSxNQUFNLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQztRQUNsRixJQUFBLGdCQUFNLEVBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUNsQixDQUFDLENBQUMsQ0FBQztJQUVILEVBQUUsQ0FBQyw0QkFBNEIsRUFBRTtRQUMvQixNQUFNLE9BQU8sR0FBWTtZQUN2QixPQUFPLEVBQUUsV0FBVztTQUNyQixDQUFDO1FBQ0YsTUFBTSxTQUFTLEdBQUcsSUFBQSxrQ0FBc0IsRUFBQyxPQUFPLEVBQUUsUUFBUSxDQUFDLFFBQVEsRUFBRSxDQUFDLENBQUM7UUFDdkUsTUFBTSxNQUFNLEdBQUcsSUFBQSxrQ0FBc0IsRUFBQyxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDO1FBQzdFLElBQUEsZ0JBQU0sRUFBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ2xCLENBQUMsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgYXNzZXJ0IGZyb20gJ2Fzc2VydCc7XG5cbmltcG9ydCAqIGFzIHV0eG9saWIgZnJvbSAnQGJpdGdvLWJldGEvdXR4by1saWInO1xuXG5pbXBvcnQgeyBjcmVhdGVNZXNzYWdlU2lnbmF0dXJlLCB2ZXJpZnlNZXNzYWdlU2lnbmF0dXJlIH0gZnJvbSAnLi4vLi4vLi4vc3JjL2xpZ2h0bmluZyc7XG5pbXBvcnQgY3J5cHRvIGZyb20gJ2NyeXB0byc7XG5cbnR5cGUgUmVxdWVzdCA9IHtcbiAgaW52b2ljZTogc3RyaW5nO1xuICBmZWU/OiBudW1iZXI7XG59O1xuXG5mdW5jdGlvbiBnZXRLZXkoc2VlZDogc3RyaW5nKTogdXR4b2xpYi5CSVAzMkludGVyZmFjZSB7XG4gIHJldHVybiB1dHhvbGliLmJpcDMyLmZyb21TZWVkKGNyeXB0by5jcmVhdGVIYXNoKCdzaGEyNTYnKS51cGRhdGUoc2VlZCkuZGlnZXN0KCkpO1xufVxuXG5kZXNjcmliZSgndmVyaWZ5U2lnbmF0dXJlJywgZnVuY3Rpb24gKCkge1xuICBjb25zdCBrZXkgPSBnZXRLZXkoJ2tleScpO1xuICBjb25zdCBrZXlQdWIgPSBrZXkubmV1dGVyZWQoKTtcbiAgY29uc3Qgd3JvbmdLZXkgPSBnZXRLZXkoJ3dyb25nS2V5Jyk7XG5cbiAgaXQoJ3JldHVybnMgdHJ1ZSBvbiB2YWxpZCBzaWduYXR1cmUnLCBmdW5jdGlvbiAoKSB7XG4gICAgY29uc3QgcmVxdWVzdDogUmVxdWVzdCA9IHtcbiAgICAgIGludm9pY2U6ICdzb21lIGRhdGEnLFxuICAgIH07XG4gICAgY29uc3Qgc2lnbmF0dXJlID0gY3JlYXRlTWVzc2FnZVNpZ25hdHVyZShyZXF1ZXN0LCBrZXkudG9CYXNlNTgoKSk7XG4gICAgY29uc3QgcmVzdWx0ID0gdmVyaWZ5TWVzc2FnZVNpZ25hdHVyZShyZXF1ZXN0LCBzaWduYXR1cmUsIGtleVB1Yi50b0Jhc2U1OCgpKTtcbiAgICBhc3NlcnQocmVzdWx0KTtcbiAgfSk7XG5cbiAgaXQoJ3JldHVybnMgdHJ1ZSBvbiBkaWZmZXJlbnQgb3JkZXInLCBmdW5jdGlvbiAoKSB7XG4gICAgY29uc3QgcmVxdWVzdDogUmVxdWVzdCA9IHtcbiAgICAgIGludm9pY2U6ICdzb21lIGRhdGEnLFxuICAgICAgZmVlOiAxMjMsXG4gICAgfTtcbiAgICBjb25zdCBvdGhlclJlcXVlc3Q6IFJlcXVlc3QgPSB7XG4gICAgICBmZWU6IDEyMyxcbiAgICAgIGludm9pY2U6ICdzb21lIGRhdGEnLFxuICAgIH07XG4gICAgY29uc3Qgc2lnbmF0dXJlID0gY3JlYXRlTWVzc2FnZVNpZ25hdHVyZShyZXF1ZXN0LCBrZXkudG9CYXNlNTgoKSk7XG4gICAgY29uc3QgcmVzdWx0ID0gdmVyaWZ5TWVzc2FnZVNpZ25hdHVyZShvdGhlclJlcXVlc3QsIHNpZ25hdHVyZSwga2V5UHViLnRvQmFzZTU4KCkpO1xuICAgIGFzc2VydChyZXN1bHQpO1xuICB9KTtcblxuICBpdCgncmV0dXJucyBmYWxzZSBvbiB3cm9uZyBtZXNzYWdlJywgZnVuY3Rpb24gKCkge1xuICAgIGNvbnN0IHJlcXVlc3Q6IFJlcXVlc3QgPSB7XG4gICAgICBpbnZvaWNlOiAnc29tZSBkYXRhJyxcbiAgICB9O1xuICAgIGNvbnN0IHdyb25nUmVxdWVzdDogUmVxdWVzdCA9IHtcbiAgICAgIGludm9pY2U6ICdzb21lIG90aGVyIGRhdGEnLFxuICAgIH07XG4gICAgY29uc3Qgc2lnbmF0dXJlID0gY3JlYXRlTWVzc2FnZVNpZ25hdHVyZShyZXF1ZXN0LCBrZXkudG9CYXNlNTgoKSk7XG4gICAgY29uc3QgcmVzdWx0ID0gdmVyaWZ5TWVzc2FnZVNpZ25hdHVyZSh3cm9uZ1JlcXVlc3QsIHNpZ25hdHVyZSwga2V5UHViLnRvQmFzZTU4KCkpO1xuICAgIGFzc2VydCghcmVzdWx0KTtcbiAgfSk7XG5cbiAgaXQoJ3JldHVybnMgZmFsc2Ugb24gd3Jvbmcga2V5JywgZnVuY3Rpb24gKCkge1xuICAgIGNvbnN0IHJlcXVlc3Q6IFJlcXVlc3QgPSB7XG4gICAgICBpbnZvaWNlOiAnc29tZSBkYXRhJyxcbiAgICB9O1xuICAgIGNvbnN0IHNpZ25hdHVyZSA9IGNyZWF0ZU1lc3NhZ2VTaWduYXR1cmUocmVxdWVzdCwgd3JvbmdLZXkudG9CYXNlNTgoKSk7XG4gICAgY29uc3QgcmVzdWx0ID0gdmVyaWZ5TWVzc2FnZVNpZ25hdHVyZShyZXF1ZXN0LCBzaWduYXR1cmUsIGtleVB1Yi50b0Jhc2U1OCgpKTtcbiAgICBhc3NlcnQoIXJlc3VsdCk7XG4gIH0pO1xufSk7XG4iXX0=
|