PHP WebShell
Текущая директория: /opt/BitGoJS/modules/abstract-utxo/dist/test/offlineVault
Просмотр файла: halfSigned.js
"use strict";
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
var desc = Object.getOwnPropertyDescriptor(m, k);
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
desc = { enumerable: true, get: function() { return m[k]; } };
}
Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || (function () {
var ownKeys = function(o) {
ownKeys = Object.getOwnPropertyNames || function (o) {
var ar = [];
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
return ar;
};
return ownKeys(o);
};
return function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
__setModuleDefault(result, mod);
return result;
};
})();
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
const fs = __importStar(require("fs"));
const assert_1 = __importDefault(require("assert"));
const crypto_1 = __importDefault(require("crypto"));
const t = __importStar(require("io-ts"));
const sdk_core_1 = require("@bitgo/sdk-core");
const utxolib = __importStar(require("@bitgo/utxo-lib"));
const offlineVault_1 = require("../../src/offlineVault");
const descriptor_1 = require("../../src/offlineVault/descriptor");
const fixtures_utils_1 = require("../transaction/descriptor/fixtures.utils");
const { assertEqualFixture } = (0, fixtures_utils_1.getFixtureRoot)(__dirname + '/fixtures');
function getFixturesNames() {
// I'm using sync here because mocha cannot do async setup
// eslint-disable-next-line no-sync
return fs.readdirSync(__dirname + '/fixtures').filter((f) => f.endsWith('.json') && !f.endsWith('.explanation.json'));
}
const KeyPair = t.intersection([t.type({ xpub: t.string }), t.partial({ xprv: t.string })]);
const KeyWithParent = t.intersection([KeyPair, t.partial({ parent: KeyPair })]);
const Fixture = t.type({
walletKeys: t.array(KeyWithParent),
response: t.unknown,
});
async function readFixture(name) {
const data = JSON.parse(await fs.promises.readFile(__dirname + '/fixtures/' + name, 'utf-8'));
return (0, sdk_core_1.decodeOrElse)('Fixture', Fixture, data, (e) => {
throw new Error(`failed to decode fixture ${name}: ${e}`);
});
}
function withRotatedXpubs(tx) {
const { user, backup, bitgo } = tx.xpubsWithDerivationPath;
return {
...tx,
xpubsWithDerivationPath: {
user: bitgo,
backup: user,
bitgo: backup,
},
};
}
function withRandomXpubs(tx) {
function randomXpub() {
const bytes = crypto_1.default.getRandomValues(new Uint8Array(32));
return utxolib.bip32.fromSeed(Buffer.from(bytes)).neutered().toBase58();
}
return {
...tx,
xpubsWithDerivationPath: {
user: randomXpub(),
backup: randomXpub(),
bitgo: randomXpub(),
},
};
}
function withoutDescriptors(tx) {
return {
...tx,
descriptors: [],
};
}
function getDerivationId(v) {
const id = v.user.derivedFromParentWithSeed;
(0, assert_1.default)(id);
return id;
}
function getRootPrv(walletKeys) {
(0, assert_1.default)(walletKeys[0]);
(0, assert_1.default)(walletKeys[0].parent);
(0, assert_1.default)(walletKeys[0].parent.xprv);
return utxolib.bip32.fromBase58(walletKeys[0].parent.xprv);
}
describe('OfflineVaultHalfSigned', function () {
for (const fixtureName of getFixturesNames()) {
it(`can sign fixture ${fixtureName}`, async function () {
const { walletKeys, response } = await readFixture(fixtureName);
(0, assert_1.default)(descriptor_1.DescriptorTransaction.is(response));
const rootPrv = getRootPrv(walletKeys);
const derivationId = getDerivationId(response.xpubsWithDerivationPath);
(0, offlineVault_1.createHalfSigned)('btc', rootPrv, derivationId, response);
const mutations = [withRotatedXpubs(response), withRandomXpubs(response), withoutDescriptors(response)];
for (const mutation of mutations) {
assert_1.default.throws(() => (0, offlineVault_1.createHalfSigned)('btc', rootPrv, derivationId, mutation));
}
await assertEqualFixture(fixtureName.replace(/\.json$/, '.explanation.json'), (0, offlineVault_1.getTransactionExplanation)('btc', response));
});
}
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"halfSigned.js","sourceRoot":"","sources":["../../../test/offlineVault/halfSigned.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,uCAAyB;AACzB,oDAA4B;AAC5B,oDAA4B;AAE5B,yCAA2B;AAC3B,8CAA+C;AAC/C,yDAA2C;AAE3C,yDAAqF;AACrF,kEAA0E;AAC1E,6EAA0E;AAE1E,MAAM,EAAE,kBAAkB,EAAE,GAAG,IAAA,+BAAc,EAAC,SAAS,GAAG,WAAW,CAAC,CAAC;AAEvE,SAAS,gBAAgB;IACvB,0DAA0D;IAC1D,mCAAmC;IACnC,OAAO,EAAE,CAAC,WAAW,CAAC,SAAS,GAAG,WAAW,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,mBAAmB,CAAC,CAAC,CAAC;AACxH,CAAC;AAED,MAAM,OAAO,GAAG,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,CAAC;AAE5F,MAAM,aAAa,GAAG,CAAC,CAAC,YAAY,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC,CAAC;AAGhF,MAAM,OAAO,GAAG,CAAC,CAAC,IAAI,CAAC;IACrB,UAAU,EAAE,CAAC,CAAC,KAAK,CAAC,aAAa,CAAC;IAClC,QAAQ,EAAE,CAAC,CAAC,OAAO;CACpB,CAAC,CAAC;AAIH,KAAK,UAAU,WAAW,CAAC,IAAY;IACrC,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,GAAG,YAAY,GAAG,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC;IAC9F,OAAO,IAAA,uBAAY,EAAC,SAAS,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC,EAAE,EAAE;QAClD,MAAM,IAAI,KAAK,CAAC,4BAA4B,IAAI,KAAK,CAAC,EAAE,CAAC,CAAC;IAC5D,CAAC,CAAC,CAAC;AACL,CAAC;AAED,SAAS,gBAAgB,CAAC,EAAyB;IACjD,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC,uBAAuB,CAAC;IAC3D,OAAO;QACL,GAAG,EAAE;QACL,uBAAuB,EAAE;YACvB,IAAI,EAAE,KAAK;YACX,MAAM,EAAE,IAAI;YACZ,KAAK,EAAE,MAAM;SACd;KACF,CAAC;AACJ,CAAC;AAED,SAAS,eAAe,CAAC,EAAyB;IAChD,SAAS,UAAU;QACjB,MAAM,KAAK,GAAG,gBAAM,CAAC,eAAe,CAAC,IAAI,UAAU,CAAC,EAAE,CAAC,CAAC,CAAC;QACzD,OAAO,OAAO,CAAC,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,QAAQ,EAAE,CAAC;IAC1E,CAAC;IACD,OAAO;QACL,GAAG,EAAE;QACL,uBAAuB,EAAE;YACvB,IAAI,EAAE,UAAU,EAAE;YAClB,MAAM,EAAE,UAAU,EAAE;YACpB,KAAK,EAAE,UAAU,EAAE;SACpB;KACF,CAAC;AACJ,CAAC;AAED,SAAS,kBAAkB,CAAC,EAAyB;IACnD,OAAO;QACL,GAAG,EAAE;QACL,WAAW,EAAE,EAAE;KAChB,CAAC;AACJ,CAAC;AAED,SAAS,eAAe,CAAC,CAAmD;IAC1E,MAAM,EAAE,GAAG,CAAC,CAAC,IAAI,CAAC,yBAAyB,CAAC;IAC5C,IAAA,gBAAM,EAAC,EAAE,CAAC,CAAC;IACX,OAAO,EAAE,CAAC;AACZ,CAAC;AAED,SAAS,UAAU,CAAC,UAA2B;IAC7C,IAAA,gBAAM,EAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC;IACtB,IAAA,gBAAM,EAAC,UAAU,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;IAC7B,IAAA,gBAAM,EAAC,UAAU,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAClC,OAAO,OAAO,CAAC,KAAK,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;AAC7D,CAAC;AAED,QAAQ,CAAC,wBAAwB,EAAE;IACjC,KAAK,MAAM,WAAW,IAAI,gBAAgB,EAAE,EAAE,CAAC;QAC7C,EAAE,CAAC,oBAAoB,WAAW,EAAE,EAAE,KAAK;YACzC,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,GAAG,MAAM,WAAW,CAAC,WAAW,CAAC,CAAC;YAChE,IAAA,gBAAM,EAAC,kCAAqB,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC;YAC3C,MAAM,OAAO,GAAG,UAAU,CAAC,UAAU,CAAC,CAAC;YACvC,MAAM,YAAY,GAAG,eAAe,CAAC,QAAQ,CAAC,uBAAuB,CAAC,CAAC;YACvE,IAAA,+BAAgB,EAAC,KAAK,EAAE,OAAO,EAAE,YAAY,EAAE,QAAQ,CAAC,CAAC;YACzD,MAAM,SAAS,GAAG,CAAC,gBAAgB,CAAC,QAAQ,CAAC,EAAE,eAAe,CAAC,QAAQ,CAAC,EAAE,kBAAkB,CAAC,QAAQ,CAAC,CAAC,CAAC;YACxG,KAAK,MAAM,QAAQ,IAAI,SAAS,EAAE,CAAC;gBACjC,gBAAM,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,IAAA,+BAAgB,EAAC,KAAK,EAAE,OAAO,EAAE,YAAY,EAAE,QAAQ,CAAC,CAAC,CAAC;YAChF,CAAC;YACD,MAAM,kBAAkB,CACtB,WAAW,CAAC,OAAO,CAAC,SAAS,EAAE,mBAAmB,CAAC,EACnD,IAAA,wCAAyB,EAAC,KAAK,EAAE,QAAQ,CAAC,CAC3C,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;AACH,CAAC,CAAC,CAAC","sourcesContent":["import * as fs from 'fs';\nimport assert from 'assert';\nimport crypto from 'crypto';\n\nimport * as t from 'io-ts';\nimport { decodeOrElse } from '@bitgo/sdk-core';\nimport * as utxolib from '@bitgo/utxo-lib';\n\nimport { createHalfSigned, getTransactionExplanation } from '../../src/offlineVault';\nimport { DescriptorTransaction } from '../../src/offlineVault/descriptor';\nimport { getFixtureRoot } from '../transaction/descriptor/fixtures.utils';\n\nconst { assertEqualFixture } = getFixtureRoot(__dirname + '/fixtures');\n\nfunction getFixturesNames(): string[] {\n  // I'm using sync here because mocha cannot do async setup\n  // eslint-disable-next-line no-sync\n  return fs.readdirSync(__dirname + '/fixtures').filter((f) => f.endsWith('.json') && !f.endsWith('.explanation.json'));\n}\n\nconst KeyPair = t.intersection([t.type({ xpub: t.string }), t.partial({ xprv: t.string })]);\n\nconst KeyWithParent = t.intersection([KeyPair, t.partial({ parent: KeyPair })]);\ntype KeyWithParent = t.TypeOf<typeof KeyWithParent>;\n\nconst Fixture = t.type({\n  walletKeys: t.array(KeyWithParent),\n  response: t.unknown,\n});\n\ntype Fixture = t.TypeOf<typeof Fixture>;\n\nasync function readFixture(name: string): Promise<Fixture> {\n  const data = JSON.parse(await fs.promises.readFile(__dirname + '/fixtures/' + name, 'utf-8'));\n  return decodeOrElse('Fixture', Fixture, data, (e) => {\n    throw new Error(`failed to decode fixture ${name}: ${e}`);\n  });\n}\n\nfunction withRotatedXpubs(tx: DescriptorTransaction): DescriptorTransaction {\n  const { user, backup, bitgo } = tx.xpubsWithDerivationPath;\n  return {\n    ...tx,\n    xpubsWithDerivationPath: {\n      user: bitgo,\n      backup: user,\n      bitgo: backup,\n    },\n  };\n}\n\nfunction withRandomXpubs(tx: DescriptorTransaction) {\n  function randomXpub() {\n    const bytes = crypto.getRandomValues(new Uint8Array(32));\n    return utxolib.bip32.fromSeed(Buffer.from(bytes)).neutered().toBase58();\n  }\n  return {\n    ...tx,\n    xpubsWithDerivationPath: {\n      user: randomXpub(),\n      backup: randomXpub(),\n      bitgo: randomXpub(),\n    },\n  };\n}\n\nfunction withoutDescriptors(tx: DescriptorTransaction): DescriptorTransaction {\n  return {\n    ...tx,\n    descriptors: [],\n  };\n}\n\nfunction getDerivationId(v: DescriptorTransaction['xpubsWithDerivationPath']): string {\n  const id = v.user.derivedFromParentWithSeed;\n  assert(id);\n  return id;\n}\n\nfunction getRootPrv(walletKeys: KeyWithParent[]): utxolib.BIP32Interface {\n  assert(walletKeys[0]);\n  assert(walletKeys[0].parent);\n  assert(walletKeys[0].parent.xprv);\n  return utxolib.bip32.fromBase58(walletKeys[0].parent.xprv);\n}\n\ndescribe('OfflineVaultHalfSigned', function () {\n  for (const fixtureName of getFixturesNames()) {\n    it(`can sign fixture ${fixtureName}`, async function () {\n      const { walletKeys, response } = await readFixture(fixtureName);\n      assert(DescriptorTransaction.is(response));\n      const rootPrv = getRootPrv(walletKeys);\n      const derivationId = getDerivationId(response.xpubsWithDerivationPath);\n      createHalfSigned('btc', rootPrv, derivationId, response);\n      const mutations = [withRotatedXpubs(response), withRandomXpubs(response), withoutDescriptors(response)];\n      for (const mutation of mutations) {\n        assert.throws(() => createHalfSigned('btc', rootPrv, derivationId, mutation));\n      }\n      await assertEqualFixture(\n        fixtureName.replace(/\\.json$/, '.explanation.json'),\n        getTransactionExplanation('btc', response)\n      );\n    });\n  }\n});\n"]}Выполнить команду
Для локальной разработки. Не используйте в интернете!