PHP WebShell
Текущая директория: /usr/lib/node_modules/bitgo/node_modules/@bitgo/sdk-core/dist/src/bitgo/tss/ecdsa
Просмотр файла: ecdsa.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 });
exports.secondaryDelimeter = exports.delimeter = void 0;
exports.createCombinedKey = createCombinedKey;
exports.createUserSignShare = createUserSignShare;
exports.createUserGammaAndMuShare = createUserGammaAndMuShare;
exports.createUserOmicronAndDeltaShare = createUserOmicronAndDeltaShare;
exports.createUserSignatureShare = createUserSignatureShare;
exports.sendShareToBitgo = sendShareToBitgo;
exports.getBitgoToUserLatestShare = getBitgoToUserLatestShare;
exports.encryptNShare = encryptNShare;
exports.buildNShareFromAPIKeyShare = buildNShareFromAPIKeyShare;
exports.decryptNShare = decryptNShare;
exports.getPublicKey = getPublicKey;
exports.parseKShare = parseKShare;
exports.convertKShare = convertKShare;
exports.parseAShare = parseAShare;
exports.convertAShare = convertAShare;
exports.parseMuShare = parseMuShare;
exports.convertMuShare = convertMuShare;
exports.parseDShare = parseDShare;
exports.convertDShare = convertDShare;
exports.parseSDShare = parseSDShare;
exports.convertSDShare = convertSDShare;
exports.parseSignatureShare = parseSignatureShare;
exports.convertCombinedSignature = convertCombinedSignature;
exports.parseCombinedSignature = parseCombinedSignature;
exports.convertSignatureShare = convertSignatureShare;
exports.convertBShare = convertBShare;
exports.parseBShare = parseBShare;
exports.convertOShare = convertOShare;
exports.parseOShare = parseOShare;
exports.getParticipantIndex = getParticipantIndex;
exports.getParticipantFromIndex = getParticipantFromIndex;
exports.verifyWalletSignature = verifyWalletSignature;
const tss_1 = require("./../../../account-lib/mpc/tss");
const types_1 = require("./types");
const utils_1 = require("../../utils");
const types_2 = require("../types");
const common_1 = require("../common");
const keccak_1 = __importDefault(require("keccak"));
const assert_1 = __importDefault(require("assert"));
const utxo_lib_1 = require("@bitgo/utxo-lib");
const pgp = __importStar(require("openpgp"));
const bs58_1 = __importDefault(require("bs58"));
const sdk_lib_mpc_1 = require("@bitgo/sdk-lib-mpc");
const MPC = new tss_1.Ecdsa();
/**
* Combines NShares to combine the final TSS key
* This can only be used to create the User or Backup key since it requires the common keychain from BitGo first
*
* @param keyShare - TSS key share
* @param encryptedNShares - encrypted NShares with information on how to decrypt
* @param commonKeychain - expected common keychain of the combined key
* @returns {CombinedKey} combined TSS key
*/
async function createCombinedKey(keyShare, encryptedNShares, commonKeychain) {
const nShares = [];
let bitgoNShare;
let userNShare;
let backupNShare;
for (const encryptedNShare of encryptedNShares) {
const nShare = await decryptNShare(encryptedNShare, encryptedNShare.isbs58Encoded);
switch (encryptedNShare.nShare.j) {
case 1:
userNShare = nShare;
break;
case 2:
backupNShare = nShare;
break;
case 3:
bitgoNShare = nShare;
break;
default:
throw new Error('Invalid NShare index');
}
nShares.push(nShare);
}
if (!bitgoNShare) {
throw new Error('Missing BitGo N Share');
}
const combinedKey = MPC.keyCombine(keyShare.pShare, nShares);
if (combinedKey.xShare.y + combinedKey.xShare.chaincode !== commonKeychain) {
throw new Error('Common keychains do not match');
}
const signingMaterial = {
pShare: keyShare.pShare,
bitgoNShare,
backupNShare,
userNShare,
};
return {
signingMaterial,
commonKeychain,
};
}
/**
* Creates the SignShare with User XShare and YShare Corresponding to BitGo
* @param {XShare} xShare User secret xShare
* @param {YShare} yShare YShare from Bitgo
* @returns {Promise<SignShare>}
*/
async function createUserSignShare(xShare, yShare) {
if (xShare.i !== types_2.ShareKeyPosition.USER) {
throw new Error(`Invalid XShare, XShare doesn't belong to the User`);
}
if (yShare.i !== types_2.ShareKeyPosition.USER || yShare.j !== types_2.ShareKeyPosition.BITGO) {
throw new Error('Invalid YShare provided for sign');
}
return await MPC.signShare(xShare, yShare);
}
/**
* Creates the Gamma Share and MuShare with User WShare and AShare From BitGo
* @param {WShare} wShare User WShare
* @param {AShare} aShare AShare from Bitgo
* @returns {Promise<SignConvertStep2Response>}
*/
async function createUserGammaAndMuShare(wShare, aShare) {
if (wShare.i !== types_2.ShareKeyPosition.USER) {
throw new Error(`Invalid WShare, doesn't belong to the User`);
}
if (aShare.i !== types_2.ShareKeyPosition.USER || aShare.j !== types_2.ShareKeyPosition.BITGO) {
throw new Error('Invalid AShare, is not from Bitgo to User');
}
return MPC.signConvertStep2({ wShare, aShare });
}
/**
* Creates the Omicron Share and Delta share with user GShare
* @param {GShare} gShare User GShare
* @returns {Promise<CreateUserOmicronAndDeltaShareRT>}
*/
async function createUserOmicronAndDeltaShare(gShare) {
if (gShare.i !== types_2.ShareKeyPosition.USER) {
throw new Error(`Invalid GShare, doesn't belong to the User`);
}
return MPC.signCombine({
gShare: gShare,
signIndex: {
i: types_2.ShareKeyPosition.BITGO,
j: gShare.i,
},
});
}
/**
* Creates the Signature Share with User OShare and DShare From BitGo
* @param {OShare} oShare User OShare
* @param {DShare} dShare DShare from bitgo
* @param {Buffer} message message to perform sign
* @returns {Promise<createUserSignShareRT>}
*/
async function createUserSignatureShare(oShare, dShare, message, hash = (0, keccak_1.default)('keccak256')) {
if (oShare.i !== types_2.ShareKeyPosition.USER) {
throw new Error(`Invalid OShare, doesn't belong to the User`);
}
if (dShare.i !== types_2.ShareKeyPosition.USER || dShare.j !== types_2.ShareKeyPosition.BITGO) {
throw new Error(`Invalid DShare, doesn't seem to be from BitGo`);
}
return MPC.sign(message, oShare, dShare, hash);
}
/**
* Sends Share To Bitgo
* @param {BitGoBase} bitgo - the bitgo instance
* @param {String} walletId - the wallet id *
* @param {String} txRequestId - the txRequest Id
* @param requestType - the type of request being submitted (either tx or message for signing)
* @param shareType
* @param share
* @param signerShare
* @param vssProof - the v value of the share
* @param privateShareProof - the uSig of the share
* @param publicShare - the y value of the share
* @param userPublicGpgKey - the public key of the gpg key used for creating the privateShareProof
* @param reqId - request tracer request id
* @returns {Promise<SignatureShareRecord>} - a Signature Share
*/
async function sendShareToBitgo(bitgo, walletId, txRequestId, requestType, shareType, share, signerShare, vssProof, privateShareProof, publicShare, userPublicGpgKey, reqId) {
if (shareType !== types_1.SendShareType.SShare && share.i !== types_2.ShareKeyPosition.BITGO) {
throw new Error('Invalid Share, is not from User to Bitgo');
}
let signatureShare;
let responseFromBitgo;
switch (shareType) {
case types_1.SendShareType.KShare:
(0, assert_1.default)(signerShare, `signer share must be present`);
const kShare = share;
signatureShare = convertKShare(kShare);
signatureShare.vssProof = vssProof;
signatureShare.publicShare = publicShare;
signatureShare.privateShareProof = privateShareProof;
await (0, common_1.sendSignatureShare)(bitgo, walletId, txRequestId, signatureShare, requestType, signerShare, 'ecdsa', 'full', userPublicGpgKey, reqId);
responseFromBitgo = await getBitgoToUserLatestShare(bitgo, walletId, txRequestId, types_1.ReceivedShareType.AShare, requestType, reqId);
break;
case types_1.SendShareType.MUShare:
const shareToSend = share;
const muShareRecord = convertMuShare(shareToSend.muShare);
const dShareRecord = convertDShare(shareToSend.dShare);
signatureShare = {
to: utils_1.SignatureShareType.BITGO,
from: getParticipantFromIndex(shareToSend.dShare.j),
share: `${muShareRecord.share}${exports.secondaryDelimeter}${dShareRecord.share}`,
};
await (0, common_1.sendSignatureShare)(bitgo, walletId, txRequestId, signatureShare, requestType, signerShare, 'ecdsa', undefined, undefined, reqId);
responseFromBitgo = await getBitgoToUserLatestShare(bitgo, walletId, txRequestId, types_1.ReceivedShareType.DShare, requestType, reqId);
break;
case types_1.SendShareType.SShare:
const sShare = share;
signatureShare = convertSignatureShare(sShare, 1, 3);
await (0, common_1.sendSignatureShare)(bitgo, walletId, txRequestId, signatureShare, requestType, signerShare, 'ecdsa', undefined, undefined, reqId);
responseFromBitgo = sShare;
break;
default:
throw new Error('Invalid Share given to send');
}
return responseFromBitgo;
}
/**
* Gets the latest user's share from bitgo needed to continue signing flow
* @param {BitGoBase} bitgo - the bitgo instance
* @param {String} walletId - the wallet id *
* @param {String} txRequestId - the txRequest Id
* @param {ReceivedShareType} shareType - the excpected share type
* @param {IRequestTracer} reqId - request tracer request id
* @returns {Promise<SendShareToBitgoRT>} - share from bitgo to user
*/
async function getBitgoToUserLatestShare(bitgo, walletId, txRequestId, shareType, requestType, reqId) {
let responseFromBitgo;
const txRequest = await (0, common_1.getTxRequest)(bitgo, walletId, txRequestId, reqId);
let userShares;
switch (requestType) {
case utils_1.RequestType.tx:
(0, assert_1.default)(txRequest.transactions, 'transactions required as part of txRequest');
userShares = txRequest.transactions[0].signatureShares;
break;
case utils_1.RequestType.message:
(0, assert_1.default)(txRequest.messages, 'messages required as part of txRequest');
userShares = txRequest.messages[0].signatureShares;
break;
}
if (!userShares || !userShares.length) {
throw new Error('user share is not present');
}
const shareRecord = userShares[userShares.length - 1];
switch (shareType) {
case types_1.ReceivedShareType.AShare:
responseFromBitgo = parseAShare(shareRecord);
break;
case types_1.ReceivedShareType.DShare:
responseFromBitgo = parseDShare(shareRecord);
break;
case types_1.ReceivedShareType.Signature:
responseFromBitgo = parseSignatureShare(shareRecord);
break;
default:
throw new Error('Invalid share received');
}
return responseFromBitgo;
}
/**
* Prepares a NShare to be exchanged with other key holders.
* Output is in a format that is usable within BitGo's ecosystem.
*
* @param keyShare - TSS key share of the party preparing exchange materials
* @param recipientIndex - index of the recipient (1, 2, or 3)
* @param recipientGpgPublicArmor - recipient's public gpg key in armor format
* @param senderGpgKey - ephemeral GPG key to encrypt / decrypt sensitve data exchanged between user and server
* @param isbs58Encoded - is bs58 encoded or not
* @returns encrypted N Share
*/
async function encryptNShare(keyShare, recipientIndex, recipientGpgPublicArmor, senderGpgKey, isbs58Encoded = true) {
const nShare = keyShare.nShares[recipientIndex];
if (!nShare) {
throw new Error('Invalid recipient');
}
const publicShare = Buffer.concat([
Buffer.from(keyShare.pShare.y, 'hex'),
Buffer.from(keyShare.pShare.chaincode, 'hex'),
]).toString('hex');
let privateShare;
if (isbs58Encoded) {
privateShare = utxo_lib_1.bip32.fromPrivateKey(Buffer.from(nShare.u, 'hex'), Buffer.from(nShare.chaincode, 'hex')).toBase58();
}
else {
privateShare = Buffer.concat([Buffer.from(nShare.u, 'hex'), Buffer.from(nShare.chaincode, 'hex')]).toString('hex');
}
const recipientPublicKey = await pgp.readKey({ armoredKey: recipientGpgPublicArmor });
const encryptedPrivateShare = (await pgp.encrypt({
message: await pgp.createMessage({
text: privateShare,
}),
encryptionKeys: [recipientPublicKey],
}));
return {
i: nShare.i,
j: nShare.j,
publicShare,
encryptedPrivateShare,
n: nShare.n,
vssProof: nShare.v,
privateShareProof: await (0, utils_1.createShareProof)(senderGpgKey.privateKey, nShare.u, 'ecdsa'),
};
}
/**
* Prepares a NShare to be exchanged with other key holders.
* An API key share received from a third party should already be encrypted
*
* @param keyShare - TSS key share of the party preparing exchange materials
* @returns encrypted N Share
*/
async function buildNShareFromAPIKeyShare(keyShare) {
return {
i: getParticipantIndex(keyShare.to),
j: getParticipantIndex(keyShare.from),
publicShare: keyShare.publicShare,
encryptedPrivateShare: keyShare.privateShare,
n: keyShare.n ?? '', // this is not currently needed for key creation
privateShareProof: keyShare.privateShareProof,
vssProof: keyShare.vssProof,
};
}
/**
* Decrypts encrypted n share
* @param encryptedNShare - decryptable n share with recipient private gpg key armor and sender public gpg key
* @param isbs58Encoded
* @returns N share
*/
async function decryptNShare(encryptedNShare, isbs58Encoded = true) {
const recipientPrivateKey = await pgp.readKey({ armoredKey: encryptedNShare.recipientPrivateArmor });
const prv = (await pgp.decrypt({
message: await pgp.readMessage({ armoredMessage: encryptedNShare.nShare.encryptedPrivateShare }),
decryptionKeys: [recipientPrivateKey],
})).data;
let u;
if (isbs58Encoded) {
const privateShare = bs58_1.default.decode(prv).toString('hex');
u = privateShare.slice(92, 156);
}
else {
u = prv.slice(0, 64);
}
return {
i: encryptedNShare.nShare.i,
j: encryptedNShare.nShare.j,
n: encryptedNShare.nShare.n,
y: encryptedNShare.nShare.publicShare.slice(0, 66),
u: u,
chaincode: encryptedNShare.nShare.publicShare.slice(66, 130),
v: encryptedNShare.nShare.vssProof,
};
}
/**
* Gets public key from common keychain
* @param commonKeyChain - common keychain of ecdsa tss
* @returns public key
*/
function getPublicKey(commonKeyChain) {
return commonKeyChain.slice(0, 66);
}
exports.delimeter = ':';
exports.secondaryDelimeter = '-';
function validateSharesLength(shares, expectedLength, shareName) {
if (shares.length < expectedLength) {
throw new Error(`Invalid ${shareName} share`);
}
}
function validateOptionalValues(shares, start, end, shareName, valueName) {
let found = false;
for (let i = start; i < end; i++) {
if (shares[i]) {
found = true;
}
else if (found) {
throw new Error(`Inconsistent optional ${valueName} value in ${shareName} share`);
}
}
return found;
}
/**
* parses K share from signature share record
* @param share - signature share record
* @returns K Share
*/
function parseKShare(share) {
const shares = share.share.split(exports.delimeter);
validateSharesLength(shares, 11 + 2 * sdk_lib_mpc_1.EcdsaPaillierProof.m, 'K');
const hasProof = validateOptionalValues(shares, 5, 11, 'K', 'proof');
const proof = hasProof
? {
z: shares[5],
u: shares[6],
w: shares[7],
s: shares[8],
s1: shares[9],
s2: shares[10],
}
: undefined;
return {
i: getParticipantIndex(share.to),
j: getParticipantIndex(share.from),
k: shares[0],
n: shares[1],
ntilde: shares[2],
h1: shares[3],
h2: shares[4],
proof,
p: shares.slice(11, 11 + sdk_lib_mpc_1.EcdsaPaillierProof.m),
sigma: shares.slice(11 + sdk_lib_mpc_1.EcdsaPaillierProof.m, 11 + 2 * sdk_lib_mpc_1.EcdsaPaillierProof.m),
};
}
/**
* convert K share to signature share record
* @param share - K share
* @returns signature share record
*/
function convertKShare(share) {
return {
to: getParticipantFromIndex(share.i),
from: getParticipantFromIndex(share.j),
share: `${share.k}${exports.delimeter}${share.n}${exports.delimeter}${share.ntilde}${exports.delimeter}${share.h1}${exports.delimeter}${share.h2}${exports.delimeter}${share.proof?.z || ''}${exports.delimeter}${share.proof?.u || ''}${exports.delimeter}${share.proof?.w || ''}${exports.delimeter}${share.proof?.s || ''}${exports.delimeter}${share.proof?.s1 || ''}${exports.delimeter}${share.proof?.s2 || ''}${exports.delimeter}${(share.p || []).join(exports.delimeter)}${exports.delimeter}${(share.sigma || []).join(exports.delimeter)}`,
};
}
/**
* parses A share from signature share record
* @param share - signature share record
* @returns A Share
*/
function parseAShare(share) {
const shares = share.share.split(exports.delimeter);
validateSharesLength(shares, 37 + sdk_lib_mpc_1.EcdsaPaillierProof.m, 'A');
const hasProof = validateOptionalValues(shares, 7, 13, 'A', 'proof');
const hasGammaProof = validateOptionalValues(shares, 13, 25, 'A', 'gammaProof');
const hasWProof = validateOptionalValues(shares, 25, 37, 'A', 'wProof');
const proof = hasProof
? {
z: shares[7],
u: shares[8],
w: shares[9],
s: shares[10],
s1: shares[11],
s2: shares[12],
}
: undefined;
const gammaProof = hasGammaProof
? {
z: shares[13],
zprm: shares[14],
t: shares[15],
v: shares[16],
w: shares[17],
s: shares[18],
s1: shares[19],
s2: shares[20],
t1: shares[21],
t2: shares[22],
u: shares[23],
x: shares[24],
}
: undefined;
const wProof = hasWProof
? {
z: shares[25],
zprm: shares[26],
t: shares[27],
v: shares[28],
w: shares[29],
s: shares[30],
s1: shares[31],
s2: shares[32],
t1: shares[33],
t2: shares[34],
u: shares[35],
x: shares[36],
}
: undefined;
return {
i: getParticipantIndex(share.to),
j: getParticipantIndex(share.from),
k: shares[0],
alpha: shares[1],
mu: shares[2],
n: shares[3],
ntilde: shares[4],
h1: shares[5],
h2: shares[6],
proof,
gammaProof,
wProof,
sigma: shares.slice(37),
};
}
/**
* convert A share to signature share record
* @param share - A share
* @returns signature share record
*/
function convertAShare(share) {
return {
to: getParticipantFromIndex(share.i),
from: getParticipantFromIndex(share.j),
share: `${share.k}${exports.delimeter}${share.alpha}${exports.delimeter}${share.mu}${exports.delimeter}${share.n}${exports.delimeter}${share.ntilde}${exports.delimeter}${share.h1}${exports.delimeter}${share.h2}${exports.delimeter}${share.proof?.z || ''}${exports.delimeter}${share.proof?.u || ''}${exports.delimeter}${share.proof?.w || ''}${exports.delimeter}${share.proof?.s || ''}${exports.delimeter}${share.proof?.s1 || ''}${exports.delimeter}${share.proof?.s2 || ''}${exports.delimeter}${share.gammaProof?.z || ''}${exports.delimeter}${share.gammaProof?.zprm || ''}${exports.delimeter}${share.gammaProof?.t || ''}${exports.delimeter}${share.gammaProof?.v || ''}${exports.delimeter}${share.gammaProof?.w || ''}${exports.delimeter}${share.gammaProof?.s || ''}${exports.delimeter}${share.gammaProof?.s1 || ''}${exports.delimeter}${share.gammaProof?.s2 || ''}${exports.delimeter}${share.gammaProof?.t1 || ''}${exports.delimeter}${share.gammaProof?.t2 || ''}${exports.delimeter}${share.gammaProof?.u || ''}${exports.delimeter}${share.gammaProof?.x || ''}${exports.delimeter}${share.wProof?.z || ''}${exports.delimeter}${share.wProof?.zprm || ''}${exports.delimeter}${share.wProof?.t || ''}${exports.delimeter}${share.wProof?.v || ''}${exports.delimeter}${share.wProof?.w || ''}${exports.delimeter}${share.wProof?.s || ''}${exports.delimeter}${share.wProof?.s1 || ''}${exports.delimeter}${share.wProof?.s2 || ''}${exports.delimeter}${share.wProof?.t1 || ''}${exports.delimeter}${share.wProof?.t2 || ''}${exports.delimeter}${share.wProof?.u || ''}${exports.delimeter}${share.wProof?.x || ''}${exports.delimeter}${(share.sigma || []).join(exports.delimeter)}`,
};
}
/**
* parses Mu share from signature share record
* @param share - signature share record
* @returns Mu Share
*/
function parseMuShare(share) {
const shares = share.share.split(exports.delimeter);
validateSharesLength(shares, 26, 'Mu');
const hasGammaProof = validateOptionalValues(shares, 2, 14, 'Mu', 'gammaProof');
const hasWProof = validateOptionalValues(shares, 14, 26, 'Mu', 'wProof');
let gammaProof;
if (hasGammaProof) {
gammaProof = {
z: shares[2],
zprm: shares[3],
t: shares[4],
v: shares[5],
w: shares[6],
s: shares[7],
s1: shares[8],
s2: shares[9],
t1: shares[10],
t2: shares[11],
u: shares[12],
x: shares[13],
};
}
let wProof;
if (hasWProof) {
wProof = {
z: shares[14],
zprm: shares[15],
t: shares[16],
v: shares[17],
w: shares[18],
s: shares[19],
s1: shares[20],
s2: shares[21],
t1: shares[22],
t2: shares[23],
u: shares[24],
x: shares[25],
};
}
return {
i: getParticipantIndex(share.to),
j: getParticipantIndex(share.from),
alpha: shares[0],
mu: shares[1],
gammaProof,
wProof,
};
}
/**
* convert Mu share to signature share record
* @param share - Mu share
* @returns signature share record
*/
function convertMuShare(share) {
return {
to: getParticipantFromIndex(share.i),
from: getParticipantFromIndex(share.j),
share: `${share.alpha}${exports.delimeter}${share.mu}${exports.delimeter}${share.gammaProof?.z || ''}${exports.delimeter}${share.gammaProof?.zprm || ''}${exports.delimeter}${share.gammaProof?.t || ''}${exports.delimeter}${share.gammaProof?.v || ''}${exports.delimeter}${share.gammaProof?.w || ''}${exports.delimeter}${share.gammaProof?.s || ''}${exports.delimeter}${share.gammaProof?.s1 || ''}${exports.delimeter}${share.gammaProof?.s2 || ''}${exports.delimeter}${share.gammaProof?.t1 || ''}${exports.delimeter}${share.gammaProof?.t2 || ''}${exports.delimeter}${share.gammaProof?.u || ''}${exports.delimeter}${share.gammaProof?.x || ''}${exports.delimeter}${share.wProof?.z || ''}${exports.delimeter}${share.wProof?.zprm || ''}${exports.delimeter}${share.wProof?.t || ''}${exports.delimeter}${share.wProof?.v || ''}${exports.delimeter}${share.wProof?.w || ''}${exports.delimeter}${share.wProof?.s || ''}${exports.delimeter}${share.wProof?.s1 || ''}${exports.delimeter}${share.wProof?.s2 || ''}${exports.delimeter}${share.wProof?.t1 || ''}${exports.delimeter}${share.wProof?.t2 || ''}${exports.delimeter}${share.wProof?.u || ''}${exports.delimeter}${share.wProof?.x || ''}`,
};
}
/**
* parses D share from signature share record
* @param share - signature share record
* @returns D Share
*/
function parseDShare(share) {
const shares = share.share.split(exports.delimeter);
validateSharesLength(shares, 2, 'D');
return {
i: getParticipantIndex(share.to),
j: getParticipantIndex(share.from),
delta: shares[0],
Gamma: shares[1],
};
}
/**
* convert D share to signature share record
* @param share - D share
* @returns signature share record
*/
function convertDShare(share) {
return {
to: getParticipantFromIndex(share.i),
from: getParticipantFromIndex(share.j),
share: `${share.delta}${exports.delimeter}${share.Gamma}`,
};
}
/**
* parses S and D share from signature share record
* @param share - signature share record
* @returns Object containing S and D Share
*/
function parseSDShare(share) {
const shares = share.share.split(exports.secondaryDelimeter);
validateSharesLength(shares, 2, 'SD');
return {
sShare: parseSignatureShare({ to: share.to, from: share.from, share: shares[0] }),
dShare: parseDShare({ to: share.to, from: share.from, share: shares[1] }),
};
}
/**
* convert S and D share to signature share record
* @param share - S and D share in a object
* @returns signature share record
*/
function convertSDShare(share) {
return {
to: getParticipantFromIndex(share.dShare.i),
from: getParticipantFromIndex(share.dShare.j),
share: `${share.sShare.R}${exports.delimeter}${share.sShare.s}${exports.delimeter}${share.sShare.y}${exports.secondaryDelimeter}${share.dShare.delta}${exports.delimeter}${share.dShare.Gamma}`,
};
}
/**
* parses signature share from signature share record
* @param share - signature share record
* @returns Signature Share
*/
function parseSignatureShare(share) {
const shares = share.share.split(exports.delimeter);
validateSharesLength(shares, 3, 'Signature');
return {
i: getParticipantIndex(share.to),
R: shares[0],
s: shares[1],
y: shares[2],
};
}
/**
* convets combined signature to signature share record
* @param signature - combined signature share
* @param userIndex - user index, either 1 (user) or 2 (backup)
* @returns signature share record
*/
function convertCombinedSignature(signature, userIndex) {
return {
to: utils_1.SignatureShareType.BITGO,
from: getParticipantFromIndex(userIndex),
share: `${signature.recid}${exports.delimeter}${signature.r}${exports.delimeter}${signature.s}${exports.delimeter}${signature.y}`,
};
}
function parseCombinedSignature(share) {
const shares = share.share.split(exports.delimeter);
validateSharesLength(shares, 3, 'Signature');
return {
recid: Number(shares[0]),
r: shares[1],
s: shares[2],
y: shares[3],
};
}
/**
* convert signature share to signature share record
* @param share - Signature share
* @param senderIndex
* @param recipientIndex
* @returns signature share record
*/
function convertSignatureShare(share, senderIndex, recipientIndex) {
return {
to: getParticipantFromIndex(recipientIndex),
from: getParticipantFromIndex(senderIndex),
share: `${share.R}${exports.delimeter}${share.s}${exports.delimeter}${share.y}`,
};
}
/**
* converts B share to signature share record
* @param share - B share
* @returns signature share record
*/
function convertBShare(share) {
return {
to: utils_1.SignatureShareType.BITGO,
from: getParticipantFromIndex(share.i),
share: `${share.beta}${exports.delimeter}${share.gamma}${exports.delimeter}${share.k}${exports.delimeter}${share.nu}${exports.delimeter}${share.w}${exports.delimeter}${share.y}${exports.delimeter}${share.l}${exports.delimeter}${share.m}${exports.delimeter}${share.n}${exports.delimeter}${share.ntilde}${exports.delimeter}${share.h1}${exports.delimeter}${share.h2}${exports.delimeter}${share.ck}${exports.delimeter}${(share.p || []).join(exports.delimeter)}`,
};
}
/**
* parses B share from signature share record
* @param share B share record
* @returns B Share
*/
function parseBShare(share) {
const shares = share.share.split(exports.delimeter);
validateSharesLength(shares, 13 + sdk_lib_mpc_1.EcdsaPaillierProof.m, 'B');
return {
i: getParticipantIndex(share.to),
beta: shares[0],
gamma: shares[1],
k: shares[2],
nu: shares[3],
w: shares[4],
y: shares[5],
l: shares[6],
m: shares[7],
n: shares[8],
ntilde: shares[9],
h1: shares[10],
h2: shares[11],
ck: shares[12],
p: shares.slice(13, 13 + sdk_lib_mpc_1.EcdsaPaillierProof.m),
};
}
/**
* converts O share to signature share record
* @param share O share
* @returns signature share record
*/
function convertOShare(share) {
return {
to: utils_1.SignatureShareType.BITGO,
from: getParticipantFromIndex(share.i),
share: `${share.Gamma}${exports.delimeter}${share.delta}${exports.delimeter}${share.k}${exports.delimeter}${share.omicron}${exports.delimeter}${share.y}`,
};
}
/**
* parses O share from signature share record
* @param share O share record
* @returns O Share
*/
function parseOShare(share) {
const shares = share.share.split(exports.delimeter);
validateSharesLength(shares, 5, 'O');
return {
i: getParticipantIndex(share.to),
Gamma: shares[0],
delta: shares[1],
k: shares[2],
omicron: shares[3],
y: shares[4],
};
}
/**
* gets participant index
* @param participant - participants (user, backup, or bitgo)
* @returns index (1, 2, 0r 3)
*/
function getParticipantIndex(participant) {
switch (participant) {
case 'user':
return 1;
case 'backup':
return 2;
case 'bitgo':
return 3;
default:
throw Error('Unkown participant');
}
}
/**
* gets participant name by index
* @param index participant index
* @returns participant name
*/
function getParticipantFromIndex(index) {
switch (index) {
case 1:
return utils_1.SignatureShareType.USER;
case 2:
return utils_1.SignatureShareType.BACKUP;
case 3:
return utils_1.SignatureShareType.BITGO;
default:
throw new Error(`Unknown participant index ${index}`);
}
}
/**
* Helper function to verify u-value wallet signatures for the bitgo-user and bitgo-backup shares.
* @param params
*/
async function verifyWalletSignature(params) {
const rawNotations = await (0, common_1.commonVerifyWalletSignature)(params);
const publicUValueRawNotationIndex = 2 + params.verifierIndex;
// Derive public form of u-value
const publicUValue = utxo_lib_1.ecc.pointFromScalar(Buffer.from(params.decryptedShare.slice(0, 64), 'hex'), true);
(0, assert_1.default)(publicUValue !== null, 'null public u-value');
// Verify that the u value + chaincode is equal to the proof retrieved from the raw notations
(0, assert_1.default)(Buffer.from(publicUValue).toString('hex') + params.decryptedShare.slice(64) ===
Buffer.from(rawNotations[publicUValueRawNotationIndex].value).toString(), 'bitgo share mismatch');
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecdsa.js","sourceRoot":"","sources":["../../../../../src/bitgo/tss/ecdsa/ecdsa.ts"],"names":[],"mappings":"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","sourcesContent":["import { Ecdsa } from './../../../account-lib/mpc/tss';\nimport {\n  AShare,\n  BShare,\n  CombinedKey,\n  CreateUserOmicronAndDeltaShareRT,\n  DecryptableNShare,\n  DShare,\n  EncryptedNShare,\n  GShare,\n  KeyShare,\n  NShare,\n  OShare,\n  ReceivedShareType,\n  SendShareToBitgoRT,\n  SendShareType,\n  Signature,\n  SignatureShare,\n  SigningMaterial,\n  SignShare,\n  WShare,\n  XShareWithChallenges,\n  YShareWithChallenges,\n} from './types';\nimport { createShareProof, RequestType, SignatureShareRecord, SignatureShareType } from '../../utils';\nimport { ShareKeyPosition } from '../types';\nimport { BitGoBase } from '../../bitgoBase';\nimport {\n  KShare,\n  MUShare,\n  RangeProofShare,\n  RangeProofWithCheckShare,\n  SignConvertStep2Response,\n  SShare,\n} from '../../../account-lib/mpc/tss/ecdsa/types';\nimport { commonVerifyWalletSignature, getTxRequest, sendSignatureShare } from '../common';\nimport createKeccakHash from 'keccak';\nimport assert from 'assert';\nimport { bip32, ecc } from '@bitgo/utxo-lib';\nimport * as pgp from 'openpgp';\nimport bs58 from 'bs58';\nimport { ApiKeyShare } from '../../keychain';\nimport { Hash } from 'crypto';\nimport { EcdsaPaillierProof } from '@bitgo/sdk-lib-mpc';\nimport { IRequestTracer } from '../../../api';\n\nconst MPC = new Ecdsa();\n\n/**\n * Combines NShares to combine the final TSS key\n * This can only be used to create the User or Backup key since it requires the common keychain from BitGo first\n *\n * @param keyShare - TSS key share\n * @param encryptedNShares - encrypted NShares with information on how to decrypt\n * @param commonKeychain - expected common keychain of the combined key\n * @returns {CombinedKey} combined TSS key\n */\nexport async function createCombinedKey(\n  keyShare: KeyShare,\n  encryptedNShares: DecryptableNShare[],\n  commonKeychain: string\n): Promise<CombinedKey> {\n  const nShares: NShare[] = [];\n\n  let bitgoNShare: NShare | undefined;\n  let userNShare: NShare | undefined;\n  let backupNShare: NShare | undefined;\n\n  for (const encryptedNShare of encryptedNShares) {\n    const nShare = await decryptNShare(encryptedNShare, encryptedNShare.isbs58Encoded);\n\n    switch (encryptedNShare.nShare.j) {\n      case 1:\n        userNShare = nShare;\n        break;\n      case 2:\n        backupNShare = nShare;\n        break;\n      case 3:\n        bitgoNShare = nShare;\n        break;\n      default:\n        throw new Error('Invalid NShare index');\n    }\n\n    nShares.push(nShare);\n  }\n\n  if (!bitgoNShare) {\n    throw new Error('Missing BitGo N Share');\n  }\n\n  const combinedKey = MPC.keyCombine(keyShare.pShare, nShares);\n  if (combinedKey.xShare.y + combinedKey.xShare.chaincode !== commonKeychain) {\n    throw new Error('Common keychains do not match');\n  }\n\n  const signingMaterial: SigningMaterial = {\n    pShare: keyShare.pShare,\n    bitgoNShare,\n    backupNShare,\n    userNShare,\n  };\n\n  return {\n    signingMaterial,\n    commonKeychain,\n  };\n}\n\n/**\n * Creates the SignShare with User XShare and YShare Corresponding to BitGo\n * @param {XShare} xShare User secret xShare\n * @param {YShare} yShare YShare from Bitgo\n * @returns {Promise<SignShare>}\n */\nexport async function createUserSignShare(\n  xShare: XShareWithChallenges,\n  yShare: YShareWithChallenges\n): Promise<SignShare> {\n  if (xShare.i !== ShareKeyPosition.USER) {\n    throw new Error(`Invalid XShare, XShare doesn't belong to the User`);\n  }\n\n  if (yShare.i !== ShareKeyPosition.USER || yShare.j !== ShareKeyPosition.BITGO) {\n    throw new Error('Invalid YShare provided for sign');\n  }\n  return await MPC.signShare(xShare, yShare);\n}\n\n/**\n * Creates the Gamma Share and MuShare with User WShare and AShare From BitGo\n * @param {WShare} wShare User WShare\n * @param {AShare} aShare AShare from Bitgo\n * @returns {Promise<SignConvertStep2Response>}\n */\nexport async function createUserGammaAndMuShare(wShare: WShare, aShare: AShare): Promise<SignConvertStep2Response> {\n  if (wShare.i !== ShareKeyPosition.USER) {\n    throw new Error(`Invalid WShare, doesn't belong to the User`);\n  }\n  if (aShare.i !== ShareKeyPosition.USER || aShare.j !== ShareKeyPosition.BITGO) {\n    throw new Error('Invalid AShare, is not from Bitgo to User');\n  }\n  return MPC.signConvertStep2({ wShare, aShare });\n}\n\n/**\n * Creates the Omicron Share and Delta share with user GShare\n * @param {GShare} gShare User GShare\n * @returns {Promise<CreateUserOmicronAndDeltaShareRT>}\n */\nexport async function createUserOmicronAndDeltaShare(gShare: GShare): Promise<CreateUserOmicronAndDeltaShareRT> {\n  if (gShare.i !== ShareKeyPosition.USER) {\n    throw new Error(`Invalid GShare, doesn't belong to the User`);\n  }\n  return MPC.signCombine({\n    gShare: gShare,\n    signIndex: {\n      i: ShareKeyPosition.BITGO,\n      j: gShare.i,\n    },\n  });\n}\n\n/**\n * Creates the Signature Share with User OShare and DShare From BitGo\n * @param {OShare} oShare User OShare\n * @param {DShare} dShare DShare from bitgo\n * @param {Buffer} message message to perform sign\n * @returns {Promise<createUserSignShareRT>}\n */\nexport async function createUserSignatureShare(\n  oShare: OShare,\n  dShare: DShare,\n  message: Buffer,\n  hash: Hash = createKeccakHash('keccak256') as Hash\n): Promise<SignatureShare> {\n  if (oShare.i !== ShareKeyPosition.USER) {\n    throw new Error(`Invalid OShare, doesn't belong to the User`);\n  }\n\n  if (dShare.i !== ShareKeyPosition.USER || dShare.j !== ShareKeyPosition.BITGO) {\n    throw new Error(`Invalid DShare, doesn't seem to be from BitGo`);\n  }\n  return MPC.sign(message, oShare, dShare, hash);\n}\n\nexport type MuDShare = { muShare: MUShare; dShare: DShare; i: ShareKeyPosition };\n\n/**\n * Sends Share To Bitgo\n * @param {BitGoBase} bitgo - the bitgo instance\n * @param {String} walletId - the wallet id  *\n * @param {String} txRequestId - the txRequest Id\n * @param requestType - the type of request being submitted (either tx or message for signing)\n * @param shareType\n * @param share\n * @param signerShare\n * @param vssProof - the v value of the share\n * @param privateShareProof - the uSig of the share\n * @param publicShare - the y value of the share\n * @param userPublicGpgKey - the public key of the gpg key used for creating the privateShareProof\n * @param reqId - request tracer request id\n * @returns {Promise<SignatureShareRecord>} - a Signature Share\n */\nexport async function sendShareToBitgo(\n  bitgo: BitGoBase,\n  walletId: string,\n  txRequestId: string,\n  requestType: RequestType,\n  shareType: SendShareType,\n  share: SShare | MuDShare | KShare,\n  signerShare?: string,\n  vssProof?: string,\n  privateShareProof?: string,\n  publicShare?: string,\n  userPublicGpgKey?: string,\n  reqId?: IRequestTracer\n): Promise<SendShareToBitgoRT> {\n  if (shareType !== SendShareType.SShare && share.i !== ShareKeyPosition.BITGO) {\n    throw new Error('Invalid Share, is not from User to Bitgo');\n  }\n  let signatureShare: SignatureShareRecord;\n  let responseFromBitgo: SendShareToBitgoRT;\n\n  switch (shareType) {\n    case SendShareType.KShare:\n      assert(signerShare, `signer share must be present`);\n      const kShare = share as KShare;\n      signatureShare = convertKShare(kShare);\n      signatureShare.vssProof = vssProof;\n      signatureShare.publicShare = publicShare;\n      signatureShare.privateShareProof = privateShareProof;\n      await sendSignatureShare(\n        bitgo,\n        walletId,\n        txRequestId,\n        signatureShare,\n        requestType,\n        signerShare,\n        'ecdsa',\n        'full',\n        userPublicGpgKey,\n        reqId\n      );\n      responseFromBitgo = await getBitgoToUserLatestShare(\n        bitgo,\n        walletId,\n        txRequestId,\n        ReceivedShareType.AShare,\n        requestType,\n        reqId\n      );\n      break;\n    case SendShareType.MUShare:\n      const shareToSend = share as MuDShare;\n      const muShareRecord = convertMuShare(shareToSend.muShare);\n      const dShareRecord = convertDShare(shareToSend.dShare);\n      signatureShare = {\n        to: SignatureShareType.BITGO,\n        from: getParticipantFromIndex(shareToSend.dShare.j),\n        share: `${muShareRecord.share}${secondaryDelimeter}${dShareRecord.share}`,\n      };\n      await sendSignatureShare(\n        bitgo,\n        walletId,\n        txRequestId,\n        signatureShare,\n        requestType,\n        signerShare,\n        'ecdsa',\n        undefined,\n        undefined,\n        reqId\n      );\n      responseFromBitgo = await getBitgoToUserLatestShare(\n        bitgo,\n        walletId,\n        txRequestId,\n        ReceivedShareType.DShare,\n        requestType,\n        reqId\n      );\n      break;\n    case SendShareType.SShare:\n      const sShare = share as SShare;\n      signatureShare = convertSignatureShare(sShare, 1, 3);\n      await sendSignatureShare(\n        bitgo,\n        walletId,\n        txRequestId,\n        signatureShare,\n        requestType,\n        signerShare,\n        'ecdsa',\n        undefined,\n        undefined,\n        reqId\n      );\n      responseFromBitgo = sShare;\n      break;\n    default:\n      throw new Error('Invalid Share given to send');\n  }\n\n  return responseFromBitgo;\n}\n\n/**\n * Gets the latest user's share from bitgo needed to continue signing flow\n * @param {BitGoBase} bitgo - the bitgo instance\n * @param {String} walletId - the wallet id  *\n * @param {String} txRequestId - the txRequest Id\n * @param {ReceivedShareType} shareType - the excpected share type\n * @param {IRequestTracer} reqId - request tracer request id\n * @returns {Promise<SendShareToBitgoRT>} - share from bitgo to user\n */\nexport async function getBitgoToUserLatestShare(\n  bitgo: BitGoBase,\n  walletId: string,\n  txRequestId: string,\n  shareType: ReceivedShareType,\n  requestType: RequestType,\n  reqId?: IRequestTracer\n): Promise<SendShareToBitgoRT> {\n  let responseFromBitgo: SendShareToBitgoRT;\n  const txRequest = await getTxRequest(bitgo, walletId, txRequestId, reqId);\n  let userShares;\n  switch (requestType) {\n    case RequestType.tx:\n      assert(txRequest.transactions, 'transactions required as part of txRequest');\n      userShares = txRequest.transactions[0].signatureShares;\n      break;\n    case RequestType.message:\n      assert(txRequest.messages, 'messages required as part of txRequest');\n      userShares = txRequest.messages[0].signatureShares;\n      break;\n  }\n  if (!userShares || !userShares.length) {\n    throw new Error('user share is not present');\n  }\n\n  const shareRecord = userShares[userShares.length - 1];\n  switch (shareType) {\n    case ReceivedShareType.AShare:\n      responseFromBitgo = parseAShare(shareRecord);\n      break;\n    case ReceivedShareType.DShare:\n      responseFromBitgo = parseDShare(shareRecord);\n      break;\n    case ReceivedShareType.Signature:\n      responseFromBitgo = parseSignatureShare(shareRecord);\n      break;\n    default:\n      throw new Error('Invalid share received');\n  }\n\n  return responseFromBitgo;\n}\n\n/**\n * Prepares a NShare to be exchanged with other key holders.\n * Output is in a format that is usable within BitGo's ecosystem.\n *\n * @param keyShare - TSS key share of the party preparing exchange materials\n * @param recipientIndex - index of the recipient (1, 2, or 3)\n * @param recipientGpgPublicArmor - recipient's public gpg key in armor format\n * @param senderGpgKey - ephemeral GPG key to encrypt / decrypt sensitve data exchanged between user and server\n * @param isbs58Encoded - is bs58 encoded or not\n * @returns encrypted N Share\n */\nexport async function encryptNShare(\n  keyShare: KeyShare,\n  recipientIndex: number,\n  recipientGpgPublicArmor: string,\n  senderGpgKey: pgp.SerializedKeyPair<string>,\n  isbs58Encoded = true\n): Promise<EncryptedNShare> {\n  const nShare = keyShare.nShares[recipientIndex];\n  if (!nShare) {\n    throw new Error('Invalid recipient');\n  }\n\n  const publicShare = Buffer.concat([\n    Buffer.from(keyShare.pShare.y, 'hex'),\n    Buffer.from(keyShare.pShare.chaincode, 'hex'),\n  ]).toString('hex');\n\n  let privateShare;\n  if (isbs58Encoded) {\n    privateShare = bip32.fromPrivateKey(Buffer.from(nShare.u, 'hex'), Buffer.from(nShare.chaincode, 'hex')).toBase58();\n  } else {\n    privateShare = Buffer.concat([Buffer.from(nShare.u, 'hex'), Buffer.from(nShare.chaincode, 'hex')]).toString('hex');\n  }\n  const recipientPublicKey = await pgp.readKey({ armoredKey: recipientGpgPublicArmor });\n\n  const encryptedPrivateShare = (await pgp.encrypt({\n    message: await pgp.createMessage({\n      text: privateShare,\n    }),\n    encryptionKeys: [recipientPublicKey],\n  })) as string;\n\n  return {\n    i: nShare.i,\n    j: nShare.j,\n    publicShare,\n    encryptedPrivateShare,\n    n: nShare.n,\n    vssProof: nShare.v,\n    privateShareProof: await createShareProof(senderGpgKey.privateKey, nShare.u, 'ecdsa'),\n  };\n}\n\n/**\n * Prepares a NShare to be exchanged with other key holders.\n * An API key share received from a third party should already be encrypted\n *\n * @param keyShare - TSS key share of the party preparing exchange materials\n * @returns encrypted N Share\n */\nexport async function buildNShareFromAPIKeyShare(keyShare: ApiKeyShare): Promise<EncryptedNShare> {\n  return {\n    i: getParticipantIndex(keyShare.to),\n    j: getParticipantIndex(keyShare.from),\n    publicShare: keyShare.publicShare,\n    encryptedPrivateShare: keyShare.privateShare,\n    n: keyShare.n ?? '', // this is not currently needed for key creation\n    privateShareProof: keyShare.privateShareProof,\n    vssProof: keyShare.vssProof,\n  };\n}\n\n/**\n * Decrypts encrypted n share\n * @param encryptedNShare - decryptable n share with recipient private gpg key armor and sender public gpg key\n * @param isbs58Encoded\n * @returns N share\n */\nexport async function decryptNShare(encryptedNShare: DecryptableNShare, isbs58Encoded = true): Promise<NShare> {\n  const recipientPrivateKey = await pgp.readKey({ armoredKey: encryptedNShare.recipientPrivateArmor });\n  const prv = (\n    await pgp.decrypt({\n      message: await pgp.readMessage({ armoredMessage: encryptedNShare.nShare.encryptedPrivateShare }),\n      decryptionKeys: [recipientPrivateKey as pgp.PrivateKey],\n    })\n  ).data as string;\n\n  let u: string;\n  if (isbs58Encoded) {\n    const privateShare = bs58.decode(prv).toString('hex');\n    u = privateShare.slice(92, 156);\n  } else {\n    u = prv.slice(0, 64);\n  }\n\n  return {\n    i: encryptedNShare.nShare.i,\n    j: encryptedNShare.nShare.j,\n    n: encryptedNShare.nShare.n,\n    y: encryptedNShare.nShare.publicShare.slice(0, 66),\n    u: u,\n    chaincode: encryptedNShare.nShare.publicShare.slice(66, 130),\n    v: encryptedNShare.nShare.vssProof,\n  };\n}\n\n/**\n * Gets public key from common keychain\n * @param commonKeyChain - common keychain of ecdsa tss\n * @returns public key\n */\nexport function getPublicKey(commonKeyChain: string): string {\n  return commonKeyChain.slice(0, 66);\n}\n\nexport const delimeter = ':';\nexport const secondaryDelimeter = '-';\n\nfunction validateSharesLength(shares: string[], expectedLength: number, shareName: string) {\n  if (shares.length < expectedLength) {\n    throw new Error(`Invalid ${shareName} share`);\n  }\n}\n\nfunction validateOptionalValues(shares: string[], start: number, end: number, shareName: string, valueName: string) {\n  let found = false;\n  for (let i = start; i < end; i++) {\n    if (shares[i]) {\n      found = true;\n    } else if (found) {\n      throw new Error(`Inconsistent optional ${valueName} value in ${shareName} share`);\n    }\n  }\n  return found;\n}\n\n/**\n * parses K share from signature share record\n * @param share - signature share record\n * @returns K Share\n */\nexport function parseKShare(share: SignatureShareRecord): KShare {\n  const shares = share.share.split(delimeter);\n  validateSharesLength(shares, 11 + 2 * EcdsaPaillierProof.m, 'K');\n  const hasProof = validateOptionalValues(shares, 5, 11, 'K', 'proof');\n\n  const proof: RangeProofShare | undefined = hasProof\n    ? {\n        z: shares[5],\n        u: shares[6],\n        w: shares[7],\n        s: shares[8],\n        s1: shares[9],\n        s2: shares[10],\n      }\n    : undefined;\n\n  return {\n    i: getParticipantIndex(share.to),\n    j: getParticipantIndex(share.from),\n    k: shares[0],\n    n: shares[1],\n    ntilde: shares[2],\n    h1: shares[3],\n    h2: shares[4],\n    proof,\n    p: shares.slice(11, 11 + EcdsaPaillierProof.m),\n    sigma: shares.slice(11 + EcdsaPaillierProof.m, 11 + 2 * EcdsaPaillierProof.m),\n  };\n}\n\n/**\n * convert K share to signature share record\n * @param share - K share\n * @returns signature share record\n */\nexport function convertKShare(share: KShare): SignatureShareRecord {\n  return {\n    to: getParticipantFromIndex(share.i),\n    from: getParticipantFromIndex(share.j),\n    share: `${share.k}${delimeter}${share.n}${delimeter}${share.ntilde}${delimeter}${share.h1}${delimeter}${\n      share.h2\n    }${delimeter}${share.proof?.z || ''}${delimeter}${share.proof?.u || ''}${delimeter}${\n      share.proof?.w || ''\n    }${delimeter}${share.proof?.s || ''}${delimeter}${share.proof?.s1 || ''}${delimeter}${\n      share.proof?.s2 || ''\n    }${delimeter}${(share.p || []).join(delimeter)}${delimeter}${(share.sigma || []).join(delimeter)}`,\n  };\n}\n\n/**\n * parses A share from signature share record\n * @param share - signature share record\n * @returns A Share\n */\nexport function parseAShare(share: SignatureShareRecord): AShare {\n  const shares = share.share.split(delimeter);\n  validateSharesLength(shares, 37 + EcdsaPaillierProof.m, 'A');\n  const hasProof = validateOptionalValues(shares, 7, 13, 'A', 'proof');\n  const hasGammaProof = validateOptionalValues(shares, 13, 25, 'A', 'gammaProof');\n  const hasWProof = validateOptionalValues(shares, 25, 37, 'A', 'wProof');\n\n  const proof: RangeProofShare | undefined = hasProof\n    ? {\n        z: shares[7],\n        u: shares[8],\n        w: shares[9],\n        s: shares[10],\n        s1: shares[11],\n        s2: shares[12],\n      }\n    : undefined;\n\n  const gammaProof: RangeProofWithCheckShare | undefined = hasGammaProof\n    ? {\n        z: shares[13],\n        zprm: shares[14],\n        t: shares[15],\n        v: shares[16],\n        w: shares[17],\n        s: shares[18],\n        s1: shares[19],\n        s2: shares[20],\n        t1: shares[21],\n        t2: shares[22],\n        u: shares[23],\n        x: shares[24],\n      }\n    : undefined;\n\n  const wProof: RangeProofWithCheckShare | undefined = hasWProof\n    ? {\n        z: shares[25],\n        zprm: shares[26],\n        t: shares[27],\n        v: shares[28],\n        w: shares[29],\n        s: shares[30],\n        s1: shares[31],\n        s2: shares[32],\n        t1: shares[33],\n        t2: shares[34],\n        u: shares[35],\n        x: shares[36],\n      }\n    : undefined;\n\n  return {\n    i: getParticipantIndex(share.to),\n    j: getParticipantIndex(share.from),\n    k: shares[0],\n    alpha: shares[1],\n    mu: shares[2],\n    n: shares[3],\n    ntilde: shares[4],\n    h1: shares[5],\n    h2: shares[6],\n    proof,\n    gammaProof,\n    wProof,\n    sigma: shares.slice(37),\n  };\n}\n\n/**\n * convert A share to signature share record\n * @param share - A share\n * @returns signature share record\n */\nexport function convertAShare(share: AShare): SignatureShareRecord {\n  return {\n    to: getParticipantFromIndex(share.i),\n    from: getParticipantFromIndex(share.j),\n    share: `${share.k}${delimeter}${share.alpha}${delimeter}${share.mu}${delimeter}${share.n}${delimeter}${\n      share.ntilde\n    }${delimeter}${share.h1}${delimeter}${share.h2}${delimeter}${share.proof?.z || ''}${delimeter}${\n      share.proof?.u || ''\n    }${delimeter}${share.proof?.w || ''}${delimeter}${share.proof?.s || ''}${delimeter}${\n      share.proof?.s1 || ''\n    }${delimeter}${share.proof?.s2 || ''}${delimeter}${share.gammaProof?.z || ''}${delimeter}${\n      share.gammaProof?.zprm || ''\n    }${delimeter}${share.gammaProof?.t || ''}${delimeter}${share.gammaProof?.v || ''}${delimeter}${\n      share.gammaProof?.w || ''\n    }${delimeter}${share.gammaProof?.s || ''}${delimeter}${share.gammaProof?.s1 || ''}${delimeter}${\n      share.gammaProof?.s2 || ''\n    }${delimeter}${share.gammaProof?.t1 || ''}${delimeter}${share.gammaProof?.t2 || ''}${delimeter}${\n      share.gammaProof?.u || ''\n    }${delimeter}${share.gammaProof?.x || ''}${delimeter}${share.wProof?.z || ''}${delimeter}${\n      share.wProof?.zprm || ''\n    }${delimeter}${share.wProof?.t || ''}${delimeter}${share.wProof?.v || ''}${delimeter}${\n      share.wProof?.w || ''\n    }${delimeter}${share.wProof?.s || ''}${delimeter}${share.wProof?.s1 || ''}${delimeter}${\n      share.wProof?.s2 || ''\n    }${delimeter}${share.wProof?.t1 || ''}${delimeter}${share.wProof?.t2 || ''}${delimeter}${\n      share.wProof?.u || ''\n    }${delimeter}${share.wProof?.x || ''}${delimeter}${(share.sigma || []).join(delimeter)}`,\n  };\n}\n\n/**\n * parses Mu share from signature share record\n * @param share - signature share record\n * @returns Mu Share\n */\nexport function parseMuShare(share: SignatureShareRecord): MUShare {\n  const shares = share.share.split(delimeter);\n  validateSharesLength(shares, 26, 'Mu');\n  const hasGammaProof = validateOptionalValues(shares, 2, 14, 'Mu', 'gammaProof');\n  const hasWProof = validateOptionalValues(shares, 14, 26, 'Mu', 'wProof');\n\n  let gammaProof;\n  if (hasGammaProof) {\n    gammaProof = {\n      z: shares[2],\n      zprm: shares[3],\n      t: shares[4],\n      v: shares[5],\n      w: shares[6],\n      s: shares[7],\n      s1: shares[8],\n      s2: shares[9],\n      t1: shares[10],\n      t2: shares[11],\n      u: shares[12],\n      x: shares[13],\n    };\n  }\n\n  let wProof;\n  if (hasWProof) {\n    wProof = {\n      z: shares[14],\n      zprm: shares[15],\n      t: shares[16],\n      v: shares[17],\n      w: shares[18],\n      s: shares[19],\n      s1: shares[20],\n      s2: shares[21],\n      t1: shares[22],\n      t2: shares[23],\n      u: shares[24],\n      x: shares[25],\n    };\n  }\n\n  return {\n    i: getParticipantIndex(share.to),\n    j: getParticipantIndex(share.from),\n    alpha: shares[0],\n    mu: shares[1],\n    gammaProof,\n    wProof,\n  };\n}\n\n/**\n * convert Mu share to signature share record\n * @param share - Mu share\n * @returns signature share record\n */\nexport function convertMuShare(share: MUShare): SignatureShareRecord {\n  return {\n    to: getParticipantFromIndex(share.i),\n    from: getParticipantFromIndex(share.j),\n    share: `${share.alpha}${delimeter}${share.mu}${delimeter}${share.gammaProof?.z || ''}${delimeter}${\n      share.gammaProof?.zprm || ''\n    }${delimeter}${share.gammaProof?.t || ''}${delimeter}${share.gammaProof?.v || ''}${delimeter}${\n      share.gammaProof?.w || ''\n    }${delimeter}${share.gammaProof?.s || ''}${delimeter}${share.gammaProof?.s1 || ''}${delimeter}${\n      share.gammaProof?.s2 || ''\n    }${delimeter}${share.gammaProof?.t1 || ''}${delimeter}${share.gammaProof?.t2 || ''}${delimeter}${\n      share.gammaProof?.u || ''\n    }${delimeter}${share.gammaProof?.x || ''}${delimeter}${share.wProof?.z || ''}${delimeter}${\n      share.wProof?.zprm || ''\n    }${delimeter}${share.wProof?.t || ''}${delimeter}${share.wProof?.v || ''}${delimeter}${\n      share.wProof?.w || ''\n    }${delimeter}${share.wProof?.s || ''}${delimeter}${share.wProof?.s1 || ''}${delimeter}${\n      share.wProof?.s2 || ''\n    }${delimeter}${share.wProof?.t1 || ''}${delimeter}${share.wProof?.t2 || ''}${delimeter}${\n      share.wProof?.u || ''\n    }${delimeter}${share.wProof?.x || ''}`,\n  };\n}\n\n/**\n * parses D share from signature share record\n * @param share - signature share record\n * @returns D Share\n */\nexport function parseDShare(share: SignatureShareRecord): DShare {\n  const shares = share.share.split(delimeter);\n  validateSharesLength(shares, 2, 'D');\n\n  return {\n    i: getParticipantIndex(share.to),\n    j: getParticipantIndex(share.from),\n    delta: shares[0],\n    Gamma: shares[1],\n  };\n}\n\n/**\n * convert D share to signature share record\n * @param share - D share\n * @returns signature share record\n */\nexport function convertDShare(share: DShare): SignatureShareRecord {\n  return {\n    to: getParticipantFromIndex(share.i),\n    from: getParticipantFromIndex(share.j),\n    share: `${share.delta}${delimeter}${share.Gamma}`,\n  };\n}\n\n/**\n * parses S and D share from signature share record\n * @param share - signature share record\n * @returns Object containing S and D Share\n */\nexport function parseSDShare(share: SignatureShareRecord): { sShare: SignatureShare; dShare: DShare } {\n  const shares = share.share.split(secondaryDelimeter);\n  validateSharesLength(shares, 2, 'SD');\n\n  return {\n    sShare: parseSignatureShare({ to: share.to, from: share.from, share: shares[0] }),\n    dShare: parseDShare({ to: share.to, from: share.from, share: shares[1] }),\n  };\n}\n\n/**\n * convert S and D share to signature share record\n * @param share - S and D share in a object\n * @returns signature share record\n */\nexport function convertSDShare(share: { sShare: SShare; dShare: DShare }): SignatureShareRecord {\n  return {\n    to: getParticipantFromIndex(share.dShare.i),\n    from: getParticipantFromIndex(share.dShare.j),\n    share: `${share.sShare.R}${delimeter}${share.sShare.s}${delimeter}${share.sShare.y}${secondaryDelimeter}${share.dShare.delta}${delimeter}${share.dShare.Gamma}`,\n  };\n}\n\n/**\n * parses signature share from signature share record\n * @param share - signature share record\n * @returns Signature Share\n */\nexport function parseSignatureShare(share: SignatureShareRecord): SignatureShare {\n  const shares = share.share.split(delimeter);\n  validateSharesLength(shares, 3, 'Signature');\n\n  return {\n    i: getParticipantIndex(share.to),\n    R: shares[0],\n    s: shares[1],\n    y: shares[2],\n  };\n}\n\n/**\n * convets combined signature to signature share record\n * @param signature - combined signature share\n * @param userIndex - user index, either 1 (user) or 2 (backup)\n * @returns signature share record\n */\nexport function convertCombinedSignature(signature: Signature, userIndex: number): SignatureShareRecord {\n  return {\n    to: SignatureShareType.BITGO,\n    from: getParticipantFromIndex(userIndex),\n    share: `${signature.recid}${delimeter}${signature.r}${delimeter}${signature.s}${delimeter}${signature.y}`,\n  };\n}\n\nexport function parseCombinedSignature(share: SignatureShareRecord): Signature {\n  const shares = share.share.split(delimeter);\n  validateSharesLength(shares, 3, 'Signature');\n\n  return {\n    recid: Number(shares[0]),\n    r: shares[1],\n    s: shares[2],\n    y: shares[3],\n  };\n}\n\n/**\n * convert signature share to signature share record\n * @param share - Signature share\n * @param senderIndex\n * @param recipientIndex\n * @returns signature share record\n */\nexport function convertSignatureShare(\n  share: SignatureShare,\n  senderIndex: number,\n  recipientIndex: number\n): SignatureShareRecord {\n  return {\n    to: getParticipantFromIndex(recipientIndex),\n    from: getParticipantFromIndex(senderIndex),\n    share: `${share.R}${delimeter}${share.s}${delimeter}${share.y}`,\n  };\n}\n\n/**\n * converts B share to signature share record\n * @param share - B share\n * @returns signature share record\n */\nexport function convertBShare(share: BShare): SignatureShareRecord {\n  return {\n    to: SignatureShareType.BITGO,\n    from: getParticipantFromIndex(share.i),\n    share: `${share.beta}${delimeter}${share.gamma}${delimeter}${share.k}${delimeter}${share.nu}${delimeter}${\n      share.w\n    }${delimeter}${share.y}${delimeter}${share.l}${delimeter}${share.m}${delimeter}${share.n}${delimeter}${\n      share.ntilde\n    }${delimeter}${share.h1}${delimeter}${share.h2}${delimeter}${share.ck}${delimeter}${(share.p || []).join(\n      delimeter\n    )}`,\n  };\n}\n\n/**\n * parses B share from signature share record\n * @param share B share record\n * @returns B Share\n */\nexport function parseBShare(share: SignatureShareRecord): BShare {\n  const shares = share.share.split(delimeter);\n  validateSharesLength(shares, 13 + EcdsaPaillierProof.m, 'B');\n\n  return {\n    i: getParticipantIndex(share.to),\n    beta: shares[0],\n    gamma: shares[1],\n    k: shares[2],\n    nu: shares[3],\n    w: shares[4],\n    y: shares[5],\n    l: shares[6],\n    m: shares[7],\n    n: shares[8],\n    ntilde: shares[9],\n    h1: shares[10],\n    h2: shares[11],\n    ck: shares[12],\n    p: shares.slice(13, 13 + EcdsaPaillierProof.m),\n  };\n}\n\n/**\n * converts O share to signature share record\n * @param share O share\n * @returns signature share record\n */\nexport function convertOShare(share: OShare): SignatureShareRecord {\n  return {\n    to: SignatureShareType.BITGO,\n    from: getParticipantFromIndex(share.i),\n    share: `${share.Gamma}${delimeter}${share.delta}${delimeter}${share.k}${delimeter}${share.omicron}${delimeter}${share.y}`,\n  };\n}\n\n/**\n * parses O share from signature share record\n * @param share O share record\n * @returns O Share\n */\nexport function parseOShare(share: SignatureShareRecord): OShare {\n  const shares = share.share.split(delimeter);\n  validateSharesLength(shares, 5, 'O');\n\n  return {\n    i: getParticipantIndex(share.to),\n    Gamma: shares[0],\n    delta: shares[1],\n    k: shares[2],\n    omicron: shares[3],\n    y: shares[4],\n  };\n}\n\n/**\n * gets participant index\n * @param participant - participants (user, backup, or bitgo)\n * @returns index (1, 2, 0r 3)\n */\nexport function getParticipantIndex(participant: 'user' | 'backup' | 'bitgo'): number {\n  switch (participant) {\n    case 'user':\n      return 1;\n    case 'backup':\n      return 2;\n    case 'bitgo':\n      return 3;\n    default:\n      throw Error('Unkown participant');\n  }\n}\n\n/**\n * gets participant name by index\n * @param index participant index\n * @returns participant name\n */\nexport function getParticipantFromIndex(index: number): SignatureShareType {\n  switch (index) {\n    case 1:\n      return SignatureShareType.USER;\n    case 2:\n      return SignatureShareType.BACKUP;\n    case 3:\n      return SignatureShareType.BITGO;\n    default:\n      throw new Error(`Unknown participant index ${index}`);\n  }\n}\n\n/**\n * Helper function to verify u-value wallet signatures for the bitgo-user and bitgo-backup shares.\n * @param params\n */\nexport async function verifyWalletSignature(params: {\n  walletSignature: pgp.Key;\n  bitgoPub: pgp.Key;\n  commonKeychain: string;\n  userKeyId: string;\n  backupKeyId: string;\n  decryptedShare: string;\n  verifierIndex: 1 | 2;\n}): Promise<void> {\n  const rawNotations = await commonVerifyWalletSignature(params);\n  const publicUValueRawNotationIndex = 2 + params.verifierIndex;\n\n  // Derive public form of u-value\n  const publicUValue = ecc.pointFromScalar(Buffer.from(params.decryptedShare.slice(0, 64), 'hex'), true);\n  assert(publicUValue !== null, 'null public u-value');\n  // Verify that the u value + chaincode is equal to the proof retrieved from the raw notations\n  assert(\n    Buffer.from(publicUValue).toString('hex') + params.decryptedShare.slice(64) ===\n      Buffer.from(rawNotations[publicUValueRawNotationIndex].value).toString(),\n    'bitgo share mismatch'\n  );\n}\n"]}Выполнить команду
Для локальной разработки. Не используйте в интернете!