PHP WebShell
Текущая директория: /usr/lib/node_modules/bitgo/node_modules/@bitgo/sdk-coin-cspr/dist/src
Просмотр файла: cspr.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.Cspr = void 0;
/**
* @prettier
*/
const CsprLib = __importStar(require("./lib"));
const secp256k1_1 = require("@bitgo/secp256k1");
const bignumber_js_1 = __importDefault(require("bignumber.js"));
const statics_1 = require("@bitgo/statics");
const sdk_core_1 = require("@bitgo/sdk-core");
class Cspr extends sdk_core_1.BaseCoin {
constructor(bitgo, staticsCoin) {
super(bitgo);
if (!staticsCoin) {
throw new Error('missing required constructor parameter staticsCoin');
}
this._staticsCoin = staticsCoin;
}
static createInstance(bitgo, staticsCoin) {
return new Cspr(bitgo, staticsCoin);
}
getChain() {
return this._staticsCoin.name;
}
getFamily() {
return this._staticsCoin.family;
}
getFullName() {
return this._staticsCoin.fullName;
}
getBaseFactor() {
return Math.pow(10, this._staticsCoin.decimalPlaces);
}
/** inherited doc */
getDefaultMultisigType() {
return sdk_core_1.multisigTypes.onchain;
}
async verifyTransaction(params) {
// TODO: Implement when available on the SDK.
return true;
}
/**
* Check if address is valid, then make sure it matches the root address.
*
* @param {VerifyAddressOptions} params address and rootAddress to verify
*/
async isWalletAddress(params) {
const { address, rootAddress } = params;
if (!this.isValidAddress(address)) {
throw new sdk_core_1.InvalidAddressError(`invalid address: ${address}`);
}
if (!this.isValidAddress(rootAddress)) {
throw new sdk_core_1.InvalidAddressError('wallet root address is not valid');
}
const newAddressDetails = CsprLib.Utils.getAddressDetails(address);
const rootAddressDetails = CsprLib.Utils.getAddressDetails(rootAddress);
if (newAddressDetails.address.toLowerCase() !== rootAddressDetails.address.toLowerCase()) {
throw new sdk_core_1.UnexpectedAddressError(`address validation failure: ${newAddressDetails.address} vs ${rootAddress}`);
}
return true;
}
/**
* Generate Casper key pair - BitGo xpub format
*
* @param {Buffer} seed - Seed from which the new keypair should be generated, otherwise a random seed is used
* @returns {Object} object with generated xpub and xprv
*/
generateKeyPair(seed) {
const keyPair = seed ? new CsprLib.KeyPair({ seed }) : new CsprLib.KeyPair();
const keys = keyPair.getExtendedKeys();
if (!keys.xprv) {
throw new Error('Missing xprv in key generation.');
}
return {
pub: keys.xpub,
prv: keys.xprv,
};
}
isValidPub(pub) {
// TODO(STLX-1344): Validate using account-lib when available
// return accountLib.Cspr.Utils.isValidPublicKey(pub);
try {
new CsprLib.KeyPair({ pub });
return true;
}
catch (e) {
return false;
}
}
/**
* Return boolean indicating whether input is valid private key for the coin
*
* @param prv the prv to be checked
* @returns is it valid?
*/
isValidPrv(prv) {
// TODO(STLX-1345): Validate using account-lib when available
// return accountLib.Cspr.Utils.isValidPrivateKey(prv);
try {
new CsprLib.KeyPair({ prv });
return true;
}
catch (e) {
return false;
}
}
/**
* Return boolean indicating whether input is valid CSPR address
*
* @param address the pub to be checked
* @returns true if the address is valid
*/
isValidAddress(address) {
try {
const addressDetails = CsprLib.Utils.getAddressDetails(address);
return address === CsprLib.Utils.normalizeAddress(addressDetails);
}
catch (e) {
return false;
}
}
/**
* Assemble keychain and half-sign prebuilt transaction
*
* @param {SignTransactionOptions} params data required to rebuild and sign the transaction
* @param {TransactionPrebuild} params.txPrebuild prebuild object returned by platform
* @param {String} params.prv user prv used to sign the transaction
* @returns Bluebird<SignedTransaction>
*/
async signTransaction(params) {
const txBuilder = this.getBuilder().from(params.txPrebuild.txHex);
const key = params.prv;
txBuilder.sign({ key });
const transaction = await txBuilder.build();
if (!transaction) {
throw new sdk_core_1.InvalidTransactionError('Error while trying to build transaction');
}
const response = {
txHex: transaction.toBroadcastFormat(),
};
return transaction.signature.length >= 2 ? response : { halfSigned: response };
}
async parseTransaction(params) {
return {};
}
/**
* Extend walletParams with extra params required for generating a Casper wallet
*
* Casper wallets have three three keys, user, backup and bitgo.
* Initially, we need a root prv to generate the account, which must be distinct from all three keychains on the wallet.
* If a root private key is not provided, a random one is generated.
* The root public key is the basis for the wallet root address.
*/
async supplementGenerateWallet(walletParams) {
if (walletParams.rootPrivateKey) {
if (!this.isValidPrv(walletParams.rootPrivateKey) || walletParams.rootPrivateKey.length !== 64) {
throw new Error('rootPrivateKey needs to be a hexadecimal private key string');
}
}
else {
const keyPair = secp256k1_1.ECPair.makeRandom();
if (!keyPair.privateKey) {
throw new Error('no privateKey');
}
walletParams.rootPrivateKey = keyPair.privateKey.toString('hex');
}
return walletParams;
}
/**
* Sign message with private key
*
* @param key
* @param message
*/
async signMessage(key, message) {
const keyPair = new CsprLib.KeyPair({ prv: key.prv });
const messageHex = typeof message === 'string' ? message : message.toString('hex');
const signatureData = CsprLib.Utils.signMessage(keyPair, messageHex);
return Buffer.from(signatureData.signature);
}
/**
* Explain a Casper transaction from Raw Tx
*
* @param {ExplainTransactionOptions} params given explain transaction params
* @param {String} params.txHex raw transaction
* @param {String} params.halfSigned.txHex raw half signed transaction
* @param {TransactionFee} fee fee information
* @returns Bluebird<TransactionExplanation>
*/
async explainTransaction(params) {
const txHex = params.txHex || (params.halfSigned && params.halfSigned.txHex);
if (!txHex || !params.feeInfo) {
throw new Error('missing explain tx parameters');
}
const txBuilder = this.getBuilder().from(txHex);
const tx = await txBuilder.build();
if (!tx) {
throw new sdk_core_1.InvalidTransactionError('Error while trying to build transaction');
}
const id = Buffer.from(tx.casperTx.hash).toString('hex');
const amount = CsprLib.Utils.getTransferAmount(tx.casperTx.session);
let transferId;
const outputs = [];
const operations = [];
switch (tx.type) {
case sdk_core_1.TransactionType.Send: {
transferId = CsprLib.Utils.getTransferId(tx.casperTx.session);
const toAddress = CsprLib.Utils.getTransferDestinationAddress(tx._deploy.session);
outputs.push({
address: toAddress,
amount,
coin: this.getChain(),
});
break;
}
case sdk_core_1.TransactionType.StakingLock: {
const validator = CsprLib.Utils.getValidatorAddress(tx._deploy.session);
operations.push({
type: sdk_core_1.TransactionType.StakingLock,
amount,
coin: this.getChain(),
validator: validator,
});
break;
}
case sdk_core_1.TransactionType.StakingUnlock: {
const validator = CsprLib.Utils.getValidatorAddress(tx._deploy.session);
operations.push({
type: sdk_core_1.TransactionType.StakingUnlock,
amount,
coin: this.getChain(),
validator: validator,
});
break;
}
default: {
throw new sdk_core_1.InvalidTransactionError('Error while trying to get transaction type');
}
}
const outputAmount = outputs
.reduce((acumulator, output) => {
const currentValue = new bignumber_js_1.default(output.amount);
return acumulator.plus(currentValue);
}, new bignumber_js_1.default(0))
.toFixed(0);
const displayOrder = [
'id',
'outputAmount',
'changeAmount',
'outputs',
'changeOutputs',
'transferId',
'fee',
'operations',
];
return {
displayOrder,
id,
outputs,
outputAmount,
changeOutputs: [], // account based does not use change outputs
changeAmount: '0', // account base does not make change
transferId,
fee: params.feeInfo,
operations,
};
}
getBuilder() {
return new CsprLib.TransactionBuilderFactory(statics_1.coins.get(this.getChain()));
}
/** @inheritDoc */
auditDecryptedKey(params) {
throw new sdk_core_1.MethodNotImplementedError();
}
}
exports.Cspr = Cspr;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cspr.js","sourceRoot":"","sources":["../../src/cspr.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;GAEG;AACH,+CAAiC;AACjC,gDAA0C;AAC1C,gEAAqC;AAErC,4CAAgF;AAChF,8CAoByB;AA6CzB,MAAa,IAAK,SAAQ,mBAAQ;IAGhC,YAAY,KAAgB,EAAE,WAAuC;QACnE,KAAK,CAAC,KAAK,CAAC,CAAC;QAEb,IAAI,CAAC,WAAW,EAAE,CAAC;YACjB,MAAM,IAAI,KAAK,CAAC,oDAAoD,CAAC,CAAC;QACxE,CAAC;QAED,IAAI,CAAC,YAAY,GAAG,WAAW,CAAC;IAClC,CAAC;IAED,MAAM,CAAC,cAAc,CAAC,KAAgB,EAAE,WAAuC;QAC7E,OAAO,IAAI,IAAI,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;IACtC,CAAC;IAED,QAAQ;QACN,OAAO,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC;IAChC,CAAC;IACD,SAAS;QACP,OAAO,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC;IAClC,CAAC;IACD,WAAW;QACT,OAAO,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC;IACpC,CAAC;IACD,aAAa;QACX,OAAO,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC;IACvD,CAAC;IAED,oBAAoB;IACpB,sBAAsB;QACpB,OAAO,wBAAa,CAAC,OAAO,CAAC;IAC/B,CAAC;IAED,KAAK,CAAC,iBAAiB,CAAC,MAAgC;QACtD,6CAA6C;QAC7C,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,eAAe,CAAC,MAAgC;QACpD,MAAM,EAAE,OAAO,EAAE,WAAW,EAAE,GAAG,MAAM,CAAC;QACxC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,EAAE,CAAC;YAClC,MAAM,IAAI,8BAAmB,CAAC,oBAAoB,OAAO,EAAE,CAAC,CAAC;QAC/D,CAAC;QACD,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,EAAE,CAAC;YACtC,MAAM,IAAI,8BAAmB,CAAC,kCAAkC,CAAC,CAAC;QACpE,CAAC;QAED,MAAM,iBAAiB,GAAG,OAAO,CAAC,KAAK,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC;QACnE,MAAM,kBAAkB,GAAG,OAAO,CAAC,KAAK,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC;QACxE,IAAI,iBAAiB,CAAC,OAAO,CAAC,WAAW,EAAE,KAAK,kBAAkB,CAAC,OAAO,CAAC,WAAW,EAAE,EAAE,CAAC;YACzF,MAAM,IAAI,iCAAsB,CAAC,+BAA+B,iBAAiB,CAAC,OAAO,OAAO,WAAW,EAAE,CAAC,CAAC;QACjH,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;;;OAKG;IACH,eAAe,CAAC,IAAa;QAC3B,MAAM,OAAO,GAAG,IAAI,CAAC,CAAC,CAAC,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,OAAO,CAAC,OAAO,EAAE,CAAC;QAC7E,MAAM,IAAI,GAAG,OAAO,CAAC,eAAe,EAAE,CAAC;QAEvC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;YACf,MAAM,IAAI,KAAK,CAAC,iCAAiC,CAAC,CAAC;QACrD,CAAC;QAED,OAAO;YACL,GAAG,EAAE,IAAI,CAAC,IAAI;YACd,GAAG,EAAE,IAAI,CAAC,IAAI;SACf,CAAC;IACJ,CAAC;IAED,UAAU,CAAC,GAAW;QACpB,6DAA6D;QAC7D,uDAAuD;QACvD,IAAI,CAAC;YACH,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC;YAC7B,OAAO,IAAI,CAAC;QACd,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;IAED;;;;;OAKG;IACH,UAAU,CAAC,GAAW;QACpB,6DAA6D;QAC7D,wDAAwD;QACxD,IAAI,CAAC;YACH,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC;YAC7B,OAAO,IAAI,CAAC;QACd,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;IAED;;;;;OAKG;IACH,cAAc,CAAC,OAAe;QAC5B,IAAI,CAAC;YACH,MAAM,cAAc,GAAG,OAAO,CAAC,KAAK,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC;YAChE,OAAO,OAAO,KAAK,OAAO,CAAC,KAAK,CAAC,gBAAgB,CAAC,cAAc,CAAC,CAAC;QACpE,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;IAED;;;;;;;OAOG;IACH,KAAK,CAAC,eAAe,CAAC,MAA8B;QAClD,MAAM,SAAS,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;QAClE,MAAM,GAAG,GAAG,MAAM,CAAC,GAAG,CAAC;QACvB,SAAS,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC;QAExB,MAAM,WAAW,GAAQ,MAAM,SAAS,CAAC,KAAK,EAAE,CAAC;QACjD,IAAI,CAAC,WAAW,EAAE,CAAC;YACjB,MAAM,IAAI,kCAAuB,CAAC,yCAAyC,CAAC,CAAC;QAC/E,CAAC;QACD,MAAM,QAAQ,GAAG;YACf,KAAK,EAAE,WAAW,CAAC,iBAAiB,EAAE;SACvC,CAAC;QACF,OAAO,WAAW,CAAC,SAAS,CAAC,MAAM,IAAI,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,UAAU,EAAE,QAAQ,EAAE,CAAC;IACjF,CAAC;IAED,KAAK,CAAC,gBAAgB,CAAC,MAA+B;QACpD,OAAO,EAAE,CAAC;IACZ,CAAC;IAED;;;;;;;OAOG;IACH,KAAK,CAAC,wBAAwB,CAC5B,YAA6C;QAE7C,IAAI,YAAY,CAAC,cAAc,EAAE,CAAC;YAChC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,cAAc,CAAC,IAAI,YAAY,CAAC,cAAc,CAAC,MAAM,KAAK,EAAE,EAAE,CAAC;gBAC/F,MAAM,IAAI,KAAK,CAAC,6DAA6D,CAAC,CAAC;YACjF,CAAC;QACH,CAAC;aAAM,CAAC;YACN,MAAM,OAAO,GAAG,kBAAM,CAAC,UAAU,EAAE,CAAC;YACpC,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE,CAAC;gBACxB,MAAM,IAAI,KAAK,CAAC,eAAe,CAAC,CAAC;YACnC,CAAC;YACD,YAAY,CAAC,cAAc,GAAG,OAAO,CAAC,UAAU,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QACnE,CAAC;QACD,OAAO,YAAY,CAAC;IACtB,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,WAAW,CAAC,GAAY,EAAE,OAAwB;QACtD,MAAM,OAAO,GAAG,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,GAAG,CAAC,GAAG,EAAE,CAAC,CAAC;QACtD,MAAM,UAAU,GAAG,OAAO,OAAO,KAAK,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QACnF,MAAM,aAAa,GAAG,OAAO,CAAC,KAAK,CAAC,WAAW,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC;QACrE,OAAO,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC;IAC9C,CAAC;IAED;;;;;;;;OAQG;IACH,KAAK,CAAC,kBAAkB,CAAC,MAAiC;QACxD,MAAM,KAAK,GAAG,MAAM,CAAC,KAAK,IAAI,CAAC,MAAM,CAAC,UAAU,IAAI,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;QAC7E,IAAI,CAAC,KAAK,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;YAC9B,MAAM,IAAI,KAAK,CAAC,+BAA+B,CAAC,CAAC;QACnD,CAAC;QACD,MAAM,SAAS,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAEhD,MAAM,EAAE,GAAQ,MAAM,SAAS,CAAC,KAAK,EAAE,CAAC;QACxC,IAAI,CAAC,EAAE,EAAE,CAAC;YACR,MAAM,IAAI,kCAAuB,CAAC,yCAAyC,CAAC,CAAC;QAC/E,CAAC;QACD,MAAM,EAAE,GAAG,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QACzD,MAAM,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC,iBAAiB,CAAC,EAAE,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;QACpE,IAAI,UAAU,CAAC;QACf,MAAM,OAAO,GAAwB,EAAE,CAAC;QACxC,MAAM,UAAU,GAA2B,EAAE,CAAC;QAE9C,QAAQ,EAAE,CAAC,IAAI,EAAE,CAAC;YAChB,KAAK,0BAAe,CAAC,IAAI,CAAC,CAAC,CAAC;gBAC1B,UAAU,GAAG,OAAO,CAAC,KAAK,CAAC,aAAa,CAAC,EAAE,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;gBAC9D,MAAM,SAAS,GAAG,OAAO,CAAC,KAAK,CAAC,6BAA6B,CAAC,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;gBAClF,OAAO,CAAC,IAAI,CAAC;oBACX,OAAO,EAAE,SAAS;oBAClB,MAAM;oBACN,IAAI,EAAE,IAAI,CAAC,QAAQ,EAAE;iBACtB,CAAC,CAAC;gBACH,MAAM;YACR,CAAC;YACD,KAAK,0BAAe,CAAC,WAAW,CAAC,CAAC,CAAC;gBACjC,MAAM,SAAS,GAAG,OAAO,CAAC,KAAK,CAAC,mBAAmB,CAAC,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;gBACxE,UAAU,CAAC,IAAI,CAAC;oBACd,IAAI,EAAE,0BAAe,CAAC,WAAW;oBACjC,MAAM;oBACN,IAAI,EAAE,IAAI,CAAC,QAAQ,EAAE;oBACrB,SAAS,EAAE,SAAS;iBACrB,CAAC,CAAC;gBACH,MAAM;YACR,CAAC;YACD,KAAK,0BAAe,CAAC,aAAa,CAAC,CAAC,CAAC;gBACnC,MAAM,SAAS,GAAG,OAAO,CAAC,KAAK,CAAC,mBAAmB,CAAC,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;gBACxE,UAAU,CAAC,IAAI,CAAC;oBACd,IAAI,EAAE,0BAAe,CAAC,aAAa;oBACnC,MAAM;oBACN,IAAI,EAAE,IAAI,CAAC,QAAQ,EAAE;oBACrB,SAAS,EAAE,SAAS;iBACrB,CAAC,CAAC;gBACH,MAAM;YACR,CAAC;YACD,OAAO,CAAC,CAAC,CAAC;gBACR,MAAM,IAAI,kCAAuB,CAAC,4CAA4C,CAAC,CAAC;YAClF,CAAC;QACH,CAAC;QAED,MAAM,YAAY,GAAG,OAAO;aACzB,MAAM,CAAC,CAAC,UAAU,EAAE,MAAM,EAAE,EAAE;YAC7B,MAAM,YAAY,GAAG,IAAI,sBAAS,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;YAClD,OAAO,UAAU,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QACvC,CAAC,EAAE,IAAI,sBAAS,CAAC,CAAC,CAAC,CAAC;aACnB,OAAO,CAAC,CAAC,CAAC,CAAC;QAEd,MAAM,YAAY,GAAG;YACnB,IAAI;YACJ,cAAc;YACd,cAAc;YACd,SAAS;YACT,eAAe;YACf,YAAY;YACZ,KAAK;YACL,YAAY;SACb,CAAC;QAEF,OAAO;YACL,YAAY;YACZ,EAAE;YACF,OAAO;YACP,YAAY;YACZ,aAAa,EAAE,EAAE,EAAE,4CAA4C;YAC/D,YAAY,EAAE,GAAG,EAAE,oCAAoC;YACvD,UAAU;YACV,GAAG,EAAE,MAAM,CAAC,OAAO;YACnB,UAAU;SACJ,CAAC;IACX,CAAC;IAEO,UAAU;QAChB,OAAO,IAAI,OAAO,CAAC,yBAAyB,CAAC,eAAK,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;IAC3E,CAAC;IAED,kBAAkB;IAClB,iBAAiB,CAAC,MAA+B;QAC/C,MAAM,IAAI,oCAAyB,EAAE,CAAC;IACxC,CAAC;CACF;AAnSD,oBAmSC","sourcesContent":["/**\n * @prettier\n */\nimport * as CsprLib from './lib';\nimport { ECPair } from '@bitgo/secp256k1';\nimport BigNumber from 'bignumber.js';\n\nimport { BaseCoin as StaticsBaseCoin, CoinFamily, coins } from '@bitgo/statics';\nimport {\n  AuditDecryptedKeyParams,\n  BaseCoin,\n  BitGoBase,\n  InvalidAddressError,\n  InvalidTransactionError,\n  KeyPair,\n  MultisigType,\n  multisigTypes,\n  ParsedTransaction,\n  ParseTransactionOptions,\n  SignedTransaction,\n  SignTransactionOptions as BaseSignTransactionOptions,\n  TransactionExplanation,\n  TransactionPrebuild as BaseTransactionPrebuild,\n  TransactionType,\n  UnexpectedAddressError,\n  VerifyAddressOptions,\n  VerifyTransactionOptions,\n  MethodNotImplementedError,\n} from '@bitgo/sdk-core';\n\ninterface SignTransactionOptions extends BaseSignTransactionOptions {\n  txPrebuild: TransactionPrebuild;\n  prv: string;\n}\n\nexport interface TransactionPrebuild extends BaseTransactionPrebuild {\n  txHex: string;\n}\n\nexport interface TransactionFee {\n  gasLimit: string;\n  gasPrice: string;\n}\n\nexport interface ExplainTransactionOptions {\n  txHex?: string;\n  halfSigned?: {\n    txHex: string;\n  };\n  feeInfo: TransactionFee;\n}\n\ninterface SupplementGenerateWalletOptions {\n  rootPrivateKey?: string;\n}\n\ninterface TransactionOutput {\n  address: string;\n  amount: string;\n  coin: string;\n}\n\ninterface TransactionOperation {\n  type: number;\n  amount: string;\n  coin: string;\n  validator: string;\n}\n\ninterface CsprVerifyAddressOptions extends VerifyAddressOptions {\n  rootAddress: string;\n}\n\nexport class Cspr extends BaseCoin {\n  protected readonly _staticsCoin: Readonly<StaticsBaseCoin>;\n\n  constructor(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>) {\n    super(bitgo);\n\n    if (!staticsCoin) {\n      throw new Error('missing required constructor parameter staticsCoin');\n    }\n\n    this._staticsCoin = staticsCoin;\n  }\n\n  static createInstance(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>): BaseCoin {\n    return new Cspr(bitgo, staticsCoin);\n  }\n\n  getChain(): string {\n    return this._staticsCoin.name;\n  }\n  getFamily(): CoinFamily {\n    return this._staticsCoin.family;\n  }\n  getFullName(): string {\n    return this._staticsCoin.fullName;\n  }\n  getBaseFactor(): string | number {\n    return Math.pow(10, this._staticsCoin.decimalPlaces);\n  }\n\n  /** inherited doc */\n  getDefaultMultisigType(): MultisigType {\n    return multisigTypes.onchain;\n  }\n\n  async verifyTransaction(params: VerifyTransactionOptions): Promise<boolean> {\n    // TODO: Implement when available on the SDK.\n    return true;\n  }\n\n  /**\n   * Check if address is valid, then make sure it matches the root address.\n   *\n   * @param {VerifyAddressOptions} params address and rootAddress to verify\n   */\n  async isWalletAddress(params: CsprVerifyAddressOptions): Promise<boolean> {\n    const { address, rootAddress } = params;\n    if (!this.isValidAddress(address)) {\n      throw new InvalidAddressError(`invalid address: ${address}`);\n    }\n    if (!this.isValidAddress(rootAddress)) {\n      throw new InvalidAddressError('wallet root address is not valid');\n    }\n\n    const newAddressDetails = CsprLib.Utils.getAddressDetails(address);\n    const rootAddressDetails = CsprLib.Utils.getAddressDetails(rootAddress);\n    if (newAddressDetails.address.toLowerCase() !== rootAddressDetails.address.toLowerCase()) {\n      throw new UnexpectedAddressError(`address validation failure: ${newAddressDetails.address} vs ${rootAddress}`);\n    }\n    return true;\n  }\n\n  /**\n   * Generate Casper key pair - BitGo xpub format\n   *\n   * @param {Buffer} seed - Seed from which the new keypair should be generated, otherwise a random seed is used\n   * @returns {Object} object with generated xpub and xprv\n   */\n  generateKeyPair(seed?: Buffer): KeyPair {\n    const keyPair = seed ? new CsprLib.KeyPair({ seed }) : new CsprLib.KeyPair();\n    const keys = keyPair.getExtendedKeys();\n\n    if (!keys.xprv) {\n      throw new Error('Missing xprv in key generation.');\n    }\n\n    return {\n      pub: keys.xpub,\n      prv: keys.xprv,\n    };\n  }\n\n  isValidPub(pub: string): boolean {\n    // TODO(STLX-1344): Validate using account-lib when available\n    //  return accountLib.Cspr.Utils.isValidPublicKey(pub);\n    try {\n      new CsprLib.KeyPair({ pub });\n      return true;\n    } catch (e) {\n      return false;\n    }\n  }\n\n  /**\n   * Return boolean indicating whether input is valid private key for the coin\n   *\n   * @param prv the prv to be checked\n   * @returns is it valid?\n   */\n  isValidPrv(prv: string): boolean {\n    // TODO(STLX-1345): Validate using account-lib when available\n    //  return accountLib.Cspr.Utils.isValidPrivateKey(prv);\n    try {\n      new CsprLib.KeyPair({ prv });\n      return true;\n    } catch (e) {\n      return false;\n    }\n  }\n\n  /**\n   * Return boolean indicating whether input is valid CSPR address\n   *\n   * @param address the pub to be checked\n   * @returns true if the address is valid\n   */\n  isValidAddress(address: string): boolean {\n    try {\n      const addressDetails = CsprLib.Utils.getAddressDetails(address);\n      return address === CsprLib.Utils.normalizeAddress(addressDetails);\n    } catch (e) {\n      return false;\n    }\n  }\n\n  /**\n   * Assemble keychain and half-sign prebuilt transaction\n   *\n   * @param {SignTransactionOptions} params data required to rebuild and sign the transaction\n   * @param {TransactionPrebuild} params.txPrebuild prebuild object returned by platform\n   * @param {String} params.prv user prv used to sign the transaction\n   * @returns Bluebird<SignedTransaction>\n   */\n  async signTransaction(params: SignTransactionOptions): Promise<SignedTransaction> {\n    const txBuilder = this.getBuilder().from(params.txPrebuild.txHex);\n    const key = params.prv;\n    txBuilder.sign({ key });\n\n    const transaction: any = await txBuilder.build();\n    if (!transaction) {\n      throw new InvalidTransactionError('Error while trying to build transaction');\n    }\n    const response = {\n      txHex: transaction.toBroadcastFormat(),\n    };\n    return transaction.signature.length >= 2 ? response : { halfSigned: response };\n  }\n\n  async parseTransaction(params: ParseTransactionOptions): Promise<ParsedTransaction> {\n    return {};\n  }\n\n  /**\n   * Extend walletParams with extra params required for generating a Casper wallet\n   *\n   * Casper wallets have three three keys, user, backup and bitgo.\n   * Initially, we need a root prv to generate the account, which must be distinct from all three keychains on the wallet.\n   * If a root private key is not provided, a random one is generated.\n   * The root public key is the basis for the wallet root address.\n   */\n  async supplementGenerateWallet(\n    walletParams: SupplementGenerateWalletOptions\n  ): Promise<SupplementGenerateWalletOptions> {\n    if (walletParams.rootPrivateKey) {\n      if (!this.isValidPrv(walletParams.rootPrivateKey) || walletParams.rootPrivateKey.length !== 64) {\n        throw new Error('rootPrivateKey needs to be a hexadecimal private key string');\n      }\n    } else {\n      const keyPair = ECPair.makeRandom();\n      if (!keyPair.privateKey) {\n        throw new Error('no privateKey');\n      }\n      walletParams.rootPrivateKey = keyPair.privateKey.toString('hex');\n    }\n    return walletParams;\n  }\n\n  /**\n   * Sign message with private key\n   *\n   * @param key\n   * @param message\n   */\n  async signMessage(key: KeyPair, message: string | Buffer): Promise<Buffer> {\n    const keyPair = new CsprLib.KeyPair({ prv: key.prv });\n    const messageHex = typeof message === 'string' ? message : message.toString('hex');\n    const signatureData = CsprLib.Utils.signMessage(keyPair, messageHex);\n    return Buffer.from(signatureData.signature);\n  }\n\n  /**\n   * Explain a Casper transaction from Raw Tx\n   *\n   * @param {ExplainTransactionOptions} params given explain transaction params\n   * @param {String} params.txHex raw transaction\n   * @param {String} params.halfSigned.txHex raw half signed transaction\n   * @param {TransactionFee} fee fee information\n   * @returns Bluebird<TransactionExplanation>\n   */\n  async explainTransaction(params: ExplainTransactionOptions): Promise<TransactionExplanation> {\n    const txHex = params.txHex || (params.halfSigned && params.halfSigned.txHex);\n    if (!txHex || !params.feeInfo) {\n      throw new Error('missing explain tx parameters');\n    }\n    const txBuilder = this.getBuilder().from(txHex);\n\n    const tx: any = await txBuilder.build();\n    if (!tx) {\n      throw new InvalidTransactionError('Error while trying to build transaction');\n    }\n    const id = Buffer.from(tx.casperTx.hash).toString('hex');\n    const amount = CsprLib.Utils.getTransferAmount(tx.casperTx.session);\n    let transferId;\n    const outputs: TransactionOutput[] = [];\n    const operations: TransactionOperation[] = [];\n\n    switch (tx.type) {\n      case TransactionType.Send: {\n        transferId = CsprLib.Utils.getTransferId(tx.casperTx.session);\n        const toAddress = CsprLib.Utils.getTransferDestinationAddress(tx._deploy.session);\n        outputs.push({\n          address: toAddress,\n          amount,\n          coin: this.getChain(),\n        });\n        break;\n      }\n      case TransactionType.StakingLock: {\n        const validator = CsprLib.Utils.getValidatorAddress(tx._deploy.session);\n        operations.push({\n          type: TransactionType.StakingLock,\n          amount,\n          coin: this.getChain(),\n          validator: validator,\n        });\n        break;\n      }\n      case TransactionType.StakingUnlock: {\n        const validator = CsprLib.Utils.getValidatorAddress(tx._deploy.session);\n        operations.push({\n          type: TransactionType.StakingUnlock,\n          amount,\n          coin: this.getChain(),\n          validator: validator,\n        });\n        break;\n      }\n      default: {\n        throw new InvalidTransactionError('Error while trying to get transaction type');\n      }\n    }\n\n    const outputAmount = outputs\n      .reduce((acumulator, output) => {\n        const currentValue = new BigNumber(output.amount);\n        return acumulator.plus(currentValue);\n      }, new BigNumber(0))\n      .toFixed(0);\n\n    const displayOrder = [\n      'id',\n      'outputAmount',\n      'changeAmount',\n      'outputs',\n      'changeOutputs',\n      'transferId',\n      'fee',\n      'operations',\n    ];\n\n    return {\n      displayOrder,\n      id,\n      outputs,\n      outputAmount,\n      changeOutputs: [], // account based does not use change outputs\n      changeAmount: '0', // account base does not make change\n      transferId,\n      fee: params.feeInfo,\n      operations,\n    } as any;\n  }\n\n  private getBuilder(): CsprLib.TransactionBuilderFactory {\n    return new CsprLib.TransactionBuilderFactory(coins.get(this.getChain()));\n  }\n\n  /** @inheritDoc */\n  auditDecryptedKey(params: AuditDecryptedKeyParams) {\n    throw new MethodNotImplementedError();\n  }\n}\n"]}Выполнить команду
Для локальной разработки. Не используйте в интернете!