PHP WebShell
Текущая директория: /usr/lib/node_modules/bitgo/node_modules/@bitgo/sdk-api/dist/src/v1
Просмотр файла: blockchain.js
"use strict";
/**
* @hidden
*/
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
/**
*/
//
// Blockchain Object
// BitGo accessor to a any Bitcoin address.
// Using this does not require authentication and is unrelated to BitGo wallet management.
//
// Copyright 2014, BitGo, Inc. All Rights Reserved.
//
const lodash_1 = __importDefault(require("lodash"));
const sdk_core_1 = require("@bitgo/sdk-core");
//
// Constructor
//
const Blockchain = function (bitgo) {
// @ts-expect-error - no implicit this
this.bitgo = bitgo;
};
//
// Get an address
// Fetch an address summary information.
// Includes balance and pending balance.
//
// Parameters include:
// address: the address to get
//
Blockchain.prototype.getAddress = function (params, callback) {
params = params || {};
sdk_core_1.common.validateParams(params, ['address'], [], callback);
return Promise.resolve(this.bitgo.get(this.bitgo.url('/address/' + params.address)).result())
.then(callback)
.catch(callback);
};
//
// Get address transactions
// List the transactions for a given address
// Parameters include:
// address: the address to get transactions for
//
Blockchain.prototype.getAddressTransactions = function (params, callback) {
params = params || {};
sdk_core_1.common.validateParams(params, ['address'], [], callback);
// TODO: support start and limit params
return Promise.resolve(this.bitgo.get(this.bitgo.url('/address/' + params.address + '/tx')).result())
.then(callback)
.catch(callback);
};
//
// Unspent Transactions
// List the unspent outputs for a given address
// Parameters include:
// address: the address to get unspent transactions
// limit: return enough unspents to accumulate to at least this amount (in satoshis).
//
Blockchain.prototype.getAddressUnspents = function (params, callback) {
params = params || {};
sdk_core_1.common.validateParams(params, ['address'], [], callback);
let url = this.bitgo.url('/address/' + params.address + '/unspents');
if (params.limit) {
if (!lodash_1.default.isInteger(params.limit)) {
throw new Error('invalid limit - number expected');
}
url += '?limit=' + params.limit * 1e8;
}
return Promise.resolve(this.bitgo.get(url).result())
.then(function (body) {
return body.unspents;
})
.then(callback)
.catch(callback);
};
//
// Get transaction
// Fetch transaction details.
//
// Parameters include:
// id: the transaction id to get
//
Blockchain.prototype.getTransaction = function (params, callback) {
params = params || {};
sdk_core_1.common.validateParams(params, ['id'], [], callback);
return Promise.resolve(this.bitgo.get(this.bitgo.url('/tx/' + params.id)).result())
.then(callback)
.catch(callback);
};
//
// Get transaction that spends a specific output
// Fetch transaction details.
//
// Parameters include:
// txid: the transaction id of the output
// vout: the position of the output on the transaction that created it
//
Blockchain.prototype.getTransactionByInput = function (params, callback) {
params = params || {};
sdk_core_1.common.validateParams(params, ['txid'], [], callback);
if (!lodash_1.default.isInteger(params.vout)) {
throw new Error('invalid vout - number expected');
}
return Promise.resolve(this.bitgo.get(this.bitgo.url('/tx/input/' + params.txid + '/' + params.vout)).result())
.then(callback)
.catch(callback);
};
//
// Get block
// Fetch block details.
//
// Parameters include:
// id: the block hash to get, or latest for the latest
//
Blockchain.prototype.getBlock = function (params, callback) {
params = params || {};
sdk_core_1.common.validateParams(params, ['id'], [], callback);
return Promise.resolve(this.bitgo.get(this.bitgo.url('/block/' + params.id)).result())
.then(callback)
.catch(callback);
};
module.exports = Blockchain;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"blockchain.js","sourceRoot":"","sources":["../../../src/v1/blockchain.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @hidden\n */\n\n/**\n */\n//\n// Blockchain Object\n// BitGo accessor to a any Bitcoin address.\n// Using this does not require authentication and is unrelated to BitGo wallet management.\n//\n// Copyright 2014, BitGo, Inc.  All Rights Reserved.\n//\n\nimport _ from 'lodash';\n\nimport { common } from '@bitgo/sdk-core';\n\n//\n// Constructor\n//\nconst Blockchain = function (bitgo) {\n  // @ts-expect-error - no implicit this\n  this.bitgo = bitgo;\n};\n\n//\n// Get an address\n// Fetch an address summary information.\n// Includes balance and pending balance.\n//\n// Parameters include:\n//   address: the address to get\n//\nBlockchain.prototype.getAddress = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['address'], [], callback);\n\n  return Promise.resolve(this.bitgo.get(this.bitgo.url('/address/' + params.address)).result())\n    .then(callback)\n    .catch(callback);\n};\n\n//\n// Get address transactions\n// List the transactions for a given address\n// Parameters include:\n//   address: the address to get transactions for\n//\nBlockchain.prototype.getAddressTransactions = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['address'], [], callback);\n\n  // TODO: support start and limit params\n  return Promise.resolve(this.bitgo.get(this.bitgo.url('/address/' + params.address + '/tx')).result())\n    .then(callback)\n    .catch(callback);\n};\n\n//\n// Unspent Transactions\n// List the unspent outputs for a given address\n// Parameters include:\n//   address: the address to get unspent transactions\n//   limit: return enough unspents to accumulate to at least this amount (in satoshis).\n//\nBlockchain.prototype.getAddressUnspents = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['address'], [], callback);\n\n  let url = this.bitgo.url('/address/' + params.address + '/unspents');\n  if (params.limit) {\n    if (!_.isInteger(params.limit)) {\n      throw new Error('invalid limit - number expected');\n    }\n    url += '?limit=' + params.limit * 1e8;\n  }\n\n  return Promise.resolve(this.bitgo.get(url).result())\n    .then(function (body) {\n      return body.unspents;\n    })\n    .then(callback)\n    .catch(callback);\n};\n\n//\n// Get transaction\n// Fetch transaction details.\n//\n// Parameters include:\n//   id: the transaction id to get\n//\nBlockchain.prototype.getTransaction = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['id'], [], callback);\n\n  return Promise.resolve(this.bitgo.get(this.bitgo.url('/tx/' + params.id)).result())\n    .then(callback)\n    .catch(callback);\n};\n\n//\n// Get transaction that spends a specific output\n// Fetch transaction details.\n//\n// Parameters include:\n//   txid: the transaction id of the output\n//   vout: the position of the output on the transaction that created it\n//\nBlockchain.prototype.getTransactionByInput = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['txid'], [], callback);\n  if (!_.isInteger(params.vout)) {\n    throw new Error('invalid vout - number expected');\n  }\n  return Promise.resolve(this.bitgo.get(this.bitgo.url('/tx/input/' + params.txid + '/' + params.vout)).result())\n    .then(callback)\n    .catch(callback);\n};\n\n//\n// Get block\n// Fetch block details.\n//\n// Parameters include:\n//   id: the block hash to get, or latest for the latest\n//\nBlockchain.prototype.getBlock = function (params, callback) {\n  params = params || {};\n  common.validateParams(params, ['id'], [], callback);\n\n  return Promise.resolve(this.bitgo.get(this.bitgo.url('/block/' + params.id)).result())\n    .then(callback)\n    .catch(callback);\n};\n\nmodule.exports = Blockchain;\n"]}Выполнить команду
Для локальной разработки. Не используйте в интернете!