@bitgo-beta/sdk-api 1.10.1-beta.58 → 1.10.1-beta.581

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -2,6 +2,32 @@
2
2
  /**
3
3
  * @hidden
4
4
  */
5
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ var desc = Object.getOwnPropertyDescriptor(m, k);
8
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
9
+ desc = { enumerable: true, get: function() { return m[k]; } };
10
+ }
11
+ Object.defineProperty(o, k2, desc);
12
+ }) : (function(o, m, k, k2) {
13
+ if (k2 === undefined) k2 = k;
14
+ o[k2] = m[k];
15
+ }));
16
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
17
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
18
+ }) : function(o, v) {
19
+ o["default"] = v;
20
+ });
21
+ var __importStar = (this && this.__importStar) || function (mod) {
22
+ if (mod && mod.__esModule) return mod;
23
+ var result = {};
24
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
25
+ __setModuleDefault(result, mod);
26
+ return result;
27
+ };
28
+ var __importDefault = (this && this.__importDefault) || function (mod) {
29
+ return (mod && mod.__esModule) ? mod : { "default": mod };
30
+ };
5
31
  Object.defineProperty(exports, "__esModule", { value: true });
6
32
  /**
7
33
  */
@@ -13,9 +39,9 @@ Object.defineProperty(exports, "__esModule", { value: true });
13
39
  //
14
40
  const sdk_core_1 = require("@bitgo-beta/sdk-core");
15
41
  const utxo_lib_1 = require("@bitgo-beta/utxo-lib");
16
- const utxolib = require("@bitgo-beta/utxo-lib");
17
- const Bluebird = require("bluebird");
18
- const _ = require("lodash");
42
+ const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
43
+ const bluebird_1 = __importDefault(require("bluebird"));
44
+ const lodash_1 = __importDefault(require("lodash"));
19
45
  //
20
46
  // Constructor
21
47
  //
@@ -39,7 +65,7 @@ TravelRule.prototype.getRecipients = function (params, callback) {
39
65
  params.txid = params.txid || params.hash;
40
66
  sdk_core_1.common.validateParams(params, ['txid'], [], callback);
41
67
  const url = this.url(params.txid + '/recipients');
42
- return Bluebird.resolve(this.bitgo.get(url).result('recipients')).nodeify(callback);
68
+ return bluebird_1.default.resolve(this.bitgo.get(url).result('recipients')).nodeify(callback);
43
69
  };
44
70
  TravelRule.prototype.validateTravelInfo = function (info) {
45
71
  const fields = {
@@ -54,7 +80,7 @@ TravelRule.prototype.validateTravelInfo = function (info) {
54
80
  toUserAddress: { type: 'string' },
55
81
  extra: { type: 'object' },
56
82
  };
57
- _.forEach(fields, function (field, fieldName) {
83
+ lodash_1.default.forEach(fields, function (field, fieldName) {
58
84
  // No required fields yet -- should there be?
59
85
  if (field.required) {
60
86
  if (info[fieldName] === undefined) {
@@ -66,8 +92,8 @@ TravelRule.prototype.validateTravelInfo = function (info) {
66
92
  }
67
93
  });
68
94
  // Strip out any other fields we don't know about
69
- const result = _.pick(info, _.keys(fields));
70
- if (_.isEmpty(result)) {
95
+ const result = lodash_1.default.pick(info, lodash_1.default.keys(fields));
96
+ if (lodash_1.default.isEmpty(result)) {
71
97
  throw new Error('empty travel data');
72
98
  }
73
99
  return result;
@@ -84,20 +110,20 @@ TravelRule.prototype.validateTravelInfo = function (info) {
84
110
  */
85
111
  TravelRule.prototype.decryptReceivedTravelInfo = function (params = {}) {
86
112
  const tx = params.tx;
87
- if (!_.isObject(tx)) {
113
+ if (!lodash_1.default.isObject(tx)) {
88
114
  throw new Error('expecting tx param to be object');
89
115
  }
90
116
  if (!tx.receivedTravelInfo || !tx.receivedTravelInfo.length) {
91
117
  return tx;
92
118
  }
93
119
  const keychain = params.keychain;
94
- if (!_.isObject(keychain) || !_.isString(keychain.xprv)) {
120
+ if (!lodash_1.default.isObject(keychain) || !lodash_1.default.isString(keychain.xprv)) {
95
121
  throw new Error('expecting keychain param with xprv');
96
122
  }
97
123
  const hdNode = utxo_lib_1.bip32.fromBase58(keychain.xprv);
98
124
  tx.receivedTravelInfo.forEach((info) => {
99
- const key = hdNode.derivePath(sdk_core_1.sanitizeLegacyPath(info.toPubKeyPath));
100
- const secret = sdk_core_1.getSharedSecret(key, Buffer.from(info.fromPubKey, 'hex')).toString('hex');
125
+ const key = hdNode.derivePath((0, sdk_core_1.sanitizeLegacyPath)(info.toPubKeyPath));
126
+ const secret = (0, sdk_core_1.getSharedSecret)(key, Buffer.from(info.fromPubKey, 'hex')).toString('hex');
101
127
  try {
102
128
  const decrypted = this.bitgo.decrypt({
103
129
  input: info.encryptedTravelInfo,
@@ -118,10 +144,10 @@ TravelRule.prototype.prepareParams = function (params) {
118
144
  const txid = params.txid;
119
145
  const recipient = params.recipient;
120
146
  let travelInfo = params.travelInfo;
121
- if (!recipient || !_.isObject(recipient)) {
147
+ if (!recipient || !lodash_1.default.isObject(recipient)) {
122
148
  throw new Error('invalid or missing recipient');
123
149
  }
124
- if (!travelInfo || !_.isObject(travelInfo)) {
150
+ if (!travelInfo || !lodash_1.default.isObject(travelInfo)) {
125
151
  throw new Error('invalid or missing travelInfo');
126
152
  }
127
153
  if (!params.noValidate) {
@@ -132,12 +158,12 @@ TravelRule.prototype.prepareParams = function (params) {
132
158
  travelInfo.toEnterprise = recipient.enterprise;
133
159
  }
134
160
  // If a key was not provided, create a new random key
135
- let fromKey = params.fromKey && utxolib.ECPair.fromWIF(params.fromKey, sdk_core_1.getNetwork());
161
+ let fromKey = params.fromKey && utxolib.ECPair.fromWIF(params.fromKey, (0, sdk_core_1.getNetwork)());
136
162
  if (!fromKey) {
137
- fromKey = sdk_core_1.makeRandomKey();
163
+ fromKey = (0, sdk_core_1.makeRandomKey)();
138
164
  }
139
165
  // Compute the shared key for encryption
140
- const sharedSecret = sdk_core_1.getSharedSecret(fromKey, Buffer.from(recipient.pubKey, 'hex')).toString('hex');
166
+ const sharedSecret = (0, sdk_core_1.getSharedSecret)(fromKey, Buffer.from(recipient.pubKey, 'hex')).toString('hex');
141
167
  // JSON-ify and encrypt the payload
142
168
  const travelInfoJSON = JSON.stringify(travelInfo);
143
169
  const encryptedTravelInfo = this.bitgo.encrypt({
@@ -164,10 +190,10 @@ TravelRule.prototype.send = function (params, callback) {
164
190
  params = params || {};
165
191
  params.txid = params.txid || params.hash;
166
192
  sdk_core_1.common.validateParams(params, ['txid', 'toPubKey', 'encryptedTravelInfo'], ['fromPubKey', 'fromPrivateInfo'], callback);
167
- if (!_.isNumber(params.outputIndex)) {
193
+ if (!lodash_1.default.isNumber(params.outputIndex)) {
168
194
  throw new Error('invalid outputIndex');
169
195
  }
170
- return Bluebird.resolve(this.bitgo
196
+ return bluebird_1.default.resolve(this.bitgo
171
197
  .post(this.url(params.txid + '/' + params.outputIndex))
172
198
  .send(params)
173
199
  .result()).nodeify(callback);
@@ -198,11 +224,11 @@ TravelRule.prototype.sendMany = function (params, callback) {
198
224
  params.txid = params.txid || params.hash;
199
225
  sdk_core_1.common.validateParams(params, ['txid'], callback);
200
226
  const travelInfos = params.travelInfos;
201
- if (!_.isArray(travelInfos)) {
227
+ if (!lodash_1.default.isArray(travelInfos)) {
202
228
  throw new Error('expected parameter travelInfos to be array');
203
229
  }
204
230
  const self = this;
205
- const travelInfoMap = _(travelInfos)
231
+ const travelInfoMap = (0, lodash_1.default)(travelInfos)
206
232
  .keyBy('outputIndex')
207
233
  .mapValues(function (travelInfo) {
208
234
  return self.validateTravelInfo(travelInfo);
@@ -212,7 +238,7 @@ TravelRule.prototype.sendMany = function (params, callback) {
212
238
  // Build up data to post
213
239
  const sendParamsList = [];
214
240
  // don't regenerate a new random key for each recipient
215
- const fromKey = params.fromKey || sdk_core_1.makeRandomKey().toWIF();
241
+ const fromKey = params.fromKey || (0, sdk_core_1.makeRandomKey)().toWIF();
216
242
  recipients.forEach(function (recipient) {
217
243
  const outputIndex = recipient.outputIndex;
218
244
  const info = travelInfoMap[outputIndex];
@@ -254,4 +280,4 @@ TravelRule.prototype.sendMany = function (params, callback) {
254
280
  });
255
281
  };
256
282
  module.exports = TravelRule;
257
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"travelRule.js","sourceRoot":"","sources":["../../../src/v1/travelRule.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @hidden\n */\n\n/**\n */\n//\n// TravelRule Object\n// BitGo accessor for a specific enterprise\n//\n// Copyright 2014, BitGo, Inc.  All Rights Reserved.\n//\nimport { common, getNetwork, getSharedSecret, makeRandomKey, sanitizeLegacyPath } from '@bitgo-beta/sdk-core';\nimport { bip32, BIP32Interface } from '@bitgo-beta/utxo-lib';\nimport * as utxolib from '@bitgo-beta/utxo-lib';\nimport * as Bluebird from 'bluebird';\nimport * as _ from 'lodash';\n\ninterface DecryptReceivedTravelRuleOptions {\n  tx?: {\n    receivedTravelInfo?: {\n      toPubKeyPath: string;\n      fromPubKey: string;\n      encryptedTravelInfo: string;\n      travelInfo: string;\n      transactionId: string;\n      outputIndex: number;\n    }[];\n  };\n  keychain?: {\n    xprv?: string;\n  };\n  hdnode?: BIP32Interface;\n}\n\ninterface Recipient {\n  enterprise: string;\n  pubKey: string;\n  outputIndex: string;\n}\n\n//\n// Constructor\n//\nconst TravelRule = function (bitgo) {\n  // @ts-expect-error - no implicit this\n  this.bitgo = bitgo;\n};\n\nTravelRule.prototype.url = function (extra) {\n  extra = extra || '';\n  return this.bitgo.url('/travel/' + extra);\n};\n\n/**\n * Get available travel-rule info recipients for a transaction\n * @param params\n *  txid: transaction id\n * @param callback\n * @returns {*}\n */\nTravelRule.prototype.getRecipients = function (params, callback) {\n  params = params || {};\n  params.txid = params.txid || params.hash;\n  common.validateParams(params, ['txid'], [], callback);\n\n  const url = this.url(params.txid + '/recipients');\n  return Bluebird.resolve(this.bitgo.get(url).result('recipients')).nodeify(callback);\n};\n\nTravelRule.prototype.validateTravelInfo = function (info) {\n  const fields = {\n    amount: { type: 'number' },\n    toAddress: { type: 'string' },\n    toEnterprise: { type: 'string' },\n    fromUserName: { type: 'string' },\n    fromUserAccount: { type: 'string' },\n    fromUserAddress: { type: 'string' },\n    toUserName: { type: 'string' },\n    toUserAccount: { type: 'string' },\n    toUserAddress: { type: 'string' },\n    extra: { type: 'object' },\n  };\n\n  _.forEach(fields, function (field: any, fieldName) {\n    // No required fields yet -- should there be?\n    if (field.required) {\n      if (info[fieldName] === undefined) {\n        throw new Error('missing required field ' + fieldName + ' in travel info');\n      }\n    }\n    if (info[fieldName] && typeof info[fieldName] !== field.type) {\n      throw new Error('incorrect type for field ' + fieldName + ' in travel info, expected ' + field.type);\n    }\n  });\n\n  // Strip out any other fields we don't know about\n  const result = _.pick(info, _.keys(fields));\n  if (_.isEmpty(result)) {\n    throw new Error('empty travel data');\n  }\n  return result;\n};\n\n/**\n * Takes a transaction object as returned by getTransaction or listTransactions, along\n * with a keychain (or hdnode object), and attempts to decrypt any encrypted travel\n * info included in the transaction's receivedTravelInfo field.\n * Parameters:\n *   tx: a transaction object\n *   keychain: keychain object (with xprv)\n * Returns:\n *   the tx object, augmented with decrypted travelInfo fields\n */\nTravelRule.prototype.decryptReceivedTravelInfo = function (params: DecryptReceivedTravelRuleOptions = {}) {\n  const tx = params.tx;\n  if (!_.isObject(tx)) {\n    throw new Error('expecting tx param to be object');\n  }\n\n  if (!tx.receivedTravelInfo || !tx.receivedTravelInfo.length) {\n    return tx;\n  }\n\n  const keychain = params.keychain;\n  if (!_.isObject(keychain) || !_.isString(keychain.xprv)) {\n    throw new Error('expecting keychain param with xprv');\n  }\n  const hdNode = bip32.fromBase58(keychain.xprv);\n\n  tx.receivedTravelInfo.forEach((info) => {\n    const key = hdNode.derivePath(sanitizeLegacyPath(info.toPubKeyPath));\n    const secret = getSharedSecret(key, Buffer.from(info.fromPubKey, 'hex')).toString('hex');\n    try {\n      const decrypted = this.bitgo.decrypt({\n        input: info.encryptedTravelInfo,\n        password: secret,\n      });\n      info.travelInfo = JSON.parse(decrypted);\n    } catch (err) {\n      console.error('failed to decrypt or parse travel info for ', info.transactionId + ':' + info.outputIndex);\n    }\n  });\n\n  return tx;\n};\n\nTravelRule.prototype.prepareParams = function (params) {\n  params = params || {};\n  params.txid = params.txid || params.hash;\n  common.validateParams(params, ['txid'], ['fromPrivateInfo']);\n  const txid = params.txid;\n  const recipient: Recipient | undefined = params.recipient;\n  let travelInfo = params.travelInfo;\n  if (!recipient || !_.isObject(recipient)) {\n    throw new Error('invalid or missing recipient');\n  }\n  if (!travelInfo || !_.isObject(travelInfo)) {\n    throw new Error('invalid or missing travelInfo');\n  }\n  if (!params.noValidate) {\n    travelInfo = this.validateTravelInfo(travelInfo);\n  }\n\n  // Fill in toEnterprise if not already filled\n  if (!travelInfo.toEnterprise && recipient.enterprise) {\n    travelInfo.toEnterprise = recipient.enterprise;\n  }\n\n  // If a key was not provided, create a new random key\n  let fromKey = params.fromKey && utxolib.ECPair.fromWIF(params.fromKey, getNetwork() as utxolib.BitcoinJSNetwork);\n  if (!fromKey) {\n    fromKey = makeRandomKey();\n  }\n\n  // Compute the shared key for encryption\n  const sharedSecret = getSharedSecret(fromKey, Buffer.from(recipient.pubKey, 'hex')).toString('hex');\n\n  // JSON-ify and encrypt the payload\n  const travelInfoJSON = JSON.stringify(travelInfo);\n  const encryptedTravelInfo = this.bitgo.encrypt({\n    input: travelInfoJSON,\n    password: sharedSecret,\n  });\n\n  const result = {\n    txid: txid,\n    outputIndex: recipient.outputIndex,\n    toPubKey: recipient.pubKey,\n    fromPubKey: fromKey.publicKey.toString('hex'),\n    encryptedTravelInfo: encryptedTravelInfo,\n    fromPrivateInfo: undefined,\n  };\n\n  if (params.fromPrivateInfo) {\n    result.fromPrivateInfo = params.fromPrivateInfo;\n  }\n\n  return result;\n};\n\n/**\n * Send travel data to the server for a transaction\n */\nTravelRule.prototype.send = function (params, callback) {\n  params = params || {};\n  params.txid = params.txid || params.hash;\n  common.validateParams(\n    params,\n    ['txid', 'toPubKey', 'encryptedTravelInfo'],\n    ['fromPubKey', 'fromPrivateInfo'],\n    callback\n  );\n\n  if (!_.isNumber(params.outputIndex)) {\n    throw new Error('invalid outputIndex');\n  }\n\n  return Bluebird.resolve(\n    this.bitgo\n      .post(this.url(params.txid + '/' + params.outputIndex))\n      .send(params)\n      .result()\n  ).nodeify(callback);\n};\n\n/**\n * Send multiple travel rule infos for the outputs of a single transaction.\n * Parameters:\n *   - txid (or hash): txid of the transaction (must be a sender of the tx)\n *   - travelInfos: array of travelInfo objects which look like the following:\n *     {\n *       outputIndex: number,     // tx output index\n *       fromUserName: string,    // name of the sending user\n *       fromUserAccount: string, // account id of the sending user\n *       fromUserAddress: string, // mailing address of the sending user\n *       toUserName: string,      // name of the receiving user\n *       toUserAccount: string,   // account id of the receiving user\n *       toUserAddress: string    // mailing address of the receiving user\n *     }\n *     All fields aside from outputIndex are optional, but at least one must\n *     be defined.\n *\n *  It is not necessary to provide travelInfo for all output indices.\n *  End-to-end encryption of the travel info is handled automatically by this method.\n *\n */\nTravelRule.prototype.sendMany = function (params, callback) {\n  params = params || {};\n  params.txid = params.txid || params.hash;\n  common.validateParams(params, ['txid'], callback);\n\n  const travelInfos = params.travelInfos;\n  if (!_.isArray(travelInfos)) {\n    throw new Error('expected parameter travelInfos to be array');\n  }\n\n  const self = this;\n  const travelInfoMap = _(travelInfos)\n    .keyBy('outputIndex')\n    .mapValues(function (travelInfo) {\n      return self.validateTravelInfo(travelInfo);\n    })\n    .value();\n\n  return self.getRecipients({ txid: params.txid }).then(function (recipients) {\n    // Build up data to post\n    const sendParamsList: any[] = [];\n    // don't regenerate a new random key for each recipient\n    const fromKey = params.fromKey || makeRandomKey().toWIF();\n\n    recipients.forEach(function (recipient) {\n      const outputIndex = recipient.outputIndex;\n      const info = travelInfoMap[outputIndex];\n      if (info) {\n        if (info.amount && info.amount !== recipient.amount) {\n          throw new Error('amount did not match for output index ' + outputIndex);\n        }\n        const sendParams = self.prepareParams({\n          txid: params.txid,\n          recipient: recipient,\n          travelInfo: info,\n          fromKey: fromKey,\n          noValidate: true, // don't re-validate\n        });\n        sendParamsList.push(sendParams);\n      }\n    });\n\n    const result: {\n      matched: number;\n      results: {\n        result?: any;\n        error?: string;\n      }[];\n    } = {\n      matched: sendParamsList.length,\n      results: [],\n    };\n\n    const sendSerial = function () {\n      const sendParams = sendParamsList.shift();\n      if (!sendParams) {\n        return result;\n      }\n      return self\n        .send(sendParams)\n        .then(function (res) {\n          result.results.push({ result: res });\n          return sendSerial();\n        })\n        .catch(function (err) {\n          result.results.push({ error: err.toString() });\n          return sendSerial();\n        });\n    };\n\n    return sendSerial();\n  });\n};\n\nmodule.exports = TravelRule;\n"]}
283
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"travelRule.js","sourceRoot":"","sources":["../../../src/v1/travelRule.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @hidden\n */\n\n/**\n */\n//\n// TravelRule Object\n// BitGo accessor for a specific enterprise\n//\n// Copyright 2014, BitGo, Inc.  All Rights Reserved.\n//\nimport { common, getNetwork, getSharedSecret, makeRandomKey, sanitizeLegacyPath } from '@bitgo-beta/sdk-core';\nimport { bip32, BIP32Interface } from '@bitgo-beta/utxo-lib';\nimport * as utxolib from '@bitgo-beta/utxo-lib';\nimport Bluebird from 'bluebird';\nimport _ from 'lodash';\n\ninterface DecryptReceivedTravelRuleOptions {\n  tx?: {\n    receivedTravelInfo?: {\n      toPubKeyPath: string;\n      fromPubKey: string;\n      encryptedTravelInfo: string;\n      travelInfo: string;\n      transactionId: string;\n      outputIndex: number;\n    }[];\n  };\n  keychain?: {\n    xprv?: string;\n  };\n  hdnode?: BIP32Interface;\n}\n\ninterface Recipient {\n  enterprise: string;\n  pubKey: string;\n  outputIndex: string;\n}\n\n//\n// Constructor\n//\nconst TravelRule = function (bitgo) {\n  // @ts-expect-error - no implicit this\n  this.bitgo = bitgo;\n};\n\nTravelRule.prototype.url = function (extra) {\n  extra = extra || '';\n  return this.bitgo.url('/travel/' + extra);\n};\n\n/**\n * Get available travel-rule info recipients for a transaction\n * @param params\n *  txid: transaction id\n * @param callback\n * @returns {*}\n */\nTravelRule.prototype.getRecipients = function (params, callback) {\n  params = params || {};\n  params.txid = params.txid || params.hash;\n  common.validateParams(params, ['txid'], [], callback);\n\n  const url = this.url(params.txid + '/recipients');\n  return Bluebird.resolve(this.bitgo.get(url).result('recipients')).nodeify(callback);\n};\n\nTravelRule.prototype.validateTravelInfo = function (info) {\n  const fields = {\n    amount: { type: 'number' },\n    toAddress: { type: 'string' },\n    toEnterprise: { type: 'string' },\n    fromUserName: { type: 'string' },\n    fromUserAccount: { type: 'string' },\n    fromUserAddress: { type: 'string' },\n    toUserName: { type: 'string' },\n    toUserAccount: { type: 'string' },\n    toUserAddress: { type: 'string' },\n    extra: { type: 'object' },\n  };\n\n  _.forEach(fields, function (field: any, fieldName) {\n    // No required fields yet -- should there be?\n    if (field.required) {\n      if (info[fieldName] === undefined) {\n        throw new Error('missing required field ' + fieldName + ' in travel info');\n      }\n    }\n    if (info[fieldName] && typeof info[fieldName] !== field.type) {\n      throw new Error('incorrect type for field ' + fieldName + ' in travel info, expected ' + field.type);\n    }\n  });\n\n  // Strip out any other fields we don't know about\n  const result = _.pick(info, _.keys(fields));\n  if (_.isEmpty(result)) {\n    throw new Error('empty travel data');\n  }\n  return result;\n};\n\n/**\n * Takes a transaction object as returned by getTransaction or listTransactions, along\n * with a keychain (or hdnode object), and attempts to decrypt any encrypted travel\n * info included in the transaction's receivedTravelInfo field.\n * Parameters:\n *   tx: a transaction object\n *   keychain: keychain object (with xprv)\n * Returns:\n *   the tx object, augmented with decrypted travelInfo fields\n */\nTravelRule.prototype.decryptReceivedTravelInfo = function (params: DecryptReceivedTravelRuleOptions = {}) {\n  const tx = params.tx;\n  if (!_.isObject(tx)) {\n    throw new Error('expecting tx param to be object');\n  }\n\n  if (!tx.receivedTravelInfo || !tx.receivedTravelInfo.length) {\n    return tx;\n  }\n\n  const keychain = params.keychain;\n  if (!_.isObject(keychain) || !_.isString(keychain.xprv)) {\n    throw new Error('expecting keychain param with xprv');\n  }\n  const hdNode = bip32.fromBase58(keychain.xprv);\n\n  tx.receivedTravelInfo.forEach((info) => {\n    const key = hdNode.derivePath(sanitizeLegacyPath(info.toPubKeyPath));\n    const secret = getSharedSecret(key, Buffer.from(info.fromPubKey, 'hex')).toString('hex');\n    try {\n      const decrypted = this.bitgo.decrypt({\n        input: info.encryptedTravelInfo,\n        password: secret,\n      });\n      info.travelInfo = JSON.parse(decrypted);\n    } catch (err) {\n      console.error('failed to decrypt or parse travel info for ', info.transactionId + ':' + info.outputIndex);\n    }\n  });\n\n  return tx;\n};\n\nTravelRule.prototype.prepareParams = function (params) {\n  params = params || {};\n  params.txid = params.txid || params.hash;\n  common.validateParams(params, ['txid'], ['fromPrivateInfo']);\n  const txid = params.txid;\n  const recipient: Recipient | undefined = params.recipient;\n  let travelInfo = params.travelInfo;\n  if (!recipient || !_.isObject(recipient)) {\n    throw new Error('invalid or missing recipient');\n  }\n  if (!travelInfo || !_.isObject(travelInfo)) {\n    throw new Error('invalid or missing travelInfo');\n  }\n  if (!params.noValidate) {\n    travelInfo = this.validateTravelInfo(travelInfo);\n  }\n\n  // Fill in toEnterprise if not already filled\n  if (!travelInfo.toEnterprise && recipient.enterprise) {\n    travelInfo.toEnterprise = recipient.enterprise;\n  }\n\n  // If a key was not provided, create a new random key\n  let fromKey = params.fromKey && utxolib.ECPair.fromWIF(params.fromKey, getNetwork() as utxolib.BitcoinJSNetwork);\n  if (!fromKey) {\n    fromKey = makeRandomKey();\n  }\n\n  // Compute the shared key for encryption\n  const sharedSecret = getSharedSecret(fromKey, Buffer.from(recipient.pubKey, 'hex')).toString('hex');\n\n  // JSON-ify and encrypt the payload\n  const travelInfoJSON = JSON.stringify(travelInfo);\n  const encryptedTravelInfo = this.bitgo.encrypt({\n    input: travelInfoJSON,\n    password: sharedSecret,\n  });\n\n  const result = {\n    txid: txid,\n    outputIndex: recipient.outputIndex,\n    toPubKey: recipient.pubKey,\n    fromPubKey: fromKey.publicKey.toString('hex'),\n    encryptedTravelInfo: encryptedTravelInfo,\n    fromPrivateInfo: undefined,\n  };\n\n  if (params.fromPrivateInfo) {\n    result.fromPrivateInfo = params.fromPrivateInfo;\n  }\n\n  return result;\n};\n\n/**\n * Send travel data to the server for a transaction\n */\nTravelRule.prototype.send = function (params, callback) {\n  params = params || {};\n  params.txid = params.txid || params.hash;\n  common.validateParams(\n    params,\n    ['txid', 'toPubKey', 'encryptedTravelInfo'],\n    ['fromPubKey', 'fromPrivateInfo'],\n    callback\n  );\n\n  if (!_.isNumber(params.outputIndex)) {\n    throw new Error('invalid outputIndex');\n  }\n\n  return Bluebird.resolve(\n    this.bitgo\n      .post(this.url(params.txid + '/' + params.outputIndex))\n      .send(params)\n      .result()\n  ).nodeify(callback);\n};\n\n/**\n * Send multiple travel rule infos for the outputs of a single transaction.\n * Parameters:\n *   - txid (or hash): txid of the transaction (must be a sender of the tx)\n *   - travelInfos: array of travelInfo objects which look like the following:\n *     {\n *       outputIndex: number,     // tx output index\n *       fromUserName: string,    // name of the sending user\n *       fromUserAccount: string, // account id of the sending user\n *       fromUserAddress: string, // mailing address of the sending user\n *       toUserName: string,      // name of the receiving user\n *       toUserAccount: string,   // account id of the receiving user\n *       toUserAddress: string    // mailing address of the receiving user\n *     }\n *     All fields aside from outputIndex are optional, but at least one must\n *     be defined.\n *\n *  It is not necessary to provide travelInfo for all output indices.\n *  End-to-end encryption of the travel info is handled automatically by this method.\n *\n */\nTravelRule.prototype.sendMany = function (params, callback) {\n  params = params || {};\n  params.txid = params.txid || params.hash;\n  common.validateParams(params, ['txid'], callback);\n\n  const travelInfos = params.travelInfos;\n  if (!_.isArray(travelInfos)) {\n    throw new Error('expected parameter travelInfos to be array');\n  }\n\n  const self = this;\n  const travelInfoMap = _(travelInfos)\n    .keyBy('outputIndex')\n    .mapValues(function (travelInfo) {\n      return self.validateTravelInfo(travelInfo);\n    })\n    .value();\n\n  return self.getRecipients({ txid: params.txid }).then(function (recipients) {\n    // Build up data to post\n    const sendParamsList: any[] = [];\n    // don't regenerate a new random key for each recipient\n    const fromKey = params.fromKey || makeRandomKey().toWIF();\n\n    recipients.forEach(function (recipient) {\n      const outputIndex = recipient.outputIndex;\n      const info = travelInfoMap[outputIndex];\n      if (info) {\n        if (info.amount && info.amount !== recipient.amount) {\n          throw new Error('amount did not match for output index ' + outputIndex);\n        }\n        const sendParams = self.prepareParams({\n          txid: params.txid,\n          recipient: recipient,\n          travelInfo: info,\n          fromKey: fromKey,\n          noValidate: true, // don't re-validate\n        });\n        sendParamsList.push(sendParams);\n      }\n    });\n\n    const result: {\n      matched: number;\n      results: {\n        result?: any;\n        error?: string;\n      }[];\n    } = {\n      matched: sendParamsList.length,\n      results: [],\n    };\n\n    const sendSerial = function () {\n      const sendParams = sendParamsList.shift();\n      if (!sendParams) {\n        return result;\n      }\n      return self\n        .send(sendParams)\n        .then(function (res) {\n          result.results.push({ result: res });\n          return sendSerial();\n        })\n        .catch(function (err) {\n          result.results.push({ error: err.toString() });\n          return sendSerial();\n        });\n    };\n\n    return sendSerial();\n  });\n};\n\nmodule.exports = TravelRule;\n"]}
@@ -0,0 +1,6 @@
1
+ import { Network } from '@bitgo-beta/utxo-lib';
2
+ /**
3
+ * Verify a Bitcoin address is a valid address
4
+ */
5
+ export declare function verifyAddress(address: any, network: Network): boolean;
6
+ //# sourceMappingURL=verifyAddress.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"verifyAddress.d.ts","sourceRoot":"","sources":["../../../src/v1/verifyAddress.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAE/C;;GAEG;AACH,wBAAgB,aAAa,CAAC,OAAO,KAAA,EAAE,OAAO,EAAE,OAAO,GAAG,OAAO,CAOhE"}
@@ -0,0 +1,41 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ exports.verifyAddress = void 0;
27
+ const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
28
+ /**
29
+ * Verify a Bitcoin address is a valid address
30
+ */
31
+ function verifyAddress(address, network) {
32
+ try {
33
+ const script = utxolib.addressFormat.toOutputScriptTryFormats(address, network, undefined);
34
+ return address === utxolib.address.fromOutputScript(script, network);
35
+ }
36
+ catch (e) {
37
+ return false;
38
+ }
39
+ }
40
+ exports.verifyAddress = verifyAddress;
41
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyaWZ5QWRkcmVzcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy92MS92ZXJpZnlBZGRyZXNzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsOERBQWdEO0FBR2hEOztHQUVHO0FBQ0gsU0FBZ0IsYUFBYSxDQUFDLE9BQU8sRUFBRSxPQUFnQjtJQUNyRCxJQUFJO1FBQ0YsTUFBTSxNQUFNLEdBQUcsT0FBTyxDQUFDLGFBQWEsQ0FBQyx3QkFBd0IsQ0FBQyxPQUFPLEVBQUUsT0FBTyxFQUFFLFNBQVMsQ0FBQyxDQUFDO1FBQzNGLE9BQU8sT0FBTyxLQUFLLE9BQU8sQ0FBQyxPQUFPLENBQUMsZ0JBQWdCLENBQUMsTUFBTSxFQUFFLE9BQU8sQ0FBQyxDQUFDO0tBQ3RFO0lBQUMsT0FBTyxDQUFDLEVBQUU7UUFDVixPQUFPLEtBQUssQ0FBQztLQUNkO0FBQ0gsQ0FBQztBQVBELHNDQU9DIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgdXR4b2xpYiBmcm9tICdAYml0Z28tYmV0YS91dHhvLWxpYic7XG5pbXBvcnQgeyBOZXR3b3JrIH0gZnJvbSAnQGJpdGdvLWJldGEvdXR4by1saWInO1xuXG4vKipcbiAqIFZlcmlmeSBhIEJpdGNvaW4gYWRkcmVzcyBpcyBhIHZhbGlkIGFkZHJlc3NcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHZlcmlmeUFkZHJlc3MoYWRkcmVzcywgbmV0d29yazogTmV0d29yayk6IGJvb2xlYW4ge1xuICB0cnkge1xuICAgIGNvbnN0IHNjcmlwdCA9IHV0eG9saWIuYWRkcmVzc0Zvcm1hdC50b091dHB1dFNjcmlwdFRyeUZvcm1hdHMoYWRkcmVzcywgbmV0d29yaywgdW5kZWZpbmVkKTtcbiAgICByZXR1cm4gYWRkcmVzcyA9PT0gdXR4b2xpYi5hZGRyZXNzLmZyb21PdXRwdXRTY3JpcHQoc2NyaXB0LCBuZXR3b3JrKTtcbiAgfSBjYXRjaCAoZSkge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxufVxuIl19
@@ -1 +1 @@
1
- {"version":3,"file":"wallet.d.ts","sourceRoot":"","sources":["../../../src/v1/wallet.ts"],"names":[],"mappings":"AAAA;;GAEG;AA4BH,QAAA,MAAM,MAAM,mCAYX,CAAC;AA00EF,SAAS,MAAM,CAAC"}
1
+ {"version":3,"file":"wallet.d.ts","sourceRoot":"","sources":["../../../src/v1/wallet.ts"],"names":[],"mappings":"AAAA;;GAEG;AAsCH,QAAA,MAAM,MAAM,mCAYX,CAAC;AA48EF,SAAS,MAAM,CAAC"}