Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@bitgo/sdk-core

Package Overview
Dependencies
Maintainers
7
Versions
193
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@bitgo/sdk-core - npm Package Compare versions

Comparing version 1.1.0-rc.19 to 1.1.0-rc.20

12

CHANGELOG.md

@@ -6,2 +6,14 @@ # Change Log

# [1.1.0-rc.20](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-core@1.1.0-rc.19...@bitgo/sdk-core@1.1.0-rc.20) (2022-06-30)
### Bug Fixes
* **account-lib:** fix ecdsa tests timeout issues ([12c86b2](https://github.com/BitGo/BitGoJS/commit/12c86b2dcbc24331ad47668829ec9f8eb131861f))
* **sdk-core:** fix sol send token sdk ([d5c697b](https://github.com/BitGo/BitGoJS/commit/d5c697b4f0b2e6a95eaf7a1f6e70db063f2877d2))
# [1.1.0-rc.19](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-core@1.1.0-rc.18...@bitgo/sdk-core@1.1.0-rc.19) (2022-06-30)

@@ -8,0 +20,0 @@

4

dist/src/account-lib/mpc/util.d.ts
/// <reference types="node" />
import * as paillierBigint from 'paillier-bigint';
import { PublicKey } from 'paillier-bigint';
export declare function bigIntFromBufferLE(buf: Buffer): bigint;

@@ -14,3 +14,3 @@ export declare function bigIntToBufferLE(n: bigint, bytes?: number): Buffer;

*/
export declare function getPaillierPublicKey(n: bigint): paillierBigint.PublicKey;
export declare function getPaillierPublicKey(n: bigint): PublicKey;
//# sourceMappingURL=util.d.ts.map
"use strict";
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
}) : (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 (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
__setModuleDefault(result, mod);
return result;
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.getPaillierPublicKey = exports.clamp = exports.bigIntToBufferBE = exports.bigIntFromU8ABE = exports.bigIntFromBufferBE = exports.bigIntToBufferLE = exports.bigIntFromBufferLE = void 0;
const paillierBigint = __importStar(require("paillier-bigint"));
const paillier_bigint_1 = require("paillier-bigint");
function bigIntFromBufferLE(buf) {

@@ -68,5 +49,5 @@ return BigInt('0x' + Buffer.from(buf).reverse().toString('hex'));

function getPaillierPublicKey(n) {
return new paillierBigint.PublicKey(n, n + BigInt(1));
return new paillier_bigint_1.PublicKey(n, n + BigInt(1));
}
exports.getPaillierPublicKey = getPaillierPublicKey;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9hY2NvdW50LWxpYi9tcGMvdXRpbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsZ0VBQWtEO0FBQ2xELFNBQWdCLGtCQUFrQixDQUFDLEdBQVc7SUFDNUMsT0FBTyxNQUFNLENBQUMsSUFBSSxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsT0FBTyxFQUFFLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7QUFDbkUsQ0FBQztBQUZELGdEQUVDO0FBRUQsU0FBZ0IsZ0JBQWdCLENBQUMsQ0FBUyxFQUFFLEtBQWM7SUFDeEQsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxFQUFFLENBQUMsQ0FBQztJQUN2QixDQUFDLEdBQUcsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDbkMsTUFBTSxHQUFHLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLEVBQUUsS0FBSyxDQUFDLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDNUMsSUFBSSxLQUFLLElBQUksR0FBRyxDQUFDLE1BQU0sR0FBRyxLQUFLLEVBQUU7UUFDL0IsT0FBTyxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUMsR0FBRyxFQUFFLE1BQU0sQ0FBQyxLQUFLLENBQUMsS0FBSyxHQUFHLEdBQUcsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUM7S0FDL0Q7SUFDRCxPQUFPLEdBQUcsQ0FBQztBQUNiLENBQUM7QUFSRCw0Q0FRQztBQUVELFNBQWdCLGtCQUFrQixDQUFDLEdBQVc7SUFDNUMsT0FBTyxNQUFNLENBQUMsSUFBSSxHQUFHLEdBQUcsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQztBQUM1QyxDQUFDO0FBRkQsZ0RBRUM7QUFFRCxTQUFnQixlQUFlLENBQUMsR0FBZTtJQUM3QyxPQUFPLGtCQUFrQixDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztBQUM5QyxDQUFDO0FBRkQsMENBRUM7QUFFRCxTQUFnQixnQkFBZ0IsQ0FBQyxDQUFTLEVBQUUsS0FBYztJQUN4RCxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsUUFBUSxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQ3ZCLENBQUMsR0FBRyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUNuQyxNQUFNLEdBQUcsR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsRUFBRSxLQUFLLENBQUMsQ0FBQztJQUNsQyxJQUFJLEtBQUssSUFBSSxHQUFHLENBQUMsTUFBTSxHQUFHLEtBQUssRUFBRTtRQUMvQixPQUFPLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLEtBQUssR0FBRyxHQUFHLENBQUMsTUFBTSxDQUFDLEVBQUUsR0FBRyxDQUFDLENBQUMsQ0FBQztLQUMvRDtJQUNELE9BQU8sR0FBRyxDQUFDO0FBQ2IsQ0FBQztBQVJELDRDQVFDO0FBRUQsU0FBZ0IsS0FBSyxDQUFDLENBQVM7SUFDN0IsQ0FBQyxJQUFJLE1BQU0sQ0FBQyxvRUFBb0UsQ0FBQyxDQUFDO0lBQ2xGLENBQUMsSUFBSSxNQUFNLENBQUMsb0VBQW9FLENBQUMsQ0FBQztJQUNsRixPQUFPLENBQUMsQ0FBQztBQUNYLENBQUM7QUFKRCxzQkFJQztBQUVEOzs7O0dBSUc7QUFDSCxTQUFnQixvQkFBb0IsQ0FBQyxDQUFTO0lBQzVDLE9BQU8sSUFBSSxjQUFjLENBQUMsU0FBUyxDQUFDLENBQUMsRUFBRSxDQUFDLEdBQUcsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7QUFDeEQsQ0FBQztBQUZELG9EQUVDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgcGFpbGxpZXJCaWdpbnQgZnJvbSAncGFpbGxpZXItYmlnaW50JztcbmV4cG9ydCBmdW5jdGlvbiBiaWdJbnRGcm9tQnVmZmVyTEUoYnVmOiBCdWZmZXIpOiBiaWdpbnQge1xuICByZXR1cm4gQmlnSW50KCcweCcgKyBCdWZmZXIuZnJvbShidWYpLnJldmVyc2UoKS50b1N0cmluZygnaGV4JykpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gYmlnSW50VG9CdWZmZXJMRShuOiBiaWdpbnQsIGJ5dGVzPzogbnVtYmVyKTogQnVmZmVyIHtcbiAgbGV0IHYgPSBuLnRvU3RyaW5nKDE2KTtcbiAgdiA9ICcwJy5zbGljZSgwLCB2Lmxlbmd0aCAlIDIpICsgdjtcbiAgY29uc3QgYnVmID0gQnVmZmVyLmZyb20odiwgJ2hleCcpLnJldmVyc2UoKTtcbiAgaWYgKGJ5dGVzICYmIGJ1Zi5sZW5ndGggPCBieXRlcykge1xuICAgIHJldHVybiBCdWZmZXIuY29uY2F0KFtidWYsIEJ1ZmZlci5hbGxvYyhieXRlcyAtIGJ1Zi5sZW5ndGgpXSk7XG4gIH1cbiAgcmV0dXJuIGJ1Zjtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGJpZ0ludEZyb21CdWZmZXJCRShidWY6IEJ1ZmZlcik6IGJpZ2ludCB7XG4gIHJldHVybiBCaWdJbnQoJzB4JyArIGJ1Zi50b1N0cmluZygnaGV4JykpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gYmlnSW50RnJvbVU4QUJFKGJ1ZjogVWludDhBcnJheSk6IGJpZ2ludCB7XG4gIHJldHVybiBiaWdJbnRGcm9tQnVmZmVyQkUoQnVmZmVyLmZyb20oYnVmKSk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBiaWdJbnRUb0J1ZmZlckJFKG46IGJpZ2ludCwgYnl0ZXM/OiBudW1iZXIpOiBCdWZmZXIge1xuICBsZXQgdiA9IG4udG9TdHJpbmcoMTYpO1xuICB2ID0gJzAnLnNsaWNlKDAsIHYubGVuZ3RoICUgMikgKyB2O1xuICBjb25zdCBidWYgPSBCdWZmZXIuZnJvbSh2LCAnaGV4Jyk7XG4gIGlmIChieXRlcyAmJiBidWYubGVuZ3RoIDwgYnl0ZXMpIHtcbiAgICByZXR1cm4gQnVmZmVyLmNvbmNhdChbQnVmZmVyLmFsbG9jKGJ5dGVzIC0gYnVmLmxlbmd0aCksIGJ1Zl0pO1xuICB9XG4gIHJldHVybiBidWY7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBjbGFtcCh1OiBiaWdpbnQpOiBiaWdpbnQge1xuICB1ICY9IEJpZ0ludCgnMHg3ZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmY4Jyk7XG4gIHUgfD0gQmlnSW50KCcweDQwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAnKTtcbiAgcmV0dXJuIHU7XG59XG5cbi8qKlxuICogRnVuY3Rpb24gZ2V0IHBhbGxpZXIgcHVibGljIGtleSBzaW1wbGUgdmFyaWVudFxuICogQHBhcmFtIHtiaWdpbnR9IG5cbiAqIEByZXR1cm5zIHtiaWdpbnR9XG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBnZXRQYWlsbGllclB1YmxpY0tleShuOiBiaWdpbnQpOiBwYWlsbGllckJpZ2ludC5QdWJsaWNLZXkge1xuICByZXR1cm4gbmV3IHBhaWxsaWVyQmlnaW50LlB1YmxpY0tleShuLCBuICsgQmlnSW50KDEpKTtcbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9hY2NvdW50LWxpYi9tcGMvdXRpbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxxREFBNEM7QUFDNUMsU0FBZ0Isa0JBQWtCLENBQUMsR0FBVztJQUM1QyxPQUFPLE1BQU0sQ0FBQyxJQUFJLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQztBQUNuRSxDQUFDO0FBRkQsZ0RBRUM7QUFFRCxTQUFnQixnQkFBZ0IsQ0FBQyxDQUFTLEVBQUUsS0FBYztJQUN4RCxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsUUFBUSxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQ3ZCLENBQUMsR0FBRyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUNuQyxNQUFNLEdBQUcsR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsRUFBRSxLQUFLLENBQUMsQ0FBQyxPQUFPLEVBQUUsQ0FBQztJQUM1QyxJQUFJLEtBQUssSUFBSSxHQUFHLENBQUMsTUFBTSxHQUFHLEtBQUssRUFBRTtRQUMvQixPQUFPLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQyxHQUFHLEVBQUUsTUFBTSxDQUFDLEtBQUssQ0FBQyxLQUFLLEdBQUcsR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQztLQUMvRDtJQUNELE9BQU8sR0FBRyxDQUFDO0FBQ2IsQ0FBQztBQVJELDRDQVFDO0FBRUQsU0FBZ0Isa0JBQWtCLENBQUMsR0FBVztJQUM1QyxPQUFPLE1BQU0sQ0FBQyxJQUFJLEdBQUcsR0FBRyxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO0FBQzVDLENBQUM7QUFGRCxnREFFQztBQUVELFNBQWdCLGVBQWUsQ0FBQyxHQUFlO0lBQzdDLE9BQU8sa0JBQWtCLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDO0FBQzlDLENBQUM7QUFGRCwwQ0FFQztBQUVELFNBQWdCLGdCQUFnQixDQUFDLENBQVMsRUFBRSxLQUFjO0lBQ3hELElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUFDLENBQUM7SUFDdkIsQ0FBQyxHQUFHLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ25DLE1BQU0sR0FBRyxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQyxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQ2xDLElBQUksS0FBSyxJQUFJLEdBQUcsQ0FBQyxNQUFNLEdBQUcsS0FBSyxFQUFFO1FBQy9CLE9BQU8sTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsS0FBSyxHQUFHLEdBQUcsQ0FBQyxNQUFNLENBQUMsRUFBRSxHQUFHLENBQUMsQ0FBQyxDQUFDO0tBQy9EO0lBQ0QsT0FBTyxHQUFHLENBQUM7QUFDYixDQUFDO0FBUkQsNENBUUM7QUFFRCxTQUFnQixLQUFLLENBQUMsQ0FBUztJQUM3QixDQUFDLElBQUksTUFBTSxDQUFDLG9FQUFvRSxDQUFDLENBQUM7SUFDbEYsQ0FBQyxJQUFJLE1BQU0sQ0FBQyxvRUFBb0UsQ0FBQyxDQUFDO0lBQ2xGLE9BQU8sQ0FBQyxDQUFDO0FBQ1gsQ0FBQztBQUpELHNCQUlDO0FBRUQ7Ozs7R0FJRztBQUNILFNBQWdCLG9CQUFvQixDQUFDLENBQVM7SUFDNUMsT0FBTyxJQUFJLDJCQUFTLENBQUMsQ0FBQyxFQUFFLENBQUMsR0FBRyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUN6QyxDQUFDO0FBRkQsb0RBRUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQdWJsaWNLZXkgfSBmcm9tICdwYWlsbGllci1iaWdpbnQnO1xuZXhwb3J0IGZ1bmN0aW9uIGJpZ0ludEZyb21CdWZmZXJMRShidWY6IEJ1ZmZlcik6IGJpZ2ludCB7XG4gIHJldHVybiBCaWdJbnQoJzB4JyArIEJ1ZmZlci5mcm9tKGJ1ZikucmV2ZXJzZSgpLnRvU3RyaW5nKCdoZXgnKSk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBiaWdJbnRUb0J1ZmZlckxFKG46IGJpZ2ludCwgYnl0ZXM/OiBudW1iZXIpOiBCdWZmZXIge1xuICBsZXQgdiA9IG4udG9TdHJpbmcoMTYpO1xuICB2ID0gJzAnLnNsaWNlKDAsIHYubGVuZ3RoICUgMikgKyB2O1xuICBjb25zdCBidWYgPSBCdWZmZXIuZnJvbSh2LCAnaGV4JykucmV2ZXJzZSgpO1xuICBpZiAoYnl0ZXMgJiYgYnVmLmxlbmd0aCA8IGJ5dGVzKSB7XG4gICAgcmV0dXJuIEJ1ZmZlci5jb25jYXQoW2J1ZiwgQnVmZmVyLmFsbG9jKGJ5dGVzIC0gYnVmLmxlbmd0aCldKTtcbiAgfVxuICByZXR1cm4gYnVmO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gYmlnSW50RnJvbUJ1ZmZlckJFKGJ1ZjogQnVmZmVyKTogYmlnaW50IHtcbiAgcmV0dXJuIEJpZ0ludCgnMHgnICsgYnVmLnRvU3RyaW5nKCdoZXgnKSk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBiaWdJbnRGcm9tVThBQkUoYnVmOiBVaW50OEFycmF5KTogYmlnaW50IHtcbiAgcmV0dXJuIGJpZ0ludEZyb21CdWZmZXJCRShCdWZmZXIuZnJvbShidWYpKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGJpZ0ludFRvQnVmZmVyQkUobjogYmlnaW50LCBieXRlcz86IG51bWJlcik6IEJ1ZmZlciB7XG4gIGxldCB2ID0gbi50b1N0cmluZygxNik7XG4gIHYgPSAnMCcuc2xpY2UoMCwgdi5sZW5ndGggJSAyKSArIHY7XG4gIGNvbnN0IGJ1ZiA9IEJ1ZmZlci5mcm9tKHYsICdoZXgnKTtcbiAgaWYgKGJ5dGVzICYmIGJ1Zi5sZW5ndGggPCBieXRlcykge1xuICAgIHJldHVybiBCdWZmZXIuY29uY2F0KFtCdWZmZXIuYWxsb2MoYnl0ZXMgLSBidWYubGVuZ3RoKSwgYnVmXSk7XG4gIH1cbiAgcmV0dXJuIGJ1Zjtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNsYW1wKHU6IGJpZ2ludCk6IGJpZ2ludCB7XG4gIHUgJj0gQmlnSW50KCcweDdmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZmZjgnKTtcbiAgdSB8PSBCaWdJbnQoJzB4NDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMCcpO1xuICByZXR1cm4gdTtcbn1cblxuLyoqXG4gKiBGdW5jdGlvbiBnZXQgcGFsbGllciBwdWJsaWMga2V5IHNpbXBsZSB2YXJpZW50XG4gKiBAcGFyYW0ge2JpZ2ludH0gblxuICogQHJldHVybnMge2JpZ2ludH1cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGdldFBhaWxsaWVyUHVibGljS2V5KG46IGJpZ2ludCk6IFB1YmxpY0tleSB7XG4gIHJldHVybiBuZXcgUHVibGljS2V5KG4sIG4gKyBCaWdJbnQoMSkpO1xufVxuIl19

@@ -14,2 +14,3 @@ /// <reference types="node" />

amount: string | number;
tokenName?: string;
memo?: string;

@@ -16,0 +17,0 @@ }

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"iBaseCoin.js","sourceRoot":"","sources":["../../../../src/bitgo/baseCoin/iBaseCoin.ts"],"names":[],"mappings":"","sourcesContent":["import { IRequestTracer } from '../../api';\nimport { IEnterprises } from '../enterprise';\nimport { Keychain, IKeychains } from '../keychain';\nimport { IMarkets } from '../market';\nimport { IPendingApprovals } from '../pendingApproval';\nimport { InitiateRecoveryOptions } from '../recovery';\nimport { ITssUtils } from '../utils';\nimport { IWallet, IWallets, WalletData } from '../wallet';\n\nimport { IWebhooks } from '../webhook/iWebhooks';\n\nexport interface ITransactionRecipient {\n  address: string;\n  amount: string | number;\n  memo?: string;\n}\n\nexport interface ITransactionFee<TAmount = string> {\n  fee: TAmount;\n  feeRate?: number;\n  size?: number;\n}\n\nexport interface ITransactionExplanation<TFee = any, TAmount = any> {\n  displayOrder: string[];\n  id: string;\n  outputs: ITransactionRecipient[];\n  outputAmount: TAmount;\n  changeOutputs: ITransactionRecipient[];\n  changeAmount: TAmount;\n  fee: TFee;\n  proxy?: string;\n  producers?: string[];\n}\n\nexport interface KeyPair {\n  pub?: string;\n  prv: string;\n}\n\nexport interface IBlsKeyPair extends KeyPair {\n  secretShares?: string[];\n}\n\nexport interface VerifyAddressOptions {\n  address: string;\n  addressType?: string;\n  keychains?: {\n    pub: string;\n  }[];\n  error?: string;\n  coinSpecific?: AddressCoinSpecific;\n  impliedForwarderVersion?: number;\n}\n\nexport interface TransactionParams {\n  recipients?: ITransactionRecipient[];\n  walletPassphrase?: string;\n  type?: string;\n}\n\nexport interface AddressVerificationData {\n  coinSpecific?: AddressCoinSpecific;\n  chain?: number;\n  index?: number;\n}\n\nexport interface VerificationOptions {\n  disableNetworking?: boolean;\n  keychains?: {\n    user?: Keychain;\n    backup?: Keychain;\n    bitgo?: Keychain;\n  };\n  addresses?: { [address: string]: AddressVerificationData };\n  allowPaygoOutput?: boolean;\n  considerMigratedFromAddressInternal?: boolean;\n}\n\nexport interface VerifyTransactionOptions {\n  txPrebuild: TransactionPrebuild;\n  txParams: TransactionParams;\n  wallet: IWallet;\n  verification?: VerificationOptions;\n  reqId?: IRequestTracer;\n}\n\nexport interface SupplementGenerateWalletOptions {\n  label: string;\n  m: number;\n  n: number;\n  enterprise?: string;\n  disableTransactionNotifications?: boolean;\n  gasPrice?: number | string;\n  eip1559?: {\n    maxFeePerGas: number | string;\n    maxPriorityFeePerGas?: number | string;\n  };\n  walletVersion?: number;\n  keys: string[];\n  isCold: boolean;\n  keySignatures?: {\n    backup: string;\n    bitgo: string;\n  };\n  rootPrivateKey?: string;\n  disableKRSEmail?: boolean;\n  multisigType?: 'tss' | 'onchain' | 'blsdkg';\n}\n\nexport interface FeeEstimateOptions {\n  numBlocks?: number;\n  hop?: boolean;\n  recipient?: string;\n  data?: string;\n  amount?: string;\n}\n\n// TODO (SDKT-9): reverse engineer and add options\nexport interface ExtraPrebuildParamsOptions {\n  [index: string]: unknown;\n}\n\n// TODO (SDKT-9): reverse engineer and add options\nexport interface PresignTransactionOptions {\n  txPrebuild?: TransactionPrebuild;\n  walletData: WalletData;\n  tssUtils: ITssUtils;\n  [index: string]: unknown;\n}\n\n// TODO (SDKT-9): reverse engineer and add options\nexport interface PrecreateBitGoOptions {\n  [index: string]: unknown;\n}\n\n// TODO (SDKT-9): reverse engineer and add options\nexport interface VerifyRecoveryTransactionOptions {\n  [index: string]: unknown;\n}\n\n// TODO (SDKT-9): reverse engineer and add options\nexport interface ParseTransactionOptions {\n  [index: string]: unknown;\n}\n\n// TODO (SDKT-9): reverse engineer and add options\nexport interface ParsedTransaction {\n  [index: string]: unknown;\n}\n\n// TODO (SDKT-9): reverse engineer and add options\nexport interface SignTransactionOptions {\n  [index: string]: unknown;\n}\n\nexport interface KeychainsTriplet {\n  userKeychain: Keychain;\n  backupKeychain: Keychain;\n  bitgoKeychain: Keychain;\n}\n\nexport interface TransactionPrebuild {\n  txBase64?: string;\n  txHex?: string;\n  txInfo?: unknown;\n  wallet?: IWallet;\n  buildParams?: any;\n  consolidateId?: string;\n  txRequestId?: string;\n}\n\nexport interface AddressCoinSpecific {\n  outputScript?: string;\n  redeemScript?: string;\n  witnessScript?: string;\n  baseAddress?: string;\n  pendingChainInitialization?: boolean;\n  forwarderVersion?: number;\n}\n\nexport interface FullySignedTransaction {\n  txHex: string; // Transaction in any format required by each coin, i.e. in Tron it is a stringifyed JSON\n}\n\nexport interface HalfSignedUtxoTransaction {\n  txHex: string;\n}\n\nexport interface HalfSignedAccountTransaction {\n  halfSigned?: {\n    txHex?: string; // Transaction in any format required by each coin, i.e. in Tron it is a stringifyed JSON\n    payload?: string;\n    txBase64?: string;\n  };\n}\n\nexport interface SignedTransactionRequest {\n  txRequestId: string;\n}\n\nexport interface DeriveKeyWithSeedOptions {\n  key: string;\n  seed: string;\n}\n\nexport interface ValidMofNOptions {\n  m?: number;\n  n?: number;\n}\n\nexport type SignedTransaction =\n  | HalfSignedAccountTransaction\n  | HalfSignedUtxoTransaction\n  | FullySignedTransaction\n  | SignedTransactionRequest;\n\nexport interface RecoverWalletTokenOptions {\n  tokenContractAddress: string;\n  wallet: IWallet;\n  recipient: string;\n  broadcast?: boolean;\n  walletPassphrase?: string;\n  prv?: string;\n}\n\nexport interface Recipient {\n  address: string;\n  amount: string;\n  data?: string;\n}\n\nexport interface RecoverTokenTransaction {\n  halfSigned: {\n    recipient: Recipient;\n    expireTime: number;\n    contractSequenceId: number;\n    operationHash: string;\n    signature: string;\n    gasLimit: number;\n    gasPrice: number;\n    tokenContractAddress: string;\n    walletId: string;\n  };\n}\n\nexport interface IBaseCoin {\n  type: string;\n  url(suffix: string): string;\n  wallets(): IWallets;\n  enterprises(): IEnterprises;\n  keychains(): IKeychains;\n  webhooks(): IWebhooks;\n  pendingApprovals(): IPendingApprovals;\n  markets(): IMarkets;\n  getChain(): string;\n  getFamily(): string;\n  getFullName(): string;\n  valuelessTransferAllowed(): boolean;\n  sweepWithSendMany(): boolean;\n  transactionDataAllowed(): boolean;\n  allowsAccountConsolidations(): boolean;\n  supportsTss(): boolean;\n  supportsStaking(): boolean;\n  supportsBlsDkg(): boolean;\n  getBaseFactor(): number | string;\n  baseUnitsToBigUnits(baseUnits: string | number): string;\n  bigUnitsToBaseUnits(bigUnits: string | number): string;\n  signMessage(key: { prv: string }, message: string): Promise<Buffer>;\n  explainTransaction(options: Record<string, any>): Promise<ITransactionExplanation<any, string | number> | undefined>;\n  verifyTransaction(params: VerifyTransactionOptions): Promise<boolean>;\n  verifyAddress(params: VerifyAddressOptions): boolean;\n  isWalletAddress(params: VerifyAddressOptions): boolean;\n  canonicalAddress(address: string, format: unknown): string;\n  supportsBlockTarget(): boolean;\n  supplementGenerateWallet(walletParams: SupplementGenerateWalletOptions, keychains: KeychainsTriplet): Promise<any>;\n  getExtraPrebuildParams(buildParams: ExtraPrebuildParamsOptions): Promise<Record<string, unknown>>;\n  postProcessPrebuild(prebuildResponse: TransactionPrebuild): Promise<TransactionPrebuild>;\n  presignTransaction(params: PresignTransactionOptions): Promise<PresignTransactionOptions>;\n  newWalletObject(walletParams: any): IWallet;\n  feeEstimate(params: FeeEstimateOptions): Promise<any>;\n  deriveKeyWithSeed(params: DeriveKeyWithSeedOptions): { key: string; derivationPath: string };\n  keyIdsForSigning(): number[];\n  preCreateBitGo(params: PrecreateBitGoOptions): void;\n  initiateRecovery(params: InitiateRecoveryOptions): never;\n  parseTransaction(params: ParseTransactionOptions): Promise<ParsedTransaction>;\n  generateKeyPair(seed?: Buffer): KeyPair;\n  isValidPub(pub: string): boolean;\n  isValidMofNSetup(params: ValidMofNOptions): boolean;\n  isValidAddress(address: string): boolean;\n  signTransaction(params: SignTransactionOptions): Promise<SignedTransaction>;\n  getSignablePayload(serializedTx: string): Promise<Buffer>;\n  // TODO - this only belongs in eth coins\n  recoverToken(params: RecoverWalletTokenOptions): Promise<RecoverTokenTransaction>;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"iBaseCoin.js","sourceRoot":"","sources":["../../../../src/bitgo/baseCoin/iBaseCoin.ts"],"names":[],"mappings":"","sourcesContent":["import { IRequestTracer } from '../../api';\nimport { IEnterprises } from '../enterprise';\nimport { Keychain, IKeychains } from '../keychain';\nimport { IMarkets } from '../market';\nimport { IPendingApprovals } from '../pendingApproval';\nimport { InitiateRecoveryOptions } from '../recovery';\nimport { ITssUtils } from '../utils';\nimport { IWallet, IWallets, WalletData } from '../wallet';\n\nimport { IWebhooks } from '../webhook/iWebhooks';\n\nexport interface ITransactionRecipient {\n  address: string;\n  amount: string | number;\n  tokenName?: string;\n  memo?: string;\n}\n\nexport interface ITransactionFee<TAmount = string> {\n  fee: TAmount;\n  feeRate?: number;\n  size?: number;\n}\n\nexport interface ITransactionExplanation<TFee = any, TAmount = any> {\n  displayOrder: string[];\n  id: string;\n  outputs: ITransactionRecipient[];\n  outputAmount: TAmount;\n  changeOutputs: ITransactionRecipient[];\n  changeAmount: TAmount;\n  fee: TFee;\n  proxy?: string;\n  producers?: string[];\n}\n\nexport interface KeyPair {\n  pub?: string;\n  prv: string;\n}\n\nexport interface IBlsKeyPair extends KeyPair {\n  secretShares?: string[];\n}\n\nexport interface VerifyAddressOptions {\n  address: string;\n  addressType?: string;\n  keychains?: {\n    pub: string;\n  }[];\n  error?: string;\n  coinSpecific?: AddressCoinSpecific;\n  impliedForwarderVersion?: number;\n}\n\nexport interface TransactionParams {\n  recipients?: ITransactionRecipient[];\n  walletPassphrase?: string;\n  type?: string;\n}\n\nexport interface AddressVerificationData {\n  coinSpecific?: AddressCoinSpecific;\n  chain?: number;\n  index?: number;\n}\n\nexport interface VerificationOptions {\n  disableNetworking?: boolean;\n  keychains?: {\n    user?: Keychain;\n    backup?: Keychain;\n    bitgo?: Keychain;\n  };\n  addresses?: { [address: string]: AddressVerificationData };\n  allowPaygoOutput?: boolean;\n  considerMigratedFromAddressInternal?: boolean;\n}\n\nexport interface VerifyTransactionOptions {\n  txPrebuild: TransactionPrebuild;\n  txParams: TransactionParams;\n  wallet: IWallet;\n  verification?: VerificationOptions;\n  reqId?: IRequestTracer;\n}\n\nexport interface SupplementGenerateWalletOptions {\n  label: string;\n  m: number;\n  n: number;\n  enterprise?: string;\n  disableTransactionNotifications?: boolean;\n  gasPrice?: number | string;\n  eip1559?: {\n    maxFeePerGas: number | string;\n    maxPriorityFeePerGas?: number | string;\n  };\n  walletVersion?: number;\n  keys: string[];\n  isCold: boolean;\n  keySignatures?: {\n    backup: string;\n    bitgo: string;\n  };\n  rootPrivateKey?: string;\n  disableKRSEmail?: boolean;\n  multisigType?: 'tss' | 'onchain' | 'blsdkg';\n}\n\nexport interface FeeEstimateOptions {\n  numBlocks?: number;\n  hop?: boolean;\n  recipient?: string;\n  data?: string;\n  amount?: string;\n}\n\n// TODO (SDKT-9): reverse engineer and add options\nexport interface ExtraPrebuildParamsOptions {\n  [index: string]: unknown;\n}\n\n// TODO (SDKT-9): reverse engineer and add options\nexport interface PresignTransactionOptions {\n  txPrebuild?: TransactionPrebuild;\n  walletData: WalletData;\n  tssUtils: ITssUtils;\n  [index: string]: unknown;\n}\n\n// TODO (SDKT-9): reverse engineer and add options\nexport interface PrecreateBitGoOptions {\n  [index: string]: unknown;\n}\n\n// TODO (SDKT-9): reverse engineer and add options\nexport interface VerifyRecoveryTransactionOptions {\n  [index: string]: unknown;\n}\n\n// TODO (SDKT-9): reverse engineer and add options\nexport interface ParseTransactionOptions {\n  [index: string]: unknown;\n}\n\n// TODO (SDKT-9): reverse engineer and add options\nexport interface ParsedTransaction {\n  [index: string]: unknown;\n}\n\n// TODO (SDKT-9): reverse engineer and add options\nexport interface SignTransactionOptions {\n  [index: string]: unknown;\n}\n\nexport interface KeychainsTriplet {\n  userKeychain: Keychain;\n  backupKeychain: Keychain;\n  bitgoKeychain: Keychain;\n}\n\nexport interface TransactionPrebuild {\n  txBase64?: string;\n  txHex?: string;\n  txInfo?: unknown;\n  wallet?: IWallet;\n  buildParams?: any;\n  consolidateId?: string;\n  txRequestId?: string;\n}\n\nexport interface AddressCoinSpecific {\n  outputScript?: string;\n  redeemScript?: string;\n  witnessScript?: string;\n  baseAddress?: string;\n  pendingChainInitialization?: boolean;\n  forwarderVersion?: number;\n}\n\nexport interface FullySignedTransaction {\n  txHex: string; // Transaction in any format required by each coin, i.e. in Tron it is a stringifyed JSON\n}\n\nexport interface HalfSignedUtxoTransaction {\n  txHex: string;\n}\n\nexport interface HalfSignedAccountTransaction {\n  halfSigned?: {\n    txHex?: string; // Transaction in any format required by each coin, i.e. in Tron it is a stringifyed JSON\n    payload?: string;\n    txBase64?: string;\n  };\n}\n\nexport interface SignedTransactionRequest {\n  txRequestId: string;\n}\n\nexport interface DeriveKeyWithSeedOptions {\n  key: string;\n  seed: string;\n}\n\nexport interface ValidMofNOptions {\n  m?: number;\n  n?: number;\n}\n\nexport type SignedTransaction =\n  | HalfSignedAccountTransaction\n  | HalfSignedUtxoTransaction\n  | FullySignedTransaction\n  | SignedTransactionRequest;\n\nexport interface RecoverWalletTokenOptions {\n  tokenContractAddress: string;\n  wallet: IWallet;\n  recipient: string;\n  broadcast?: boolean;\n  walletPassphrase?: string;\n  prv?: string;\n}\n\nexport interface Recipient {\n  address: string;\n  amount: string;\n  data?: string;\n}\n\nexport interface RecoverTokenTransaction {\n  halfSigned: {\n    recipient: Recipient;\n    expireTime: number;\n    contractSequenceId: number;\n    operationHash: string;\n    signature: string;\n    gasLimit: number;\n    gasPrice: number;\n    tokenContractAddress: string;\n    walletId: string;\n  };\n}\n\nexport interface IBaseCoin {\n  type: string;\n  url(suffix: string): string;\n  wallets(): IWallets;\n  enterprises(): IEnterprises;\n  keychains(): IKeychains;\n  webhooks(): IWebhooks;\n  pendingApprovals(): IPendingApprovals;\n  markets(): IMarkets;\n  getChain(): string;\n  getFamily(): string;\n  getFullName(): string;\n  valuelessTransferAllowed(): boolean;\n  sweepWithSendMany(): boolean;\n  transactionDataAllowed(): boolean;\n  allowsAccountConsolidations(): boolean;\n  supportsTss(): boolean;\n  supportsStaking(): boolean;\n  supportsBlsDkg(): boolean;\n  getBaseFactor(): number | string;\n  baseUnitsToBigUnits(baseUnits: string | number): string;\n  bigUnitsToBaseUnits(bigUnits: string | number): string;\n  signMessage(key: { prv: string }, message: string): Promise<Buffer>;\n  explainTransaction(options: Record<string, any>): Promise<ITransactionExplanation<any, string | number> | undefined>;\n  verifyTransaction(params: VerifyTransactionOptions): Promise<boolean>;\n  verifyAddress(params: VerifyAddressOptions): boolean;\n  isWalletAddress(params: VerifyAddressOptions): boolean;\n  canonicalAddress(address: string, format: unknown): string;\n  supportsBlockTarget(): boolean;\n  supplementGenerateWallet(walletParams: SupplementGenerateWalletOptions, keychains: KeychainsTriplet): Promise<any>;\n  getExtraPrebuildParams(buildParams: ExtraPrebuildParamsOptions): Promise<Record<string, unknown>>;\n  postProcessPrebuild(prebuildResponse: TransactionPrebuild): Promise<TransactionPrebuild>;\n  presignTransaction(params: PresignTransactionOptions): Promise<PresignTransactionOptions>;\n  newWalletObject(walletParams: any): IWallet;\n  feeEstimate(params: FeeEstimateOptions): Promise<any>;\n  deriveKeyWithSeed(params: DeriveKeyWithSeedOptions): { key: string; derivationPath: string };\n  keyIdsForSigning(): number[];\n  preCreateBitGo(params: PrecreateBitGoOptions): void;\n  initiateRecovery(params: InitiateRecoveryOptions): never;\n  parseTransaction(params: ParseTransactionOptions): Promise<ParsedTransaction>;\n  generateKeyPair(seed?: Buffer): KeyPair;\n  isValidPub(pub: string): boolean;\n  isValidMofNSetup(params: ValidMofNOptions): boolean;\n  isValidAddress(address: string): boolean;\n  signTransaction(params: SignTransactionOptions): Promise<SignedTransaction>;\n  getSignablePayload(serializedTx: string): Promise<Buffer>;\n  // TODO - this only belongs in eth coins\n  recoverToken(params: RecoverWalletTokenOptions): Promise<RecoverTokenTransaction>;\n}\n"]}

@@ -0,1 +1,2 @@

import { EnvironmentName } from './environments';
export declare type KrsProvider = {

@@ -8,2 +9,86 @@ feeType: 'flatUsd';

export declare const krsProviders: Record<string, KrsProvider>;
export declare const defaults: {
maxFee: number;
maxFeeRate: number;
minFeeRate: number;
fallbackFeeRate: number;
minOutputSize: number;
minInstantFeeRate: number;
bitgoEthAddress: string;
};
/**
* Get the default (hardcoded) constants for a particular network.
*
* Note that this may not be the complete set of constants, and additional constants may get fetched
* from BitGo during the lifespan of a BitGo object.
* @param env
*/
export declare const defaultConstants: (env: EnvironmentName) => {
maxFee: number;
maxFeeRate: number;
minFeeRate: number;
fallbackFeeRate: number;
minOutputSize: number;
minInstantFeeRate: number;
bitgoEthAddress: string;
} & ({
eth: {
tokens: import("@bitgo/statics").BaseContractAddressConfig[];
};
xlm: {
tokens: import("@bitgo/statics").BaseNetworkConfig[];
};
algo: {
tokens: import("@bitgo/statics").AlgoTokenConfig[];
};
ofc: {
tokens: import("@bitgo/statics").OfcTokenConfig[];
};
celo: {
tokens: import("@bitgo/statics").BaseContractAddressConfig[]; /**
* Get the default (hardcoded) constants for a particular network.
*
* Note that this may not be the complete set of constants, and additional constants may get fetched
* from BitGo during the lifespan of a BitGo object.
* @param env
*/
};
eos: {
tokens: import("@bitgo/statics").BaseContractAddressConfig[];
};
avaxc: {
tokens: import("@bitgo/statics").BaseContractAddressConfig[];
};
sol: {
tokens: import("@bitgo/statics").SolTokenConfig[];
};
} | {
eth: {
tokens: import("@bitgo/statics").BaseContractAddressConfig[];
};
xlm: {
tokens: import("@bitgo/statics").BaseNetworkConfig[];
};
algo: {
tokens: import("@bitgo/statics").AlgoTokenConfig[];
};
ofc: {
tokens: import("@bitgo/statics").OfcTokenConfig[];
};
celo: {
tokens: import("@bitgo/statics").BaseContractAddressConfig[];
};
eos: {
tokens: import("@bitgo/statics").BaseContractAddressConfig[];
};
avaxc: {
tokens: import("@bitgo/statics").BaseContractAddressConfig[];
};
sol: {
tokens: import("@bitgo/statics").SolTokenConfig[];
};
});
export declare type Config = {
krsProviders: Record<string, KrsProvider>;
};
//# sourceMappingURL=config.d.ts.map
"use strict";
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
}) : (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 (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
__setModuleDefault(result, mod);
return result;
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.krsProviders = void 0;
exports.defaultConstants = exports.defaults = exports.krsProviders = void 0;
const _ = __importStar(require("lodash"));
const statics_1 = require("@bitgo/statics");
const environments_1 = require("./environments");
// KRS providers and their fee structures

@@ -25,2 +47,27 @@ exports.krsProviders = {

};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2JpdGdvL2NvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFPQSx5Q0FBeUM7QUFDNUIsUUFBQSxZQUFZLEdBQWdDO0lBQ3ZELFNBQVMsRUFBRTtRQUNULE9BQU8sRUFBRSxTQUFTO1FBQ2xCLFNBQVMsRUFBRSxFQUFFO1FBQ2IsY0FBYyxFQUFFLENBQUMsS0FBSyxFQUFFLEtBQUssQ0FBQztRQUM5QixZQUFZLEVBQUU7WUFDWixHQUFHLEVBQUUsRUFBRSxFQUFFLGtHQUFrRztTQUM1RztLQUNGO0lBQ0QsVUFBVSxFQUFFO1FBQ1YsT0FBTyxFQUFFLFNBQVM7UUFDbEIsU0FBUyxFQUFFLENBQUM7UUFDWixjQUFjLEVBQUUsQ0FBQyxLQUFLLEVBQUUsS0FBSyxDQUFDO0tBQy9CO0lBQ0QsR0FBRyxFQUFFO1FBQ0gsT0FBTyxFQUFFLFNBQVM7UUFDbEIsU0FBUyxFQUFFLENBQUM7UUFDWixjQUFjLEVBQUUsQ0FBQyxLQUFLLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxNQUFNLENBQUM7S0FDekY7Q0FDRixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHR5cGUgS3JzUHJvdmlkZXIgPSB7XG4gIGZlZVR5cGU6ICdmbGF0VXNkJztcbiAgZmVlQW1vdW50OiBudW1iZXI7XG4gIHN1cHBvcnRlZENvaW5zOiBzdHJpbmdbXTtcbiAgZmVlQWRkcmVzc2VzPzogUmVjb3JkPHN0cmluZywgc3RyaW5nPjtcbn07XG5cbi8vIEtSUyBwcm92aWRlcnMgYW5kIHRoZWlyIGZlZSBzdHJ1Y3R1cmVzXG5leHBvcnQgY29uc3Qga3JzUHJvdmlkZXJzOiBSZWNvcmQ8c3RyaW5nLCBLcnNQcm92aWRlcj4gPSB7XG4gIGtleXRlcm5hbDoge1xuICAgIGZlZVR5cGU6ICdmbGF0VXNkJyxcbiAgICBmZWVBbW91bnQ6IDk5LFxuICAgIHN1cHBvcnRlZENvaW5zOiBbJ2J0YycsICdldGgnXSxcbiAgICBmZWVBZGRyZXNzZXM6IHtcbiAgICAgIGJ0YzogJycsIC8vIFRPRE8gW0JHLTY5NjVdIEdldCBhZGRyZXNzIGZyb20gS2V5dGVybmFsIC0gcmVjb3Zlcnkgd2lsbCBmYWlsIGZvciBub3cgdW50aWwgS2V5dGVybmFsIGlzIHJlYWR5XG4gICAgfSxcbiAgfSxcbiAgYml0Z29LUlN2Mjoge1xuICAgIGZlZVR5cGU6ICdmbGF0VXNkJyxcbiAgICBmZWVBbW91bnQ6IDAsIC8vIHdlIHdpbGwgcmVjZWl2ZSBwYXltZW50cyBvZmYtY2hhaW5cbiAgICBzdXBwb3J0ZWRDb2luczogWydidGMnLCAnZXRoJ10sXG4gIH0sXG4gIGRhaToge1xuICAgIGZlZVR5cGU6ICdmbGF0VXNkJyxcbiAgICBmZWVBbW91bnQ6IDAsIC8vIGRhaSB3aWxsIHJlY2VpdmUgcGF5bWVudHMgb2ZmLWNoYWluXG4gICAgc3VwcG9ydGVkQ29pbnM6IFsnYnRjJywgJ2V0aCcsICd4bG0nLCAneHJwJywgJ2Rhc2gnLCAnemVjJywgJ2x0YycsICdiY2gnLCAnYnN2JywgJ2JjaGEnXSxcbiAgfSxcbn07XG4iXX0=
exports.defaults = {
maxFee: 0.1e8,
maxFeeRate: 1000000,
minFeeRate: 5000,
fallbackFeeRate: 50000,
minOutputSize: 2730,
minInstantFeeRate: 10000,
bitgoEthAddress: '0x0f47ea803926926f299b7f1afc8460888d850f47',
};
// TODO: once server starts returning eth address keychains, remove bitgoEthAddress
/**
* Get the default (hardcoded) constants for a particular network.
*
* Note that this may not be the complete set of constants, and additional constants may get fetched
* from BitGo during the lifespan of a BitGo object.
* @param env
*/
const defaultConstants = (env) => {
if (environments_1.Environments[env] === undefined) {
throw Error(`invalid environment ${env}`);
}
const network = environments_1.Environments[env].network;
return _.merge({}, exports.defaults, statics_1.tokens[network]);
};
exports.defaultConstants = defaultConstants;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2JpdGdvL2NvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsMENBQTRCO0FBQzVCLDRDQUF3QztBQUN4QyxpREFBK0Q7QUFTL0QseUNBQXlDO0FBQzVCLFFBQUEsWUFBWSxHQUFnQztJQUN2RCxTQUFTLEVBQUU7UUFDVCxPQUFPLEVBQUUsU0FBUztRQUNsQixTQUFTLEVBQUUsRUFBRTtRQUNiLGNBQWMsRUFBRSxDQUFDLEtBQUssRUFBRSxLQUFLLENBQUM7UUFDOUIsWUFBWSxFQUFFO1lBQ1osR0FBRyxFQUFFLEVBQUUsRUFBRSxrR0FBa0c7U0FDNUc7S0FDRjtJQUNELFVBQVUsRUFBRTtRQUNWLE9BQU8sRUFBRSxTQUFTO1FBQ2xCLFNBQVMsRUFBRSxDQUFDO1FBQ1osY0FBYyxFQUFFLENBQUMsS0FBSyxFQUFFLEtBQUssQ0FBQztLQUMvQjtJQUNELEdBQUcsRUFBRTtRQUNILE9BQU8sRUFBRSxTQUFTO1FBQ2xCLFNBQVMsRUFBRSxDQUFDO1FBQ1osY0FBYyxFQUFFLENBQUMsS0FBSyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsTUFBTSxDQUFDO0tBQ3pGO0NBQ0YsQ0FBQztBQUVXLFFBQUEsUUFBUSxHQUFHO0lBQ3RCLE1BQU0sRUFBRSxLQUFLO0lBQ2IsVUFBVSxFQUFFLE9BQU87SUFDbkIsVUFBVSxFQUFFLElBQUk7SUFDaEIsZUFBZSxFQUFFLEtBQUs7SUFDdEIsYUFBYSxFQUFFLElBQUk7SUFDbkIsaUJBQWlCLEVBQUUsS0FBSztJQUN4QixlQUFlLEVBQUUsNENBQTRDO0NBQzlELENBQUM7QUFFRixtRkFBbUY7QUFDbkY7Ozs7OztHQU1HO0FBQ0ksTUFBTSxnQkFBZ0IsR0FBRyxDQUFDLEdBQW9CLEVBQUUsRUFBRTtJQUN2RCxJQUFJLDJCQUFZLENBQUMsR0FBRyxDQUFDLEtBQUssU0FBUyxFQUFFO1FBQ25DLE1BQU0sS0FBSyxDQUFDLHVCQUF1QixHQUFHLEVBQUUsQ0FBQyxDQUFDO0tBQzNDO0lBRUQsTUFBTSxPQUFPLEdBQUcsMkJBQVksQ0FBQyxHQUFHLENBQUMsQ0FBQyxPQUFPLENBQUM7SUFDMUMsT0FBTyxDQUFDLENBQUMsS0FBSyxDQUFDLEVBQUUsRUFBRSxnQkFBUSxFQUFFLGdCQUFNLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQztBQUNoRCxDQUFDLENBQUM7QUFQVyxRQUFBLGdCQUFnQixvQkFPM0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBfIGZyb20gJ2xvZGFzaCc7XG5pbXBvcnQgeyB0b2tlbnMgfSBmcm9tICdAYml0Z28vc3RhdGljcyc7XG5pbXBvcnQgeyBFbnZpcm9ubWVudE5hbWUsIEVudmlyb25tZW50cyB9IGZyb20gJy4vZW52aXJvbm1lbnRzJztcblxuZXhwb3J0IHR5cGUgS3JzUHJvdmlkZXIgPSB7XG4gIGZlZVR5cGU6ICdmbGF0VXNkJztcbiAgZmVlQW1vdW50OiBudW1iZXI7XG4gIHN1cHBvcnRlZENvaW5zOiBzdHJpbmdbXTtcbiAgZmVlQWRkcmVzc2VzPzogUmVjb3JkPHN0cmluZywgc3RyaW5nPjtcbn07XG5cbi8vIEtSUyBwcm92aWRlcnMgYW5kIHRoZWlyIGZlZSBzdHJ1Y3R1cmVzXG5leHBvcnQgY29uc3Qga3JzUHJvdmlkZXJzOiBSZWNvcmQ8c3RyaW5nLCBLcnNQcm92aWRlcj4gPSB7XG4gIGtleXRlcm5hbDoge1xuICAgIGZlZVR5cGU6ICdmbGF0VXNkJyxcbiAgICBmZWVBbW91bnQ6IDk5LFxuICAgIHN1cHBvcnRlZENvaW5zOiBbJ2J0YycsICdldGgnXSxcbiAgICBmZWVBZGRyZXNzZXM6IHtcbiAgICAgIGJ0YzogJycsIC8vIFRPRE8gW0JHLTY5NjVdIEdldCBhZGRyZXNzIGZyb20gS2V5dGVybmFsIC0gcmVjb3Zlcnkgd2lsbCBmYWlsIGZvciBub3cgdW50aWwgS2V5dGVybmFsIGlzIHJlYWR5XG4gICAgfSxcbiAgfSxcbiAgYml0Z29LUlN2Mjoge1xuICAgIGZlZVR5cGU6ICdmbGF0VXNkJyxcbiAgICBmZWVBbW91bnQ6IDAsIC8vIHdlIHdpbGwgcmVjZWl2ZSBwYXltZW50cyBvZmYtY2hhaW5cbiAgICBzdXBwb3J0ZWRDb2luczogWydidGMnLCAnZXRoJ10sXG4gIH0sXG4gIGRhaToge1xuICAgIGZlZVR5cGU6ICdmbGF0VXNkJyxcbiAgICBmZWVBbW91bnQ6IDAsIC8vIGRhaSB3aWxsIHJlY2VpdmUgcGF5bWVudHMgb2ZmLWNoYWluXG4gICAgc3VwcG9ydGVkQ29pbnM6IFsnYnRjJywgJ2V0aCcsICd4bG0nLCAneHJwJywgJ2Rhc2gnLCAnemVjJywgJ2x0YycsICdiY2gnLCAnYnN2JywgJ2JjaGEnXSxcbiAgfSxcbn07XG5cbmV4cG9ydCBjb25zdCBkZWZhdWx0cyA9IHtcbiAgbWF4RmVlOiAwLjFlOCxcbiAgbWF4RmVlUmF0ZTogMTAwMDAwMCxcbiAgbWluRmVlUmF0ZTogNTAwMCxcbiAgZmFsbGJhY2tGZWVSYXRlOiA1MDAwMCxcbiAgbWluT3V0cHV0U2l6ZTogMjczMCxcbiAgbWluSW5zdGFudEZlZVJhdGU6IDEwMDAwLFxuICBiaXRnb0V0aEFkZHJlc3M6ICcweDBmNDdlYTgwMzkyNjkyNmYyOTliN2YxYWZjODQ2MDg4OGQ4NTBmNDcnLFxufTtcblxuLy8gVE9ETzogb25jZSBzZXJ2ZXIgc3RhcnRzIHJldHVybmluZyBldGggYWRkcmVzcyBrZXljaGFpbnMsIHJlbW92ZSBiaXRnb0V0aEFkZHJlc3Ncbi8qKlxuICogR2V0IHRoZSBkZWZhdWx0IChoYXJkY29kZWQpIGNvbnN0YW50cyBmb3IgYSBwYXJ0aWN1bGFyIG5ldHdvcmsuXG4gKlxuICogTm90ZSB0aGF0IHRoaXMgbWF5IG5vdCBiZSB0aGUgY29tcGxldGUgc2V0IG9mIGNvbnN0YW50cywgYW5kIGFkZGl0aW9uYWwgY29uc3RhbnRzIG1heSBnZXQgZmV0Y2hlZFxuICogZnJvbSBCaXRHbyBkdXJpbmcgdGhlIGxpZmVzcGFuIG9mIGEgQml0R28gb2JqZWN0LlxuICogQHBhcmFtIGVudlxuICovXG5leHBvcnQgY29uc3QgZGVmYXVsdENvbnN0YW50cyA9IChlbnY6IEVudmlyb25tZW50TmFtZSkgPT4ge1xuICBpZiAoRW52aXJvbm1lbnRzW2Vudl0gPT09IHVuZGVmaW5lZCkge1xuICAgIHRocm93IEVycm9yKGBpbnZhbGlkIGVudmlyb25tZW50ICR7ZW52fWApO1xuICB9XG5cbiAgY29uc3QgbmV0d29yayA9IEVudmlyb25tZW50c1tlbnZdLm5ldHdvcms7XG4gIHJldHVybiBfLm1lcmdlKHt9LCBkZWZhdWx0cywgdG9rZW5zW25ldHdvcmtdKTtcbn07XG5cbmV4cG9ydCB0eXBlIENvbmZpZyA9IHtcbiAga3JzUHJvdmlkZXJzOiBSZWNvcmQ8c3RyaW5nLCBLcnNQcm92aWRlcj47XG59O1xuIl19

@@ -268,3 +268,3 @@ "use strict";

address: { address: recipient.address },
amount: { value: `${recipient.amount}`, symbol: chain },
amount: { value: `${recipient.amount}`, symbol: recipient.tokenName ? recipient.tokenName : chain },
}));

@@ -278,3 +278,2 @@ const whitelistedParams = {

memo: (_a = params.memo) === null || _a === void 0 ? void 0 : _a.value,
token: params.tokenName,
nonce: params.nonce,

@@ -355,2 +354,2 @@ },

exports.TssUtils = TssUtils;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eddsa.js","sourceRoot":"","sources":["../../../../../../src/bitgo/utils/tss/eddsa/eddsa.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @prettier\n */\nimport * as bs58 from 'bs58';\nimport * as crypto from 'crypto';\nimport * as _ from 'lodash';\nimport * as openpgp from 'openpgp';\nimport { Ed25519BIP32 } from '../../../../account-lib/mpc/hdTree';\nimport Eddsa, { KeyShare, YShare } from '../../../../account-lib/mpc/tss';\nimport { IRequestTracer } from '../../../../api';\nimport { IBaseCoin, KeychainsTriplet } from '../../../baseCoin';\nimport { BitGoBase } from '../../../bitgoBase';\nimport { AddKeychainOptions, Keychain, KeyType } from '../../../keychain';\nimport { IWallet } from '../../../wallet';\nimport { ITssUtils, PrebuildTransactionWithIntentOptions, SignatureShareRecord, TxRequest } from './types';\nimport { MpcUtils } from '../../mpcUtils';\nimport { encryptText, getBitgoGpgPubKey } from '../../opengpgUtils';\nimport {\n  createUserSignShare,\n  createUserToBitGoGShare,\n  getBitgoToUserRShare,\n  getTxRequest,\n  offerUserToBitgoRShare,\n  sendUserToBitgoGShare,\n  SigningMaterial,\n} from '../../../tss';\n\n/**\n * Utility functions for TSS work flows.\n */\n\nexport class TssUtils extends MpcUtils implements ITssUtils {\n  private _wallet?: IWallet;\n\n  constructor(bitgo: BitGoBase, baseCoin: IBaseCoin, wallet?: IWallet) {\n    super(bitgo, baseCoin);\n    this._wallet = wallet;\n  }\n\n  private get wallet(): IWallet {\n    if (_.isNil(this._wallet)) {\n      throw new Error('Wallet not defined');\n    }\n    return this._wallet;\n  }\n\n  /**\n   * Creates a Keychain containing the User's TSS signing materials.\n   *\n   * @param userGpgKey - ephemeral GPG key to encrypt / decrypt sensitve data exchanged between user and server\n   * @param userKeyShare - user's TSS key share\n   * @param backupKeyShare - backup's TSS key share\n   * @param bitgoKeychain - previously created BitGo keychain; must be compatible with user and backup key shares\n   * @param passphrase - wallet passphrase used to encrypt user's signing materials\n   * @param [originalPasscodeEncryptionCode] - optional encryption code needed for wallet password reset for hot wallets\n   */\n  async createUserKeychain(\n    userGpgKey: openpgp.SerializedKeyPair<string>,\n    userKeyShare: KeyShare,\n    backupKeyShare: KeyShare,\n    bitgoKeychain: Keychain,\n    passphrase: string,\n    originalPasscodeEncryptionCode?: string\n  ): Promise<Keychain> {\n    const MPC = await Eddsa.initialize();\n    const bitgoKeyShares = bitgoKeychain.keyShares;\n    if (!bitgoKeyShares) {\n      throw new Error('Missing BitGo key shares');\n    }\n\n    const bitGoToUserShare = bitgoKeyShares.find((keyShare) => keyShare.from === 'bitgo' && keyShare.to === 'user');\n    if (!bitGoToUserShare) {\n      throw new Error('Missing BitGo to User key share');\n    }\n\n    const bitGoToUserPrivateShare = await this.decryptPrivateShare(bitGoToUserShare.privateShare, userGpgKey);\n\n    const bitgoToUser: YShare = {\n      i: 1,\n      j: 3,\n      y: bitGoToUserShare.publicShare.slice(0, 64),\n      u: bitGoToUserPrivateShare.slice(0, 64),\n      chaincode: bitGoToUserPrivateShare.slice(64),\n    };\n\n    // TODO(BG-47170): use tss.createCombinedKey helper when signatures are supported\n    const userCombined = MPC.keyCombine(userKeyShare.uShare, [backupKeyShare.yShares[1], bitgoToUser]);\n    const commonKeychain = userCombined.pShare.y + userCombined.pShare.chaincode;\n    if (commonKeychain !== bitgoKeychain.commonKeychain) {\n      throw new Error('Failed to create user keychain - commonKeychains do not match.');\n    }\n\n    const userSigningMaterial: SigningMaterial = {\n      uShare: userKeyShare.uShare,\n      bitgoYShare: bitgoToUser,\n      backupYShare: backupKeyShare.yShares[1],\n    };\n\n    const userKeychainParams: AddKeychainOptions = {\n      source: 'user',\n      keyType: 'tss' as KeyType,\n      commonKeychain: bitgoKeychain.commonKeychain,\n      encryptedPrv: this.bitgo.encrypt({ input: JSON.stringify(userSigningMaterial), password: passphrase }),\n      originalPasscodeEncryptionCode,\n    };\n\n    return await this.baseCoin.keychains().add(userKeychainParams);\n  }\n\n  /**\n   * Creates a Keychain containing the Backup party's TSS signing materials.\n   *\n   * @param userGpgKey - ephemeral GPG key to encrypt / decrypt sensitve data exchanged between user and server\n   * @param userKeyShare - User's TSS Keyshare\n   * @param backupKeyShare - Backup's TSS Keyshare\n   * @param bitgoKeychain - previously created BitGo keychain; must be compatible with user and backup key shares\n   * @param passphrase - wallet passphrase used to encrypt user's signing materials\n   */\n  async createBackupKeychain(\n    userGpgKey: openpgp.SerializedKeyPair<string>,\n    userKeyShare: KeyShare,\n    backupKeyShare: KeyShare,\n    bitgoKeychain: Keychain,\n    passphrase: string\n  ): Promise<Keychain> {\n    const MPC = await Eddsa.initialize();\n    const bitgoKeyShares = bitgoKeychain.keyShares;\n    if (!bitgoKeyShares) {\n      throw new Error('Invalid bitgo keyshares');\n    }\n\n    const bitGoToBackupShare = bitgoKeyShares.find((keyShare) => keyShare.from === 'bitgo' && keyShare.to === 'backup');\n    if (!bitGoToBackupShare) {\n      throw new Error('Missing BitGo to User key share');\n    }\n\n    const bitGoToBackupPrivateShare = await this.decryptPrivateShare(bitGoToBackupShare.privateShare, userGpgKey);\n\n    const bitgoToBackup: YShare = {\n      i: 2,\n      j: 3,\n      y: bitGoToBackupShare.publicShare.slice(0, 64),\n      u: bitGoToBackupPrivateShare.slice(0, 64),\n      chaincode: bitGoToBackupPrivateShare.slice(64),\n    };\n\n    // TODO(BG-47170): use tss.createCombinedKey helper when signatures are supported\n    const backupCombined = MPC.keyCombine(backupKeyShare.uShare, [userKeyShare.yShares[2], bitgoToBackup]);\n    const commonKeychain = backupCombined.pShare.y + backupCombined.pShare.chaincode;\n    if (commonKeychain !== bitgoKeychain.commonKeychain) {\n      throw new Error('Failed to create backup keychain - commonKeychains do not match.');\n    }\n\n    const backupSigningMaterial: SigningMaterial = {\n      uShare: backupKeyShare.uShare,\n      bitgoYShare: bitgoToBackup,\n      userYShare: userKeyShare.yShares[2],\n    };\n    const prv = JSON.stringify(backupSigningMaterial);\n\n    return await this.baseCoin.keychains().createBackup({\n      source: 'backup',\n      keyType: 'tss',\n      commonKeychain: bitgoKeychain.commonKeychain,\n      prv: prv,\n      encryptedPrv: this.bitgo.encrypt({ input: prv, password: passphrase }),\n    });\n  }\n\n  /**\n   * Creates a Keychain containing BitGo's TSS signing materials.\n   *\n   * @param userGpgKey - ephemeral GPG key to encrypt / decrypt sensitve data exchanged between user and server\n   * @param userKeyShare - user's TSS key share\n   * @param backupKeyShare - backup's TSS key share\n   */\n  async createBitgoKeychain(\n    userGpgKey: openpgp.SerializedKeyPair<string>,\n    userKeyShare: KeyShare,\n    backupKeyShare: KeyShare,\n    enterprise?: string\n  ): Promise<Keychain> {\n    // TODO(BG-47170): use tss.encryptYShare helper when signatures are supported\n    const userToBitgoPublicShare = Buffer.concat([\n      Buffer.from(userKeyShare.uShare.y, 'hex'),\n      Buffer.from(userKeyShare.uShare.chaincode, 'hex'),\n    ]).toString('hex');\n    const userToBitgoPrivateShare = Buffer.concat([\n      Buffer.from(userKeyShare.yShares[3].u, 'hex'),\n      Buffer.from(userKeyShare.yShares[3].chaincode, 'hex'),\n    ]).toString('hex');\n    const userToBitgoKeyShare = {\n      publicShare: userToBitgoPublicShare,\n      privateShare: userToBitgoPrivateShare,\n    };\n\n    const backupToBitgoPublicShare = Buffer.concat([\n      Buffer.from(backupKeyShare.uShare.y, 'hex'),\n      Buffer.from(backupKeyShare.uShare.chaincode, 'hex'),\n    ]).toString('hex');\n    const backupToBitgoPrivateShare = Buffer.concat([\n      Buffer.from(backupKeyShare.yShares[3].u, 'hex'),\n      Buffer.from(backupKeyShare.yShares[3].chaincode, 'hex'),\n    ]).toString('hex');\n    const backupToBitgoKeyShare = {\n      publicShare: backupToBitgoPublicShare,\n      privateShare: backupToBitgoPrivateShare,\n    };\n\n    return await this.createBitgoKeychainInWP(\n      userGpgKey,\n      userToBitgoKeyShare,\n      backupToBitgoKeyShare,\n      'tss',\n      enterprise\n    );\n  }\n\n  /**\n   * Creates User, Backup, and BitGo TSS Keychains.\n   *\n   * @param params.passphrase - passphrase used to encrypt signing materials created for User and Backup\n   */\n  async createKeychains(params: {\n    passphrase: string;\n    enterprise?: string;\n    originalPasscodeEncryptionCode?: string;\n  }): Promise<KeychainsTriplet> {\n    const MPC = await Eddsa.initialize();\n    const m = 2;\n    const n = 3;\n\n    const userKeyShare = MPC.keyShare(1, m, n);\n    const backupKeyShare = MPC.keyShare(2, m, n);\n\n    const randomHexString = crypto.randomBytes(12).toString('hex');\n\n    // Allow generating secp256k1 key pairs\n    openpgp.config.rejectCurves = new Set();\n    const userGpgKey = await openpgp.generateKey({\n      userIDs: [\n        {\n          name: randomHexString,\n          email: `user-${randomHexString}@${randomHexString}.com`,\n        },\n      ],\n      curve: 'secp256k1',\n    });\n\n    const bitgoKeychain = await this.createBitgoKeychain(userGpgKey, userKeyShare, backupKeyShare, params.enterprise);\n    const userKeychainPromise = this.createUserKeychain(\n      userGpgKey,\n      userKeyShare,\n      backupKeyShare,\n      bitgoKeychain,\n      params.passphrase,\n      params.originalPasscodeEncryptionCode\n    );\n    const backupKeychainPromise = this.createBackupKeychain(\n      userGpgKey,\n      userKeyShare,\n      backupKeyShare,\n      bitgoKeychain,\n      params.passphrase\n    );\n    const [userKeychain, backupKeychain] = await Promise.all([userKeychainPromise, backupKeychainPromise]);\n\n    // create wallet\n    const keychains = {\n      userKeychain,\n      backupKeychain,\n      bitgoKeychain,\n    };\n\n    return keychains;\n  }\n\n  /**\n   * Signs the transaction associated to the transaction request.\n   *\n   * @param txRequest - transaction request object or id\n   * @param prv - decrypted private key\n   * @param reqId - request id\n   * @returns {Promise<TxRequest>} fully signed TxRequest object\n   */\n  async signTxRequest(params: {\n    txRequest: string | TxRequest;\n    prv: string;\n    reqId: IRequestTracer;\n  }): Promise<TxRequest> {\n    let txRequestResolved: TxRequest;\n    let txRequestId: string;\n\n    const { txRequest, prv } = params;\n\n    if (typeof txRequest === 'string') {\n      txRequestResolved = await getTxRequest(this.bitgo, this.wallet.id(), txRequest);\n      txRequestId = txRequestResolved.txRequestId;\n    } else {\n      txRequestResolved = txRequest;\n      txRequestId = txRequest.txRequestId;\n    }\n\n    const hdTree = await Ed25519BIP32.initialize();\n    const MPC = await Eddsa.initialize(hdTree);\n\n    const userSigningMaterial: SigningMaterial = JSON.parse(prv);\n    if (!userSigningMaterial.backupYShare) {\n      throw new Error('Invalid user key - missing backupYShare');\n    }\n\n    const signingKey = MPC.keyDerive(\n      userSigningMaterial.uShare,\n      [userSigningMaterial.bitgoYShare, userSigningMaterial.backupYShare],\n      txRequestResolved.unsignedTxs[0].derivationPath\n    );\n\n    const signablePayload = Buffer.from(txRequestResolved.unsignedTxs[0].signableHex, 'hex');\n\n    const userSignShare = await createUserSignShare(signablePayload, signingKey.pShare);\n\n    const signerShare = signingKey.yShares[3].u + signingKey.yShares[3].chaincode;\n    const bitgoGpgKey = await getBitgoGpgPubKey(this.bitgo);\n    const encryptedSignerShare = await encryptText(signerShare, bitgoGpgKey);\n\n    await offerUserToBitgoRShare(this.bitgo, this.wallet.id(), txRequestId, userSignShare, encryptedSignerShare);\n\n    const bitgoToUserRShare = await getBitgoToUserRShare(this.bitgo, this.wallet.id(), txRequestId);\n\n    const userToBitGoGShare = await createUserToBitGoGShare(\n      userSignShare,\n      bitgoToUserRShare,\n      userSigningMaterial.backupYShare,\n      userSigningMaterial.bitgoYShare,\n      signablePayload\n    );\n\n    await sendUserToBitgoGShare(this.bitgo, this.wallet.id(), txRequestId, userToBitGoGShare);\n\n    return await getTxRequest(this.bitgo, this.wallet.id(), txRequestId);\n  }\n\n  /**\n   * Builds a tx request from params and verify it\n   *\n   * @param {PrebuildTransactionWithIntentOptions} params - parameters to build the tx\n   * @param apiVersion lite or full\n   * @param preview boolean indicating if this is to preview a tx request, which will not initiate policy checks or pending approvals\n   * @returns {Promise<TxRequest>} - a built tx request\n   */\n  async prebuildTxWithIntent(\n    params: PrebuildTransactionWithIntentOptions,\n    apiVersion = 'lite',\n    preview?: boolean\n  ): Promise<TxRequest> {\n    const chain = this.baseCoin.getChain();\n    const intentRecipients = params.recipients.map((recipient) => ({\n      address: { address: recipient.address },\n      amount: { value: `${recipient.amount}`, symbol: chain },\n    }));\n\n    const whitelistedParams = {\n      intent: {\n        intentType: params.intentType,\n        sequenceId: params.sequenceId,\n        comment: params.comment,\n        recipients: intentRecipients,\n        memo: params.memo?.value,\n        token: params.tokenName,\n        nonce: params.nonce,\n      },\n      apiVersion: apiVersion,\n      preview,\n    };\n\n    const unsignedTx = (await this.bitgo\n      .post(this.bitgo.url('/wallet/' + this.wallet.id() + '/txrequests', 2))\n      .send(whitelistedParams)\n      .result()) as TxRequest;\n\n    return unsignedTx;\n  }\n\n  /**\n   * Call delete signature shares for a txRequest, the endpoint delete the signatures and return them\n   *\n   * @param {string} txRequestId tx id reference to delete signature shares\n   * @returns {SignatureShareRecord[]}\n   */\n  async deleteSignatureShares(txRequestId: string): Promise<SignatureShareRecord[]> {\n    return this.bitgo\n      .del(this.bitgo.url(`/wallet/${this.wallet.id()}/txrequests/${txRequestId}/signatureshares`, 2))\n      .send()\n      .result();\n  }\n\n  /**\n   * Initialize the send procedure once Bitgo has the User To Bitgo GShare\n   *\n   * @param {String} txRequestId - the txRequest Id\n   * @returns {Promise<any>}\n   */\n  async sendTxRequest(txRequestId: string): Promise<any> {\n    return this.bitgo\n      .post(this.baseCoin.url('/wallet/' + this.wallet.id() + '/tx/send'))\n      .send({ txRequestId })\n      .result();\n  }\n\n  /**\n   * Delete signature shares, get the tx request without them from the db and sign it to finally send it.\n   *\n   * Note : This can be performed in order to reach latest network conditions required on pending approval flow.\n   *\n   * @param {String} txRequestId - the txRequest Id to make the requests.\n   * @param {String} decryptedPrv - decrypted prv to sign the tx request.\n   * @param {RequestTracer} reqId id tracer.\n   * @returns {Promise<any>}\n   */\n  async recreateTxRequest(txRequestId: string, decryptedPrv: string, reqId: IRequestTracer): Promise<TxRequest> {\n    await this.deleteSignatureShares(txRequestId);\n    // after delete signatures shares get the tx without them\n    const txRequest = await getTxRequest(this.bitgo, this.wallet.id(), txRequestId);\n    return await this.signTxRequest({ txRequest, prv: decryptedPrv, reqId });\n  }\n\n  /**\n   * Gets the latest Tx Request by id\n   *\n   * @param {String} txRequestId - the txRequest Id\n   * @returns {Promise<TxRequest>}\n   */\n  async getTxRequest(txRequestId: string): Promise<TxRequest> {\n    return getTxRequest(this.bitgo, this.wallet.id(), txRequestId);\n  }\n\n  /**\n   * Get the commonPub portion of the commonKeychain.\n   *\n   * @param {String} commonKeychain\n   * @returns {string}\n   */\n  static getPublicKeyFromCommonKeychain(commonKeychain: string): string {\n    if (commonKeychain.length !== 128) {\n      throw new Error(`Invalid commonKeychain length, expected 128, got ${commonKeychain.length}`);\n    }\n    const commonPubHexStr = commonKeychain.slice(0, 64);\n    return bs58.encode(Buffer.from(commonPubHexStr, 'hex'));\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eddsa.js","sourceRoot":"","sources":["../../../../../../src/bitgo/utils/tss/eddsa/eddsa.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @prettier\n */\nimport * as bs58 from 'bs58';\nimport * as crypto from 'crypto';\nimport * as _ from 'lodash';\nimport * as openpgp from 'openpgp';\nimport { Ed25519BIP32 } from '../../../../account-lib/mpc/hdTree';\nimport Eddsa, { KeyShare, YShare } from '../../../../account-lib/mpc/tss';\nimport { IRequestTracer } from '../../../../api';\nimport { IBaseCoin, KeychainsTriplet } from '../../../baseCoin';\nimport { BitGoBase } from '../../../bitgoBase';\nimport { AddKeychainOptions, Keychain, KeyType } from '../../../keychain';\nimport { IWallet } from '../../../wallet';\nimport { ITssUtils, PrebuildTransactionWithIntentOptions, SignatureShareRecord, TxRequest } from './types';\nimport { MpcUtils } from '../../mpcUtils';\nimport { encryptText, getBitgoGpgPubKey } from '../../opengpgUtils';\nimport {\n  createUserSignShare,\n  createUserToBitGoGShare,\n  getBitgoToUserRShare,\n  getTxRequest,\n  offerUserToBitgoRShare,\n  sendUserToBitgoGShare,\n  SigningMaterial,\n} from '../../../tss';\n\n/**\n * Utility functions for TSS work flows.\n */\n\nexport class TssUtils extends MpcUtils implements ITssUtils {\n  private _wallet?: IWallet;\n\n  constructor(bitgo: BitGoBase, baseCoin: IBaseCoin, wallet?: IWallet) {\n    super(bitgo, baseCoin);\n    this._wallet = wallet;\n  }\n\n  private get wallet(): IWallet {\n    if (_.isNil(this._wallet)) {\n      throw new Error('Wallet not defined');\n    }\n    return this._wallet;\n  }\n\n  /**\n   * Creates a Keychain containing the User's TSS signing materials.\n   *\n   * @param userGpgKey - ephemeral GPG key to encrypt / decrypt sensitve data exchanged between user and server\n   * @param userKeyShare - user's TSS key share\n   * @param backupKeyShare - backup's TSS key share\n   * @param bitgoKeychain - previously created BitGo keychain; must be compatible with user and backup key shares\n   * @param passphrase - wallet passphrase used to encrypt user's signing materials\n   * @param [originalPasscodeEncryptionCode] - optional encryption code needed for wallet password reset for hot wallets\n   */\n  async createUserKeychain(\n    userGpgKey: openpgp.SerializedKeyPair<string>,\n    userKeyShare: KeyShare,\n    backupKeyShare: KeyShare,\n    bitgoKeychain: Keychain,\n    passphrase: string,\n    originalPasscodeEncryptionCode?: string\n  ): Promise<Keychain> {\n    const MPC = await Eddsa.initialize();\n    const bitgoKeyShares = bitgoKeychain.keyShares;\n    if (!bitgoKeyShares) {\n      throw new Error('Missing BitGo key shares');\n    }\n\n    const bitGoToUserShare = bitgoKeyShares.find((keyShare) => keyShare.from === 'bitgo' && keyShare.to === 'user');\n    if (!bitGoToUserShare) {\n      throw new Error('Missing BitGo to User key share');\n    }\n\n    const bitGoToUserPrivateShare = await this.decryptPrivateShare(bitGoToUserShare.privateShare, userGpgKey);\n\n    const bitgoToUser: YShare = {\n      i: 1,\n      j: 3,\n      y: bitGoToUserShare.publicShare.slice(0, 64),\n      u: bitGoToUserPrivateShare.slice(0, 64),\n      chaincode: bitGoToUserPrivateShare.slice(64),\n    };\n\n    // TODO(BG-47170): use tss.createCombinedKey helper when signatures are supported\n    const userCombined = MPC.keyCombine(userKeyShare.uShare, [backupKeyShare.yShares[1], bitgoToUser]);\n    const commonKeychain = userCombined.pShare.y + userCombined.pShare.chaincode;\n    if (commonKeychain !== bitgoKeychain.commonKeychain) {\n      throw new Error('Failed to create user keychain - commonKeychains do not match.');\n    }\n\n    const userSigningMaterial: SigningMaterial = {\n      uShare: userKeyShare.uShare,\n      bitgoYShare: bitgoToUser,\n      backupYShare: backupKeyShare.yShares[1],\n    };\n\n    const userKeychainParams: AddKeychainOptions = {\n      source: 'user',\n      keyType: 'tss' as KeyType,\n      commonKeychain: bitgoKeychain.commonKeychain,\n      encryptedPrv: this.bitgo.encrypt({ input: JSON.stringify(userSigningMaterial), password: passphrase }),\n      originalPasscodeEncryptionCode,\n    };\n\n    return await this.baseCoin.keychains().add(userKeychainParams);\n  }\n\n  /**\n   * Creates a Keychain containing the Backup party's TSS signing materials.\n   *\n   * @param userGpgKey - ephemeral GPG key to encrypt / decrypt sensitve data exchanged between user and server\n   * @param userKeyShare - User's TSS Keyshare\n   * @param backupKeyShare - Backup's TSS Keyshare\n   * @param bitgoKeychain - previously created BitGo keychain; must be compatible with user and backup key shares\n   * @param passphrase - wallet passphrase used to encrypt user's signing materials\n   */\n  async createBackupKeychain(\n    userGpgKey: openpgp.SerializedKeyPair<string>,\n    userKeyShare: KeyShare,\n    backupKeyShare: KeyShare,\n    bitgoKeychain: Keychain,\n    passphrase: string\n  ): Promise<Keychain> {\n    const MPC = await Eddsa.initialize();\n    const bitgoKeyShares = bitgoKeychain.keyShares;\n    if (!bitgoKeyShares) {\n      throw new Error('Invalid bitgo keyshares');\n    }\n\n    const bitGoToBackupShare = bitgoKeyShares.find((keyShare) => keyShare.from === 'bitgo' && keyShare.to === 'backup');\n    if (!bitGoToBackupShare) {\n      throw new Error('Missing BitGo to User key share');\n    }\n\n    const bitGoToBackupPrivateShare = await this.decryptPrivateShare(bitGoToBackupShare.privateShare, userGpgKey);\n\n    const bitgoToBackup: YShare = {\n      i: 2,\n      j: 3,\n      y: bitGoToBackupShare.publicShare.slice(0, 64),\n      u: bitGoToBackupPrivateShare.slice(0, 64),\n      chaincode: bitGoToBackupPrivateShare.slice(64),\n    };\n\n    // TODO(BG-47170): use tss.createCombinedKey helper when signatures are supported\n    const backupCombined = MPC.keyCombine(backupKeyShare.uShare, [userKeyShare.yShares[2], bitgoToBackup]);\n    const commonKeychain = backupCombined.pShare.y + backupCombined.pShare.chaincode;\n    if (commonKeychain !== bitgoKeychain.commonKeychain) {\n      throw new Error('Failed to create backup keychain - commonKeychains do not match.');\n    }\n\n    const backupSigningMaterial: SigningMaterial = {\n      uShare: backupKeyShare.uShare,\n      bitgoYShare: bitgoToBackup,\n      userYShare: userKeyShare.yShares[2],\n    };\n    const prv = JSON.stringify(backupSigningMaterial);\n\n    return await this.baseCoin.keychains().createBackup({\n      source: 'backup',\n      keyType: 'tss',\n      commonKeychain: bitgoKeychain.commonKeychain,\n      prv: prv,\n      encryptedPrv: this.bitgo.encrypt({ input: prv, password: passphrase }),\n    });\n  }\n\n  /**\n   * Creates a Keychain containing BitGo's TSS signing materials.\n   *\n   * @param userGpgKey - ephemeral GPG key to encrypt / decrypt sensitve data exchanged between user and server\n   * @param userKeyShare - user's TSS key share\n   * @param backupKeyShare - backup's TSS key share\n   */\n  async createBitgoKeychain(\n    userGpgKey: openpgp.SerializedKeyPair<string>,\n    userKeyShare: KeyShare,\n    backupKeyShare: KeyShare,\n    enterprise?: string\n  ): Promise<Keychain> {\n    // TODO(BG-47170): use tss.encryptYShare helper when signatures are supported\n    const userToBitgoPublicShare = Buffer.concat([\n      Buffer.from(userKeyShare.uShare.y, 'hex'),\n      Buffer.from(userKeyShare.uShare.chaincode, 'hex'),\n    ]).toString('hex');\n    const userToBitgoPrivateShare = Buffer.concat([\n      Buffer.from(userKeyShare.yShares[3].u, 'hex'),\n      Buffer.from(userKeyShare.yShares[3].chaincode, 'hex'),\n    ]).toString('hex');\n    const userToBitgoKeyShare = {\n      publicShare: userToBitgoPublicShare,\n      privateShare: userToBitgoPrivateShare,\n    };\n\n    const backupToBitgoPublicShare = Buffer.concat([\n      Buffer.from(backupKeyShare.uShare.y, 'hex'),\n      Buffer.from(backupKeyShare.uShare.chaincode, 'hex'),\n    ]).toString('hex');\n    const backupToBitgoPrivateShare = Buffer.concat([\n      Buffer.from(backupKeyShare.yShares[3].u, 'hex'),\n      Buffer.from(backupKeyShare.yShares[3].chaincode, 'hex'),\n    ]).toString('hex');\n    const backupToBitgoKeyShare = {\n      publicShare: backupToBitgoPublicShare,\n      privateShare: backupToBitgoPrivateShare,\n    };\n\n    return await this.createBitgoKeychainInWP(\n      userGpgKey,\n      userToBitgoKeyShare,\n      backupToBitgoKeyShare,\n      'tss',\n      enterprise\n    );\n  }\n\n  /**\n   * Creates User, Backup, and BitGo TSS Keychains.\n   *\n   * @param params.passphrase - passphrase used to encrypt signing materials created for User and Backup\n   */\n  async createKeychains(params: {\n    passphrase: string;\n    enterprise?: string;\n    originalPasscodeEncryptionCode?: string;\n  }): Promise<KeychainsTriplet> {\n    const MPC = await Eddsa.initialize();\n    const m = 2;\n    const n = 3;\n\n    const userKeyShare = MPC.keyShare(1, m, n);\n    const backupKeyShare = MPC.keyShare(2, m, n);\n\n    const randomHexString = crypto.randomBytes(12).toString('hex');\n\n    // Allow generating secp256k1 key pairs\n    openpgp.config.rejectCurves = new Set();\n    const userGpgKey = await openpgp.generateKey({\n      userIDs: [\n        {\n          name: randomHexString,\n          email: `user-${randomHexString}@${randomHexString}.com`,\n        },\n      ],\n      curve: 'secp256k1',\n    });\n\n    const bitgoKeychain = await this.createBitgoKeychain(userGpgKey, userKeyShare, backupKeyShare, params.enterprise);\n    const userKeychainPromise = this.createUserKeychain(\n      userGpgKey,\n      userKeyShare,\n      backupKeyShare,\n      bitgoKeychain,\n      params.passphrase,\n      params.originalPasscodeEncryptionCode\n    );\n    const backupKeychainPromise = this.createBackupKeychain(\n      userGpgKey,\n      userKeyShare,\n      backupKeyShare,\n      bitgoKeychain,\n      params.passphrase\n    );\n    const [userKeychain, backupKeychain] = await Promise.all([userKeychainPromise, backupKeychainPromise]);\n\n    // create wallet\n    const keychains = {\n      userKeychain,\n      backupKeychain,\n      bitgoKeychain,\n    };\n\n    return keychains;\n  }\n\n  /**\n   * Signs the transaction associated to the transaction request.\n   *\n   * @param txRequest - transaction request object or id\n   * @param prv - decrypted private key\n   * @param reqId - request id\n   * @returns {Promise<TxRequest>} fully signed TxRequest object\n   */\n  async signTxRequest(params: {\n    txRequest: string | TxRequest;\n    prv: string;\n    reqId: IRequestTracer;\n  }): Promise<TxRequest> {\n    let txRequestResolved: TxRequest;\n    let txRequestId: string;\n\n    const { txRequest, prv } = params;\n\n    if (typeof txRequest === 'string') {\n      txRequestResolved = await getTxRequest(this.bitgo, this.wallet.id(), txRequest);\n      txRequestId = txRequestResolved.txRequestId;\n    } else {\n      txRequestResolved = txRequest;\n      txRequestId = txRequest.txRequestId;\n    }\n\n    const hdTree = await Ed25519BIP32.initialize();\n    const MPC = await Eddsa.initialize(hdTree);\n\n    const userSigningMaterial: SigningMaterial = JSON.parse(prv);\n    if (!userSigningMaterial.backupYShare) {\n      throw new Error('Invalid user key - missing backupYShare');\n    }\n\n    const signingKey = MPC.keyDerive(\n      userSigningMaterial.uShare,\n      [userSigningMaterial.bitgoYShare, userSigningMaterial.backupYShare],\n      txRequestResolved.unsignedTxs[0].derivationPath\n    );\n\n    const signablePayload = Buffer.from(txRequestResolved.unsignedTxs[0].signableHex, 'hex');\n\n    const userSignShare = await createUserSignShare(signablePayload, signingKey.pShare);\n\n    const signerShare = signingKey.yShares[3].u + signingKey.yShares[3].chaincode;\n    const bitgoGpgKey = await getBitgoGpgPubKey(this.bitgo);\n    const encryptedSignerShare = await encryptText(signerShare, bitgoGpgKey);\n\n    await offerUserToBitgoRShare(this.bitgo, this.wallet.id(), txRequestId, userSignShare, encryptedSignerShare);\n\n    const bitgoToUserRShare = await getBitgoToUserRShare(this.bitgo, this.wallet.id(), txRequestId);\n\n    const userToBitGoGShare = await createUserToBitGoGShare(\n      userSignShare,\n      bitgoToUserRShare,\n      userSigningMaterial.backupYShare,\n      userSigningMaterial.bitgoYShare,\n      signablePayload\n    );\n\n    await sendUserToBitgoGShare(this.bitgo, this.wallet.id(), txRequestId, userToBitGoGShare);\n\n    return await getTxRequest(this.bitgo, this.wallet.id(), txRequestId);\n  }\n\n  /**\n   * Builds a tx request from params and verify it\n   *\n   * @param {PrebuildTransactionWithIntentOptions} params - parameters to build the tx\n   * @param apiVersion lite or full\n   * @param preview boolean indicating if this is to preview a tx request, which will not initiate policy checks or pending approvals\n   * @returns {Promise<TxRequest>} - a built tx request\n   */\n  async prebuildTxWithIntent(\n    params: PrebuildTransactionWithIntentOptions,\n    apiVersion = 'lite',\n    preview?: boolean\n  ): Promise<TxRequest> {\n    const chain = this.baseCoin.getChain();\n    const intentRecipients = params.recipients.map((recipient) => ({\n      address: { address: recipient.address },\n      amount: { value: `${recipient.amount}`, symbol: recipient.tokenName ? recipient.tokenName : chain },\n    }));\n\n    const whitelistedParams = {\n      intent: {\n        intentType: params.intentType,\n        sequenceId: params.sequenceId,\n        comment: params.comment,\n        recipients: intentRecipients,\n        memo: params.memo?.value,\n        nonce: params.nonce,\n      },\n      apiVersion: apiVersion,\n      preview,\n    };\n\n    const unsignedTx = (await this.bitgo\n      .post(this.bitgo.url('/wallet/' + this.wallet.id() + '/txrequests', 2))\n      .send(whitelistedParams)\n      .result()) as TxRequest;\n\n    return unsignedTx;\n  }\n\n  /**\n   * Call delete signature shares for a txRequest, the endpoint delete the signatures and return them\n   *\n   * @param {string} txRequestId tx id reference to delete signature shares\n   * @returns {SignatureShareRecord[]}\n   */\n  async deleteSignatureShares(txRequestId: string): Promise<SignatureShareRecord[]> {\n    return this.bitgo\n      .del(this.bitgo.url(`/wallet/${this.wallet.id()}/txrequests/${txRequestId}/signatureshares`, 2))\n      .send()\n      .result();\n  }\n\n  /**\n   * Initialize the send procedure once Bitgo has the User To Bitgo GShare\n   *\n   * @param {String} txRequestId - the txRequest Id\n   * @returns {Promise<any>}\n   */\n  async sendTxRequest(txRequestId: string): Promise<any> {\n    return this.bitgo\n      .post(this.baseCoin.url('/wallet/' + this.wallet.id() + '/tx/send'))\n      .send({ txRequestId })\n      .result();\n  }\n\n  /**\n   * Delete signature shares, get the tx request without them from the db and sign it to finally send it.\n   *\n   * Note : This can be performed in order to reach latest network conditions required on pending approval flow.\n   *\n   * @param {String} txRequestId - the txRequest Id to make the requests.\n   * @param {String} decryptedPrv - decrypted prv to sign the tx request.\n   * @param {RequestTracer} reqId id tracer.\n   * @returns {Promise<any>}\n   */\n  async recreateTxRequest(txRequestId: string, decryptedPrv: string, reqId: IRequestTracer): Promise<TxRequest> {\n    await this.deleteSignatureShares(txRequestId);\n    // after delete signatures shares get the tx without them\n    const txRequest = await getTxRequest(this.bitgo, this.wallet.id(), txRequestId);\n    return await this.signTxRequest({ txRequest, prv: decryptedPrv, reqId });\n  }\n\n  /**\n   * Gets the latest Tx Request by id\n   *\n   * @param {String} txRequestId - the txRequest Id\n   * @returns {Promise<TxRequest>}\n   */\n  async getTxRequest(txRequestId: string): Promise<TxRequest> {\n    return getTxRequest(this.bitgo, this.wallet.id(), txRequestId);\n  }\n\n  /**\n   * Get the commonPub portion of the commonKeychain.\n   *\n   * @param {String} commonKeychain\n   * @returns {string}\n   */\n  static getPublicKeyFromCommonKeychain(commonKeychain: string): string {\n    if (commonKeychain.length !== 128) {\n      throw new Error(`Invalid commonKeychain length, expected 128, got ${commonKeychain.length}`);\n    }\n    const commonPubHexStr = commonKeychain.slice(0, 64);\n    return bs58.encode(Buffer.from(commonPubHexStr, 'hex'));\n  }\n}\n"]}

@@ -14,2 +14,3 @@ import type { SerializedKeyPair } from 'openpgp';

amount: string | number;
tokenName?: string;
}[];

@@ -16,0 +17,0 @@ comment?: string;

@@ -10,2 +10,2 @@ "use strict";

})(SignatureShareType = exports.SignatureShareType || (exports.SignatureShareType = {}));
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvYml0Z28vdXRpbHMvdHNzL2VkZHNhL3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQWlEQSxJQUFZLGtCQUlYO0FBSkQsV0FBWSxrQkFBa0I7SUFDNUIsbUNBQWEsQ0FBQTtJQUNiLHVDQUFpQixDQUFBO0lBQ2pCLHFDQUFlLENBQUE7QUFDakIsQ0FBQyxFQUpXLGtCQUFrQixHQUFsQiwwQkFBa0IsS0FBbEIsMEJBQWtCLFFBSTdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBTZXJpYWxpemVkS2V5UGFpciB9IGZyb20gJ29wZW5wZ3AnO1xuaW1wb3J0IHsgS2V5U2hhcmUgfSBmcm9tICcuLi8uLi8uLi8uLi9hY2NvdW50LWxpYi9tcGMvdHNzJztcbmltcG9ydCB7IElSZXF1ZXN0VHJhY2VyIH0gZnJvbSAnLi4vLi4vLi4vLi4vYXBpJztcbmltcG9ydCB7IEtleWNoYWluc1RyaXBsZXQgfSBmcm9tICcuLi8uLi8uLi9iYXNlQ29pbic7XG5pbXBvcnQgeyBLZXljaGFpbiB9IGZyb20gJy4uLy4uLy4uL2tleWNoYWluJztcbmltcG9ydCB7IE1lbW8gfSBmcm9tICcuLi8uLi8uLi93YWxsZXQnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFByZWJ1aWxkVHJhbnNhY3Rpb25XaXRoSW50ZW50T3B0aW9ucyB7XG4gIHJlcUlkOiBJUmVxdWVzdFRyYWNlcjtcbiAgaW50ZW50VHlwZTogc3RyaW5nO1xuICBzZXF1ZW5jZUlkPzogc3RyaW5nO1xuICByZWNpcGllbnRzOiB7XG4gICAgYWRkcmVzczogc3RyaW5nO1xuICAgIGFtb3VudDogc3RyaW5nIHwgbnVtYmVyO1xuICB9W107XG4gIGNvbW1lbnQ/OiBzdHJpbmc7XG4gIG1lbW8/OiBNZW1vO1xuICB0b2tlbk5hbWU/OiBzdHJpbmc7XG4gIG5vbmNlPzogc3RyaW5nO1xufVxuXG5leHBvcnQgdHlwZSBUeFJlcXVlc3RWZXJzaW9uID0gJ2Z1bGwnIHwgJ2xpdGUnO1xuXG5leHBvcnQgdHlwZSBVbnNpZ25lZFRyYW5zYWN0aW9uID0ge1xuICBzZXJpYWxpemVkVHhIZXg6IHN0cmluZztcbiAgc2lnbmFibGVIZXg6IHN0cmluZztcbiAgZmVlSW5mbz86IHtcbiAgICBmZWU6IG51bWJlcjtcbiAgICBmZWVTdHJpbmc6IHN0cmluZztcbiAgfTtcbiAgZGVyaXZhdGlvblBhdGg6IHN0cmluZztcbn07XG5cbi8vIGNvbXBsZXRlIHdpdGggbW9yZSBwcm9wcyBpZiBuZWNjZXNhcnlcbmV4cG9ydCBpbnRlcmZhY2UgVHhSZXF1ZXN0IHtcbiAgdHhSZXF1ZXN0SWQ6IHN0cmluZztcbiAgLy8gT25seSBhdmFpbGFibGUgaW4gJ2xpdGUnIHZlcnNpb25cbiAgdW5zaWduZWRUeHM6IFVuc2lnbmVkVHJhbnNhY3Rpb25bXTtcbiAgc2lnbmF0dXJlU2hhcmVzPzogU2lnbmF0dXJlU2hhcmVSZWNvcmRbXTtcbiAgLy8gT25seSBhdmFpbGFibGUgaW4gJ2Z1bGwnIHZlcnNpb25cbiAgdHJhbnNhY3Rpb25zOiB7XG4gICAgc3RhdGU6IHN0cmluZztcbiAgICB1bnNpZ25lZFR4OiBVbnNpZ25lZFRyYW5zYWN0aW9uO1xuICAgIHByaXZhdGVTaWduYXR1cmVTaGFyZXM6IFNpZ25hdHVyZVNoYXJlUmVjb3JkW107XG4gICAgc2lnbmF0dXJlU2hhcmVzOiBTaWduYXR1cmVTaGFyZVJlY29yZFtdO1xuICB9W107XG4gIGFwaVZlcnNpb24/OiBUeFJlcXVlc3RWZXJzaW9uO1xufVxuXG5leHBvcnQgZW51bSBTaWduYXR1cmVTaGFyZVR5cGUge1xuICBVU0VSID0gJ3VzZXInLFxuICBCQUNLVVAgPSAnYmFja3VwJyxcbiAgQklUR08gPSAnYml0Z28nLFxufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNpZ25hdHVyZVNoYXJlUmVjb3JkIHtcbiAgZnJvbTogU2lnbmF0dXJlU2hhcmVUeXBlO1xuICB0bzogU2lnbmF0dXJlU2hhcmVUeXBlO1xuICBzaGFyZTogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIElUc3NVdGlscyB7XG4gIGNyZWF0ZVVzZXJLZXljaGFpbihcbiAgICB1c2VyR3BnS2V5OiBTZXJpYWxpemVkS2V5UGFpcjxzdHJpbmc+LFxuICAgIHVzZXJLZXlTaGFyZTogS2V5U2hhcmUsXG4gICAgYmFja3VwS2V5U2hhcmU6IEtleVNoYXJlLFxuICAgIGJpdGdvS2V5Y2hhaW46IEtleWNoYWluLFxuICAgIHBhc3NwaHJhc2U6IHN0cmluZyxcbiAgICBvcmlnaW5hbFBhc3Njb2RlRW5jcnlwdGlvbkNvZGU6IHN0cmluZ1xuICApOiBQcm9taXNlPEtleWNoYWluPjtcbiAgY3JlYXRlQmFja3VwS2V5Y2hhaW4oXG4gICAgdXNlckdwZ0tleTogU2VyaWFsaXplZEtleVBhaXI8c3RyaW5nPixcbiAgICB1c2VyS2V5U2hhcmU6IEtleVNoYXJlLFxuICAgIGJhY2t1cEtleVNoYXJlOiBLZXlTaGFyZSxcbiAgICBiaXRnb0tleWNoYWluOiBLZXljaGFpbixcbiAgICBwYXNzcGhyYXNlOiBzdHJpbmdcbiAgKTogUHJvbWlzZTxLZXljaGFpbj47XG4gIGNyZWF0ZUJpdGdvS2V5Y2hhaW4oXG4gICAgdXNlckdwZ0tleTogU2VyaWFsaXplZEtleVBhaXI8c3RyaW5nPixcbiAgICB1c2VyS2V5U2hhcmU6IEtleVNoYXJlLFxuICAgIGJhY2t1cEtleVNoYXJlOiBLZXlTaGFyZSxcbiAgICBlbnRlcnByaXNlOiBzdHJpbmdcbiAgKTogUHJvbWlzZTxLZXljaGFpbj47XG4gIGNyZWF0ZUtleWNoYWlucyhwYXJhbXM6IHtcbiAgICBwYXNzcGhyYXNlOiBzdHJpbmc7XG4gICAgZW50ZXJwcmlzZT86IHN0cmluZztcbiAgICBvcmlnaW5hbFBhc3Njb2RlRW5jcnlwdGlvbkNvZGU/OiBzdHJpbmc7XG4gIH0pOiBQcm9taXNlPEtleWNoYWluc1RyaXBsZXQ+O1xuICBzaWduVHhSZXF1ZXN0KHBhcmFtczogeyB0eFJlcXVlc3Q6IHN0cmluZyB8IFR4UmVxdWVzdDsgcHJ2OiBzdHJpbmc7IHJlcUlkOiBJUmVxdWVzdFRyYWNlciB9KTogUHJvbWlzZTxUeFJlcXVlc3Q+O1xuICBwcmVidWlsZFR4V2l0aEludGVudChcbiAgICBwYXJhbXM6IFByZWJ1aWxkVHJhbnNhY3Rpb25XaXRoSW50ZW50T3B0aW9ucyxcbiAgICBhcGlWZXJzaW9uPzogVHhSZXF1ZXN0VmVyc2lvbixcbiAgICBwcmV2aWV3PzogYm9vbGVhblxuICApOiBQcm9taXNlPFR4UmVxdWVzdD47XG4gIGRlbGV0ZVNpZ25hdHVyZVNoYXJlcyh0eFJlcXVlc3RJZDogc3RyaW5nKTogUHJvbWlzZTxTaWduYXR1cmVTaGFyZVJlY29yZFtdPjtcbiAgc2VuZFR4UmVxdWVzdCh0eFJlcXVlc3RJZDogc3RyaW5nKTogUHJvbWlzZTxhbnk+O1xuICByZWNyZWF0ZVR4UmVxdWVzdCh0eFJlcXVlc3RJZDogc3RyaW5nLCBkZWNyeXB0ZWRQcnY6IHN0cmluZywgcmVxSWQ6IElSZXF1ZXN0VHJhY2VyKTogUHJvbWlzZTxUeFJlcXVlc3Q+O1xuICBnZXRUeFJlcXVlc3QodHhSZXF1ZXN0SWQ6IHN0cmluZyk6IFByb21pc2U8VHhSZXF1ZXN0Pjtcbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvYml0Z28vdXRpbHMvdHNzL2VkZHNhL3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQWtEQSxJQUFZLGtCQUlYO0FBSkQsV0FBWSxrQkFBa0I7SUFDNUIsbUNBQWEsQ0FBQTtJQUNiLHVDQUFpQixDQUFBO0lBQ2pCLHFDQUFlLENBQUE7QUFDakIsQ0FBQyxFQUpXLGtCQUFrQixHQUFsQiwwQkFBa0IsS0FBbEIsMEJBQWtCLFFBSTdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBTZXJpYWxpemVkS2V5UGFpciB9IGZyb20gJ29wZW5wZ3AnO1xuaW1wb3J0IHsgS2V5U2hhcmUgfSBmcm9tICcuLi8uLi8uLi8uLi9hY2NvdW50LWxpYi9tcGMvdHNzJztcbmltcG9ydCB7IElSZXF1ZXN0VHJhY2VyIH0gZnJvbSAnLi4vLi4vLi4vLi4vYXBpJztcbmltcG9ydCB7IEtleWNoYWluc1RyaXBsZXQgfSBmcm9tICcuLi8uLi8uLi9iYXNlQ29pbic7XG5pbXBvcnQgeyBLZXljaGFpbiB9IGZyb20gJy4uLy4uLy4uL2tleWNoYWluJztcbmltcG9ydCB7IE1lbW8gfSBmcm9tICcuLi8uLi8uLi93YWxsZXQnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFByZWJ1aWxkVHJhbnNhY3Rpb25XaXRoSW50ZW50T3B0aW9ucyB7XG4gIHJlcUlkOiBJUmVxdWVzdFRyYWNlcjtcbiAgaW50ZW50VHlwZTogc3RyaW5nO1xuICBzZXF1ZW5jZUlkPzogc3RyaW5nO1xuICByZWNpcGllbnRzOiB7XG4gICAgYWRkcmVzczogc3RyaW5nO1xuICAgIGFtb3VudDogc3RyaW5nIHwgbnVtYmVyO1xuICAgIHRva2VuTmFtZT86IHN0cmluZztcbiAgfVtdO1xuICBjb21tZW50Pzogc3RyaW5nO1xuICBtZW1vPzogTWVtbztcbiAgdG9rZW5OYW1lPzogc3RyaW5nO1xuICBub25jZT86IHN0cmluZztcbn1cblxuZXhwb3J0IHR5cGUgVHhSZXF1ZXN0VmVyc2lvbiA9ICdmdWxsJyB8ICdsaXRlJztcblxuZXhwb3J0IHR5cGUgVW5zaWduZWRUcmFuc2FjdGlvbiA9IHtcbiAgc2VyaWFsaXplZFR4SGV4OiBzdHJpbmc7XG4gIHNpZ25hYmxlSGV4OiBzdHJpbmc7XG4gIGZlZUluZm8/OiB7XG4gICAgZmVlOiBudW1iZXI7XG4gICAgZmVlU3RyaW5nOiBzdHJpbmc7XG4gIH07XG4gIGRlcml2YXRpb25QYXRoOiBzdHJpbmc7XG59O1xuXG4vLyBjb21wbGV0ZSB3aXRoIG1vcmUgcHJvcHMgaWYgbmVjY2VzYXJ5XG5leHBvcnQgaW50ZXJmYWNlIFR4UmVxdWVzdCB7XG4gIHR4UmVxdWVzdElkOiBzdHJpbmc7XG4gIC8vIE9ubHkgYXZhaWxhYmxlIGluICdsaXRlJyB2ZXJzaW9uXG4gIHVuc2lnbmVkVHhzOiBVbnNpZ25lZFRyYW5zYWN0aW9uW107XG4gIHNpZ25hdHVyZVNoYXJlcz86IFNpZ25hdHVyZVNoYXJlUmVjb3JkW107XG4gIC8vIE9ubHkgYXZhaWxhYmxlIGluICdmdWxsJyB2ZXJzaW9uXG4gIHRyYW5zYWN0aW9uczoge1xuICAgIHN0YXRlOiBzdHJpbmc7XG4gICAgdW5zaWduZWRUeDogVW5zaWduZWRUcmFuc2FjdGlvbjtcbiAgICBwcml2YXRlU2lnbmF0dXJlU2hhcmVzOiBTaWduYXR1cmVTaGFyZVJlY29yZFtdO1xuICAgIHNpZ25hdHVyZVNoYXJlczogU2lnbmF0dXJlU2hhcmVSZWNvcmRbXTtcbiAgfVtdO1xuICBhcGlWZXJzaW9uPzogVHhSZXF1ZXN0VmVyc2lvbjtcbn1cblxuZXhwb3J0IGVudW0gU2lnbmF0dXJlU2hhcmVUeXBlIHtcbiAgVVNFUiA9ICd1c2VyJyxcbiAgQkFDS1VQID0gJ2JhY2t1cCcsXG4gIEJJVEdPID0gJ2JpdGdvJyxcbn1cblxuZXhwb3J0IGludGVyZmFjZSBTaWduYXR1cmVTaGFyZVJlY29yZCB7XG4gIGZyb206IFNpZ25hdHVyZVNoYXJlVHlwZTtcbiAgdG86IFNpZ25hdHVyZVNoYXJlVHlwZTtcbiAgc2hhcmU6IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJVHNzVXRpbHMge1xuICBjcmVhdGVVc2VyS2V5Y2hhaW4oXG4gICAgdXNlckdwZ0tleTogU2VyaWFsaXplZEtleVBhaXI8c3RyaW5nPixcbiAgICB1c2VyS2V5U2hhcmU6IEtleVNoYXJlLFxuICAgIGJhY2t1cEtleVNoYXJlOiBLZXlTaGFyZSxcbiAgICBiaXRnb0tleWNoYWluOiBLZXljaGFpbixcbiAgICBwYXNzcGhyYXNlOiBzdHJpbmcsXG4gICAgb3JpZ2luYWxQYXNzY29kZUVuY3J5cHRpb25Db2RlOiBzdHJpbmdcbiAgKTogUHJvbWlzZTxLZXljaGFpbj47XG4gIGNyZWF0ZUJhY2t1cEtleWNoYWluKFxuICAgIHVzZXJHcGdLZXk6IFNlcmlhbGl6ZWRLZXlQYWlyPHN0cmluZz4sXG4gICAgdXNlcktleVNoYXJlOiBLZXlTaGFyZSxcbiAgICBiYWNrdXBLZXlTaGFyZTogS2V5U2hhcmUsXG4gICAgYml0Z29LZXljaGFpbjogS2V5Y2hhaW4sXG4gICAgcGFzc3BocmFzZTogc3RyaW5nXG4gICk6IFByb21pc2U8S2V5Y2hhaW4+O1xuICBjcmVhdGVCaXRnb0tleWNoYWluKFxuICAgIHVzZXJHcGdLZXk6IFNlcmlhbGl6ZWRLZXlQYWlyPHN0cmluZz4sXG4gICAgdXNlcktleVNoYXJlOiBLZXlTaGFyZSxcbiAgICBiYWNrdXBLZXlTaGFyZTogS2V5U2hhcmUsXG4gICAgZW50ZXJwcmlzZTogc3RyaW5nXG4gICk6IFByb21pc2U8S2V5Y2hhaW4+O1xuICBjcmVhdGVLZXljaGFpbnMocGFyYW1zOiB7XG4gICAgcGFzc3BocmFzZTogc3RyaW5nO1xuICAgIGVudGVycHJpc2U/OiBzdHJpbmc7XG4gICAgb3JpZ2luYWxQYXNzY29kZUVuY3J5cHRpb25Db2RlPzogc3RyaW5nO1xuICB9KTogUHJvbWlzZTxLZXljaGFpbnNUcmlwbGV0PjtcbiAgc2lnblR4UmVxdWVzdChwYXJhbXM6IHsgdHhSZXF1ZXN0OiBzdHJpbmcgfCBUeFJlcXVlc3Q7IHBydjogc3RyaW5nOyByZXFJZDogSVJlcXVlc3RUcmFjZXIgfSk6IFByb21pc2U8VHhSZXF1ZXN0PjtcbiAgcHJlYnVpbGRUeFdpdGhJbnRlbnQoXG4gICAgcGFyYW1zOiBQcmVidWlsZFRyYW5zYWN0aW9uV2l0aEludGVudE9wdGlvbnMsXG4gICAgYXBpVmVyc2lvbj86IFR4UmVxdWVzdFZlcnNpb24sXG4gICAgcHJldmlldz86IGJvb2xlYW5cbiAgKTogUHJvbWlzZTxUeFJlcXVlc3Q+O1xuICBkZWxldGVTaWduYXR1cmVTaGFyZXModHhSZXF1ZXN0SWQ6IHN0cmluZyk6IFByb21pc2U8U2lnbmF0dXJlU2hhcmVSZWNvcmRbXT47XG4gIHNlbmRUeFJlcXVlc3QodHhSZXF1ZXN0SWQ6IHN0cmluZyk6IFByb21pc2U8YW55PjtcbiAgcmVjcmVhdGVUeFJlcXVlc3QodHhSZXF1ZXN0SWQ6IHN0cmluZywgZGVjcnlwdGVkUHJ2OiBzdHJpbmcsIHJlcUlkOiBJUmVxdWVzdFRyYWNlcik6IFByb21pc2U8VHhSZXF1ZXN0PjtcbiAgZ2V0VHhSZXF1ZXN0KHR4UmVxdWVzdElkOiBzdHJpbmcpOiBQcm9taXNlPFR4UmVxdWVzdD47XG59XG4iXX0=
{
"name": "@bitgo/sdk-core",
"version": "1.1.0-rc.19",
"version": "1.1.0-rc.20",
"description": "core library functions for BitGoJS",

@@ -39,3 +39,3 @@ "main": "./dist/src/index.js",

"@bitgo/bls-dkg": "^1.1.0-rc.1",
"@bitgo/statics": "^6.18.0-rc.20",
"@bitgo/statics": "^6.18.0-rc.21",
"@bitgo/utxo-lib": "^2.3.0-rc.10",

@@ -66,3 +66,3 @@ "@noble/secp256k1": "1.6.0",

},
"gitHead": "0820e8d1952d40fc6ce2e63d6228dbc5519d5265"
"gitHead": "d0f7f949da4a58434e965b0a3592c6abbf6c6928"
}

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc