PHP WebShell
Текущая директория: /usr/lib/node_modules/bitgo/node_modules/@bitgo/sdk-coin-ethw/dist/src
Просмотр файла: ethw.js
"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.Ethw = void 0;
const superagent_1 = __importDefault(require("superagent"));
const sdk_core_1 = require("@bitgo/sdk-core");
const statics_1 = require("@bitgo/statics");
const sdk_coin_eth_1 = require("@bitgo/sdk-coin-eth");
class Ethw extends sdk_coin_eth_1.Eth {
constructor(bitgo, staticsCoin) {
super(bitgo, staticsCoin);
}
static createInstance(bitgo, staticsCoin) {
return new Ethw(bitgo, staticsCoin);
}
verifyTransaction(params) {
throw new Error('Method not implemented.');
}
async isWalletAddress(params) {
throw new Error('Method not implemented.');
}
parseTransaction(params) {
throw new Error('Method not implemented.');
}
generateKeyPair(seed) {
throw new Error('Method not implemented.');
}
/**
* Query full node for the balance of an address
* @param {string} address the ETHw address
* @returns {Promise<BN>} address balance
*/
async queryAddressBalance(address) {
const result = await this.recoveryFullNodeRPCQuery('eth_getBalance', [address, 'latest']);
// throw if the result does not exist or the result is not a valid number
if (!result || !result.result) {
throw new Error(`Could not obtain address balance for ${address} from full node, got: ${result.result}`);
}
return new sdk_coin_eth_1.optionalDeps.ethUtil.BN(result.result.slice(2), 16);
}
/**
* Queries the contract (via RPC) for the next sequence ID
* @param {string} address address of the contract
* @returns {Promise<number>} sequence ID
*/
async querySequenceId(address) {
// Get sequence ID using contract call
const sequenceIdMethodSignature = sdk_coin_eth_1.optionalDeps.ethAbi.methodID('getNextSequenceId', []);
const sequenceIdArgs = sdk_coin_eth_1.optionalDeps.ethAbi.rawEncode([], []);
const sequenceIdData = Buffer.concat([sequenceIdMethodSignature, sequenceIdArgs]).toString('hex');
const sequenceIdDataHex = sdk_coin_eth_1.optionalDeps.ethUtil.addHexPrefix(sequenceIdData);
const result = await this.recoveryFullNodeRPCQuery('eth_call', [
{ to: address, data: sequenceIdDataHex },
'latest',
]);
if (!result || !result.result) {
throw new Error('Could not obtain sequence ID from full node, got: ' + result.result);
}
const sequenceIdHex = result.result;
return new sdk_coin_eth_1.optionalDeps.ethUtil.BN(sequenceIdHex.slice(2), 16).toNumber();
}
/**
* Queries public full node to get the next ETHw nonce that should be used for the given ETH address
* @param {string} address
* @returns {Promise<number>} next ETHw nonce
*/
async getAddressNonce(address) {
const result = await this.recoveryFullNodeRPCQuery('eth_getTransactionCount', [address, 'latest']);
if (!result || !result.result) {
throw new Error('Unable to find next nonce from full node, got: ' + JSON.stringify(result));
}
return new sdk_coin_eth_1.optionalDeps.ethUtil.BN(result.result.slice(2), 16).toNumber();
}
/**
* Make a RPC query to full node for information such as balance, token balance, solidity calls
* @param {string} method RPC method to execute
* @param {Array} params params to include in the RPC request
* @returns {Promise<FullNodeResponseBody>} response from full node
*/
async recoveryFullNodeRPCQuery(method, params) {
const response = await superagent_1.default.post(sdk_core_1.common.Environments[this.bitgo.getEnv()].ethwFullNodeRPCBaseUrl).send({
method,
params,
id: 0,
jsonrpc: '2.0',
});
if (!response.ok) {
throw new Error('could not reach ETHW full node');
}
if (response.body.error) {
throw new Error(`ETHW full node error: ${response.body.error.code} - ${response.body.error.message}`);
}
return response.body;
}
/**
* Create a new transaction builder for the current chain
* @return a new transaction builder
*/
getTransactionBuilder() {
return new sdk_coin_eth_1.TransactionBuilder(statics_1.coins.get(this.getChain()));
}
}
exports.Ethw = Ethw;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ethw.js","sourceRoot":"","sources":["../../src/ethw.ts"],"names":[],"mappings":"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","sourcesContent":["import request from 'superagent';\n\nimport { BN } from 'ethereumjs-util';\n\nimport {\n  BaseCoin,\n  BitGoBase,\n  common,\n  KeyPair,\n  ParsedTransaction,\n  ParseTransactionOptions,\n  VerifyAddressOptions,\n  VerifyTransactionOptions,\n} from '@bitgo/sdk-core';\nimport { BaseCoin as StaticsBaseCoin, coins } from '@bitgo/statics';\nimport { Eth, optionalDeps, TransactionBuilder } from '@bitgo/sdk-coin-eth';\n\ntype FullNodeResponseBody = {\n  jsonrpc: string;\n  id: string;\n  result?: string;\n  error?: {\n    code: string;\n    message: string;\n  };\n};\n\nexport class Ethw extends Eth {\n  protected constructor(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>) {\n    super(bitgo, staticsCoin);\n  }\n\n  static createInstance(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>): BaseCoin {\n    return new Ethw(bitgo, staticsCoin);\n  }\n\n  verifyTransaction(params: VerifyTransactionOptions): Promise<boolean> {\n    throw new Error('Method not implemented.');\n  }\n  async isWalletAddress(params: VerifyAddressOptions): Promise<boolean> {\n    throw new Error('Method not implemented.');\n  }\n  parseTransaction(params: ParseTransactionOptions): Promise<ParsedTransaction> {\n    throw new Error('Method not implemented.');\n  }\n  generateKeyPair(seed?: Buffer | undefined): KeyPair {\n    throw new Error('Method not implemented.');\n  }\n\n  /**\n   * Query full node for the balance of an address\n   * @param {string} address the ETHw address\n   * @returns {Promise<BN>} address balance\n   */\n  async queryAddressBalance(address: string): Promise<BN> {\n    const result = await this.recoveryFullNodeRPCQuery('eth_getBalance', [address, 'latest']);\n    // throw if the result does not exist or the result is not a valid number\n    if (!result || !result.result) {\n      throw new Error(`Could not obtain address balance for ${address} from full node, got: ${result.result}`);\n    }\n    return new optionalDeps.ethUtil.BN(result.result.slice(2), 16);\n  }\n\n  /**\n   * Queries the contract (via RPC) for the next sequence ID\n   * @param {string} address address of the contract\n   * @returns {Promise<number>} sequence ID\n   */\n  async querySequenceId(address: string): Promise<number> {\n    // Get sequence ID using contract call\n    const sequenceIdMethodSignature = optionalDeps.ethAbi.methodID('getNextSequenceId', []);\n    const sequenceIdArgs = optionalDeps.ethAbi.rawEncode([], []);\n    const sequenceIdData = Buffer.concat([sequenceIdMethodSignature, sequenceIdArgs]).toString('hex');\n    const sequenceIdDataHex = optionalDeps.ethUtil.addHexPrefix(sequenceIdData);\n    const result = await this.recoveryFullNodeRPCQuery('eth_call', [\n      { to: address, data: sequenceIdDataHex },\n      'latest',\n    ]);\n    if (!result || !result.result) {\n      throw new Error('Could not obtain sequence ID from full node, got: ' + result.result);\n    }\n    const sequenceIdHex = result.result;\n    return new optionalDeps.ethUtil.BN(sequenceIdHex.slice(2), 16).toNumber();\n  }\n\n  /**\n   * Queries public full node to get the next ETHw nonce that should be used for the given ETH address\n   * @param {string} address\n   * @returns {Promise<number>} next ETHw nonce\n   */\n  async getAddressNonce(address: string): Promise<number> {\n    const result = await this.recoveryFullNodeRPCQuery('eth_getTransactionCount', [address, 'latest']);\n    if (!result || !result.result) {\n      throw new Error('Unable to find next nonce from full node, got: ' + JSON.stringify(result));\n    }\n    return new optionalDeps.ethUtil.BN(result.result.slice(2), 16).toNumber();\n  }\n\n  /**\n   * Make a RPC query to full node for information such as balance, token balance, solidity calls\n   * @param {string} method RPC method to execute\n   * @param {Array} params params to include in the RPC request\n   * @returns {Promise<FullNodeResponseBody>} response from full node\n   */\n  async recoveryFullNodeRPCQuery(method: string, params: Array<unknown>): Promise<FullNodeResponseBody> {\n    const response = await request.post(common.Environments[this.bitgo.getEnv()].ethwFullNodeRPCBaseUrl).send({\n      method,\n      params,\n      id: 0,\n      jsonrpc: '2.0',\n    });\n\n    if (!response.ok) {\n      throw new Error('could not reach ETHW full node');\n    }\n\n    if (response.body.error) {\n      throw new Error(`ETHW full node error: ${response.body.error.code} - ${response.body.error.message}`);\n    }\n    return response.body;\n  }\n\n  /**\n   * Create a new transaction builder for the current chain\n   * @return a new transaction builder\n   */\n  protected getTransactionBuilder(): TransactionBuilder {\n    return new TransactionBuilder(coins.get(this.getChain()));\n  }\n}\n"]}Выполнить команду
Для локальной разработки. Не используйте в интернете!