@bitgo-beta/sdk-api 1.10.1-beta.99 → 1.10.1-beta.991
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.
- package/CHANGELOG.md +905 -0
- package/dist/package.json +13 -25
- package/dist/src/api.d.ts +3 -3
- package/dist/src/api.d.ts.map +1 -1
- package/dist/src/api.js +39 -33
- package/dist/src/bitgoAPI.d.ts +64 -11
- package/dist/src/bitgoAPI.d.ts.map +1 -1
- package/dist/src/bitgoAPI.js +357 -121
- package/dist/src/encrypt.d.ts +4 -4
- package/dist/src/encrypt.d.ts.map +1 -1
- package/dist/src/encrypt.js +44 -7
- package/dist/src/index.js +6 -2
- package/dist/src/types.d.ts +54 -43
- package/dist/src/types.d.ts.map +1 -1
- package/dist/src/types.js +4 -2
- package/dist/src/util.d.ts +12 -0
- package/dist/src/util.d.ts.map +1 -1
- package/dist/src/util.js +57 -4
- package/dist/src/v1/blockchain.js +25 -12
- package/dist/src/v1/keychains.js +27 -22
- package/dist/src/v1/markets.js +10 -5
- package/dist/src/v1/pendingapproval.d.ts.map +1 -1
- package/dist/src/v1/pendingapproval.js +57 -18
- package/dist/src/v1/pendingapprovals.d.ts.map +1 -1
- package/dist/src/v1/pendingapprovals.js +41 -7
- package/dist/src/v1/signPsbt.d.ts +14 -0
- package/dist/src/v1/signPsbt.d.ts.map +1 -0
- package/dist/src/v1/signPsbt.js +69 -0
- package/dist/src/v1/transactionBuilder.js +144 -92
- package/dist/src/v1/travelRule.js +60 -23
- package/dist/src/v1/verifyAddress.d.ts +6 -0
- package/dist/src/v1/verifyAddress.d.ts.map +1 -0
- package/dist/src/v1/verifyAddress.js +50 -0
- package/dist/src/v1/wallet.d.ts.map +1 -1
- package/dist/src/v1/wallet.js +428 -224
- package/dist/src/v1/wallets.js +93 -37
- package/package.json +13 -25
- package/dist/web/main.js +0 -2
- package/dist/web/main.js.LICENSE.txt +0 -110
package/dist/package.json
CHANGED
|
@@ -1,18 +1,11 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@bitgo-beta/sdk-api",
|
|
3
|
-
"version": "1.10.1-beta.
|
|
3
|
+
"version": "1.10.1-beta.991",
|
|
4
4
|
"description": "REST wrapper for BitGoJS",
|
|
5
5
|
"main": "./dist/src/index.js",
|
|
6
6
|
"types": "./dist/src/index.d.ts",
|
|
7
|
-
"exports": {
|
|
8
|
-
"./package.json": "./package.json",
|
|
9
|
-
".": {
|
|
10
|
-
"node": "./dist/src/index.js",
|
|
11
|
-
"default": "./dist/web/main.js"
|
|
12
|
-
}
|
|
13
|
-
},
|
|
14
7
|
"browser": {
|
|
15
|
-
"
|
|
8
|
+
"proxy-agent": false
|
|
16
9
|
},
|
|
17
10
|
"scripts": {
|
|
18
11
|
"build": "yarn tsc --build --incremental --verbose .",
|
|
@@ -21,12 +14,9 @@
|
|
|
21
14
|
"clean": "rm -r ./dist",
|
|
22
15
|
"lint": "eslint --quiet .",
|
|
23
16
|
"prepare": "npm run build",
|
|
24
|
-
"webpack-dev": "yarn webpack",
|
|
25
|
-
"webpack-prod": "yarn webpack --mode=production --node-env=production",
|
|
26
|
-
"prepublishOnly": "yarn webpack-prod",
|
|
27
17
|
"test": "npm run coverage",
|
|
28
18
|
"coverage": "nyc -- npm run unit-test",
|
|
29
|
-
"unit-test": "mocha"
|
|
19
|
+
"unit-test": "mocha 'test/unit/**/*.ts'"
|
|
30
20
|
},
|
|
31
21
|
"author": "BitGo SDK Team <sdkteam@bitgo.com>",
|
|
32
22
|
"license": "MIT",
|
|
@@ -50,23 +40,21 @@
|
|
|
50
40
|
]
|
|
51
41
|
},
|
|
52
42
|
"dependencies": {
|
|
53
|
-
"@bitgo-beta/sdk-core": "8.2.1-beta.
|
|
54
|
-
"@bitgo-beta/
|
|
55
|
-
"@bitgo-beta/
|
|
56
|
-
"@bitgo-beta/
|
|
43
|
+
"@bitgo-beta/sdk-core": "8.2.1-beta.992",
|
|
44
|
+
"@bitgo-beta/sdk-hmac": "1.0.1-beta.359",
|
|
45
|
+
"@bitgo-beta/sjcl": "1.0.2-beta.1231",
|
|
46
|
+
"@bitgo-beta/unspents": "0.13.2-beta.992",
|
|
47
|
+
"@bitgo-beta/utxo-lib": "8.0.3-beta.993",
|
|
57
48
|
"@types/superagent": "4.1.15",
|
|
58
|
-
"bitcoinjs-message": "
|
|
59
|
-
"bluebird": "^3.5.3",
|
|
60
|
-
"browser-or-node": "2.0.0",
|
|
61
|
-
"bs58": "^2.0.1",
|
|
49
|
+
"bitcoinjs-message": "npm:@bitgo-forks/bitcoinjs-message@1.0.0-master.3",
|
|
62
50
|
"debug": "3.1.0",
|
|
63
51
|
"eol": "^0.5.0",
|
|
64
52
|
"lodash": "^4.17.15",
|
|
53
|
+
"proxy-agent": "6.4.0",
|
|
65
54
|
"sanitize-html": "^2.11",
|
|
66
|
-
"secp256k1": "
|
|
55
|
+
"secp256k1": "5.0.1",
|
|
67
56
|
"secrets.js-grempe": "^1.1.0",
|
|
68
|
-
"superagent": "
|
|
69
|
-
"superagent-proxy": "3.0.0"
|
|
57
|
+
"superagent": "^9.0.1"
|
|
70
58
|
},
|
|
71
59
|
"overrides": {
|
|
72
60
|
"degenerator": "5.0.0"
|
|
@@ -74,5 +62,5 @@
|
|
|
74
62
|
"resolutions": {
|
|
75
63
|
"degenerator": "5.0.0"
|
|
76
64
|
},
|
|
77
|
-
"gitHead": "
|
|
65
|
+
"gitHead": "8abf9149c6a0c5dd7a7b400f4854d8c8030129b6"
|
|
78
66
|
}
|
package/dist/src/api.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import
|
|
1
|
+
import superagent from 'superagent';
|
|
2
2
|
import { BitGoRequest } from '@bitgo-beta/sdk-core';
|
|
3
|
-
import { VerifyResponseOptions } from './types';
|
|
3
|
+
import { AuthVersion, VerifyResponseOptions } from './types';
|
|
4
4
|
import { BitGoAPI } from './bitgoAPI';
|
|
5
5
|
/**
|
|
6
6
|
* Add the bitgo-specific result() function on a superagent request.
|
|
@@ -43,5 +43,5 @@ export declare function setRequestQueryString(req: superagent.SuperAgentRequest)
|
|
|
43
43
|
* Verify that the response received from the server is signed correctly.
|
|
44
44
|
* Right now, it is very permissive with the timestamp variance.
|
|
45
45
|
*/
|
|
46
|
-
export declare function verifyResponse(bitgo: BitGoAPI, token: string | undefined, method: VerifyResponseOptions['method'], req: superagent.SuperAgentRequest, response: superagent.Response): superagent.Response;
|
|
46
|
+
export declare function verifyResponse(bitgo: BitGoAPI, token: string | undefined, method: VerifyResponseOptions['method'], req: superagent.SuperAgentRequest, response: superagent.Response, authVersion: AuthVersion): superagent.Response;
|
|
47
47
|
//# sourceMappingURL=api.d.ts.map
|
package/dist/src/api.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"api.d.ts","sourceRoot":"","sources":["../../src/api.ts"],"names":[],"mappings":"AAOA,OAAO,
|
|
1
|
+
{"version":3,"file":"api.d.ts","sourceRoot":"","sources":["../../src/api.ts"],"names":[],"mappings":"AAOA,OAAO,UAAU,MAAM,YAAY,CAAC;AAIpC,OAAO,EAAoB,YAAY,EAAE,MAAM,sBAAsB,CAAC;AAEtE,OAAO,EAAE,WAAW,EAAE,qBAAqB,EAAE,MAAM,SAAS,CAAC;AAC7D,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAItC;;;;;;;;;;GAUG;AACH,wBAAgB,cAAc,CAAC,kBAAkB,GAAG,GAAG,EACrD,GAAG,EAAE,UAAU,CAAC,iBAAiB,GAChC,YAAY,CAAC,kBAAkB,CAAC,CASlC;AAED;;;;GAIG;AACH,wBAAgB,oBAAoB,CAAC,kBAAkB,EACrD,aAAa,CAAC,EAAE,MAAM,GACrB,CAAC,GAAG,EAAE,UAAU,CAAC,QAAQ,KAAK,kBAAkB,CAalD;AAkBD;;;;GAIG;AACH,wBAAgB,mBAAmB,CAAC,CAAC,EAAE,KAAK,GAAG;IAAE,QAAQ,CAAC,EAAE,UAAU,CAAC,QAAQ,CAAA;CAAE,GAAG,KAAK,CAKxF;AAgCD;;;;GAIG;AACH,wBAAgB,oBAAoB,CAAC,GAAG,EAAE,UAAU,CAAC,OAAO,GAAG,MAAM,GAAG,SAAS,CAkBhF;AAED;;;GAGG;AACH,wBAAgB,qBAAqB,CAAC,GAAG,EAAE,UAAU,CAAC,iBAAiB,GAAG,IAAI,CAwB7E;AAED;;;GAGG;AACH,wBAAgB,cAAc,CAC5B,KAAK,EAAE,QAAQ,EACf,KAAK,EAAE,MAAM,GAAG,SAAS,EACzB,MAAM,EAAE,qBAAqB,CAAC,QAAQ,CAAC,EACvC,GAAG,EAAE,UAAU,CAAC,iBAAiB,EACjC,QAAQ,EAAE,UAAU,CAAC,QAAQ,EAC7B,WAAW,EAAE,WAAW,GACvB,UAAU,CAAC,QAAQ,CAgDrB"}
|
package/dist/src/api.js
CHANGED
|
@@ -1,18 +1,26 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
2
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.
|
|
6
|
+
exports.toBitgoRequest = toBitgoRequest;
|
|
7
|
+
exports.handleResponseResult = handleResponseResult;
|
|
8
|
+
exports.handleResponseError = handleResponseError;
|
|
9
|
+
exports.serializeRequestData = serializeRequestData;
|
|
10
|
+
exports.setRequestQueryString = setRequestQueryString;
|
|
11
|
+
exports.verifyResponse = verifyResponse;
|
|
4
12
|
/**
|
|
5
13
|
* @prettier
|
|
6
14
|
*/
|
|
7
|
-
const debug_1 = require("debug");
|
|
8
|
-
const
|
|
9
|
-
const
|
|
10
|
-
const
|
|
11
|
-
const
|
|
12
|
-
const
|
|
13
|
-
const
|
|
15
|
+
const debug_1 = __importDefault(require("debug"));
|
|
16
|
+
const eol_1 = __importDefault(require("eol"));
|
|
17
|
+
const lodash_1 = __importDefault(require("lodash"));
|
|
18
|
+
const sanitize_html_1 = __importDefault(require("sanitize-html"));
|
|
19
|
+
const superagent_1 = __importDefault(require("superagent"));
|
|
20
|
+
const url_1 = __importDefault(require("url"));
|
|
21
|
+
const querystring_1 = __importDefault(require("querystring"));
|
|
14
22
|
const sdk_core_1 = require("@bitgo-beta/sdk-core");
|
|
15
|
-
const debug = debug_1.default('bitgo:api');
|
|
23
|
+
const debug = (0, debug_1.default)('bitgo:api');
|
|
16
24
|
/**
|
|
17
25
|
* Add the bitgo-specific result() function on a superagent request.
|
|
18
26
|
*
|
|
@@ -31,7 +39,6 @@ function toBitgoRequest(req) {
|
|
|
31
39
|
},
|
|
32
40
|
});
|
|
33
41
|
}
|
|
34
|
-
exports.toBitgoRequest = toBitgoRequest;
|
|
35
42
|
/**
|
|
36
43
|
* Return a function which extracts the specified response body property from the response if successful,
|
|
37
44
|
* otherwise throw an `ApiErrorResponse` parsed from the response body.
|
|
@@ -39,13 +46,17 @@ exports.toBitgoRequest = toBitgoRequest;
|
|
|
39
46
|
*/
|
|
40
47
|
function handleResponseResult(optionalField) {
|
|
41
48
|
return function (res) {
|
|
42
|
-
if (
|
|
43
|
-
return
|
|
49
|
+
if (lodash_1.default.isNumber(res.status) && res.status >= 200 && res.status < 300) {
|
|
50
|
+
return (
|
|
51
|
+
// If there's an optional field and the body is non-nullish with that property, return it;
|
|
52
|
+
// otherwise return the body if available; if not, return the text; and finally fallback to the entire response.
|
|
53
|
+
(optionalField && res.body && res.body[optionalField] !== undefined ? res.body[optionalField] : res.body) ??
|
|
54
|
+
res.text ??
|
|
55
|
+
res);
|
|
44
56
|
}
|
|
45
57
|
throw errFromResponse(res);
|
|
46
58
|
};
|
|
47
59
|
}
|
|
48
|
-
exports.handleResponseResult = handleResponseResult;
|
|
49
60
|
/**
|
|
50
61
|
* Extract relevant information from a successful response (that is, a response with an HTTP status code
|
|
51
62
|
* between 200 and 299), but which resulted in an application specific error and use it to construct and
|
|
@@ -54,12 +65,11 @@ exports.handleResponseResult = handleResponseResult;
|
|
|
54
65
|
* @param res
|
|
55
66
|
*/
|
|
56
67
|
function errFromResponse(res) {
|
|
57
|
-
var _a;
|
|
58
68
|
const message = createResponseErrorString(res);
|
|
59
69
|
const status = res.status;
|
|
60
70
|
const result = res.body;
|
|
61
|
-
const invalidToken =
|
|
62
|
-
const needsOtp =
|
|
71
|
+
const invalidToken = lodash_1.default.has(res.header, 'x-auth-required') && res.header['x-auth-required'] === 'true';
|
|
72
|
+
const needsOtp = res.body?.needsOTP !== undefined;
|
|
63
73
|
return new sdk_core_1.ApiResponseError(message, status, result, invalidToken, needsOtp);
|
|
64
74
|
}
|
|
65
75
|
/**
|
|
@@ -73,16 +83,14 @@ function handleResponseError(e) {
|
|
|
73
83
|
}
|
|
74
84
|
throw e;
|
|
75
85
|
}
|
|
76
|
-
exports.handleResponseError = handleResponseError;
|
|
77
86
|
/**
|
|
78
87
|
* There are many ways a request can fail, and may ways information on that failure can be
|
|
79
88
|
* communicated to the client. This function tries to handle those cases and create a sane error string
|
|
80
89
|
* @param res Response from an HTTP request
|
|
81
90
|
*/
|
|
82
91
|
function createResponseErrorString(res) {
|
|
83
|
-
var _a;
|
|
84
92
|
let errString = res.status.toString(); // at the very least we'll have the status code
|
|
85
|
-
if (
|
|
93
|
+
if (res.body?.error) {
|
|
86
94
|
// this is the case we hope for, where the server gives us a nice error from the JSON body
|
|
87
95
|
errString = res.body.error;
|
|
88
96
|
}
|
|
@@ -90,11 +98,11 @@ function createResponseErrorString(res) {
|
|
|
90
98
|
// if the response came back as text, we try to parse it as HTML and remove all tags, leaving us
|
|
91
99
|
// just the bare text, which we then trim of excessive newlines and limit to a certain length
|
|
92
100
|
try {
|
|
93
|
-
let sanitizedText =
|
|
101
|
+
let sanitizedText = (0, sanitize_html_1.default)(res.text, { allowedTags: [] });
|
|
94
102
|
sanitizedText = sanitizedText.trim();
|
|
95
|
-
sanitizedText =
|
|
96
|
-
sanitizedText =
|
|
97
|
-
sanitizedText =
|
|
103
|
+
sanitizedText = eol_1.default.lf(sanitizedText); // use '\n' for all newlines
|
|
104
|
+
sanitizedText = lodash_1.default.replace(sanitizedText, /\n[ |\t]{1,}\n/g, '\n\n'); // remove the spaces/tabs between newlines
|
|
105
|
+
sanitizedText = lodash_1.default.replace(sanitizedText, /[\n]{3,}/g, '\n\n'); // have at most 2 consecutive newlines
|
|
98
106
|
sanitizedText = sanitizedText.substring(0, 5000); // prevent message from getting too large
|
|
99
107
|
errString = errString + '\n' + sanitizedText; // add it to our existing errString (at this point the more info the better!)
|
|
100
108
|
}
|
|
@@ -118,9 +126,9 @@ function serializeRequestData(req) {
|
|
|
118
126
|
if (contentType) {
|
|
119
127
|
contentType = contentType.split(';')[0];
|
|
120
128
|
}
|
|
121
|
-
let serialize =
|
|
129
|
+
let serialize = superagent_1.default.serialize[contentType];
|
|
122
130
|
if (!serialize && /[\/+]json\b/.test(contentType)) {
|
|
123
|
-
serialize =
|
|
131
|
+
serialize = superagent_1.default.serialize['application/json'];
|
|
124
132
|
}
|
|
125
133
|
if (serialize) {
|
|
126
134
|
data = serialize(data);
|
|
@@ -129,13 +137,12 @@ function serializeRequestData(req) {
|
|
|
129
137
|
}
|
|
130
138
|
}
|
|
131
139
|
}
|
|
132
|
-
exports.serializeRequestData = serializeRequestData;
|
|
133
140
|
/**
|
|
134
141
|
* Set the superagent query string correctly for browsers or node.
|
|
135
142
|
* @param req
|
|
136
143
|
*/
|
|
137
144
|
function setRequestQueryString(req) {
|
|
138
|
-
const urlDetails =
|
|
145
|
+
const urlDetails = url_1.default.parse(req.url);
|
|
139
146
|
let queryString;
|
|
140
147
|
const query = req._query;
|
|
141
148
|
const qs = req.qs;
|
|
@@ -146,7 +153,7 @@ function setRequestQueryString(req) {
|
|
|
146
153
|
}
|
|
147
154
|
else if (qs) {
|
|
148
155
|
// node version
|
|
149
|
-
queryString =
|
|
156
|
+
queryString = querystring_1.default.stringify(qs);
|
|
150
157
|
req.qs = null;
|
|
151
158
|
}
|
|
152
159
|
if (queryString) {
|
|
@@ -156,15 +163,14 @@ function setRequestQueryString(req) {
|
|
|
156
163
|
else {
|
|
157
164
|
urlDetails.search = '?' + queryString;
|
|
158
165
|
}
|
|
159
|
-
req.url =
|
|
166
|
+
req.url = url_1.default.format(urlDetails);
|
|
160
167
|
}
|
|
161
168
|
}
|
|
162
|
-
exports.setRequestQueryString = setRequestQueryString;
|
|
163
169
|
/**
|
|
164
170
|
* Verify that the response received from the server is signed correctly.
|
|
165
171
|
* Right now, it is very permissive with the timestamp variance.
|
|
166
172
|
*/
|
|
167
|
-
function verifyResponse(bitgo, token, method, req, response) {
|
|
173
|
+
function verifyResponse(bitgo, token, method, req, response, authVersion) {
|
|
168
174
|
// we can't verify the response if we're not authenticated
|
|
169
175
|
if (!req.isV2Authenticated || !req.authenticationToken) {
|
|
170
176
|
return response;
|
|
@@ -177,6 +183,7 @@ function verifyResponse(bitgo, token, method, req, response) {
|
|
|
177
183
|
timestamp: response.header.timestamp,
|
|
178
184
|
token: req.authenticationToken,
|
|
179
185
|
method,
|
|
186
|
+
authVersion,
|
|
180
187
|
});
|
|
181
188
|
if (!verificationResponse.isValid) {
|
|
182
189
|
// calculate the HMAC
|
|
@@ -205,5 +212,4 @@ function verifyResponse(bitgo, token, method, req, response) {
|
|
|
205
212
|
}
|
|
206
213
|
return response;
|
|
207
214
|
}
|
|
208
|
-
exports.verifyResponse = verifyResponse;
|
|
209
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api.js","sourceRoot":"","sources":["../../src/api.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @prettier\n */\nimport Debug from 'debug';\nimport * as eol from 'eol';\nimport * as _ from 'lodash';\nimport * as sanitizeHtml from 'sanitize-html';\nimport * as superagent from 'superagent';\nimport * as urlLib from 'url';\nimport * as querystring from 'querystring';\n\nimport { ApiResponseError, BitGoRequest } from '@bitgo-beta/sdk-core';\n\nimport { VerifyResponseOptions } from './types';\nimport { BitGoAPI } from './bitgoAPI';\n\nconst debug = Debug('bitgo:api');\n\n/**\n * Add the bitgo-specific result() function on a superagent request.\n *\n * If the server response is successful, the `result()` function will return either the entire response body,\n * or the field from the response body specified by the `optionalField` parameter if it is provided.\n *\n * If the server response with an error, `result()` will handle HTTP errors appropriately by\n * rethrowing them as an `ApiResponseError` if possible, and otherwise rethrowing the underlying response error.\n *\n * @param req\n */\nexport function toBitgoRequest<ResponseResultType = any>(\n  req: superagent.SuperAgentRequest\n): BitGoRequest<ResponseResultType> {\n  return Object.assign(req, {\n    result(optionalField?: string) {\n      return req.then(\n        (response) => handleResponseResult<ResponseResultType>(optionalField)(response),\n        (error) => handleResponseError(error)\n      );\n    },\n  });\n}\n\n/**\n * Return a function which extracts the specified response body property from the response if successful,\n * otherwise throw an `ApiErrorResponse` parsed from the response body.\n * @param optionalField\n */\nexport function handleResponseResult<ResponseResultType>(\n  optionalField?: string\n): (res: superagent.Response) => ResponseResultType {\n  return function (res: superagent.Response): ResponseResultType {\n    if (_.isNumber(res.status) && res.status >= 200 && res.status < 300) {\n      return optionalField ? res.body[optionalField] : res.body;\n    }\n    throw errFromResponse(res);\n  };\n}\n\n/**\n * Extract relevant information from a successful response (that is, a response with an HTTP status code\n * between 200 and 299), but which resulted in an application specific error and use it to construct and\n * throw an `ApiErrorResponse`.\n *\n * @param res\n */\nfunction errFromResponse<ResponseBodyType>(res: superagent.Response): ApiResponseError {\n  const message = createResponseErrorString(res);\n  const status = res.status;\n  const result = res.body as ResponseBodyType;\n  const invalidToken = _.has(res.header, 'x-auth-required') && res.header['x-auth-required'] === 'true';\n  const needsOtp = res.body?.needsOTP !== undefined;\n  return new ApiResponseError(message, status, result, invalidToken, needsOtp);\n}\n\n/**\n * Handle an error or an error containing an HTTP response and use it to throw a well-formed error object.\n *\n * @param e\n */\nexport function handleResponseError(e: Error & { response?: superagent.Response }): never {\n  if (e.response) {\n    throw errFromResponse(e.response);\n  }\n  throw e;\n}\n\n/**\n * There are many ways a request can fail, and may ways information on that failure can be\n * communicated to the client. This function tries to handle those cases and create a sane error string\n * @param res Response from an HTTP request\n */\nfunction createResponseErrorString(res: superagent.Response): string {\n  let errString = res.status.toString(); // at the very least we'll have the status code\n  if (res.body?.error) {\n    // this is the case we hope for, where the server gives us a nice error from the JSON body\n    errString = res.body.error;\n  } else if (res.text) {\n    // if the response came back as text, we try to parse it as HTML and remove all tags, leaving us\n    // just the bare text, which we then trim of excessive newlines and limit to a certain length\n    try {\n      let sanitizedText = sanitizeHtml(res.text, { allowedTags: [] });\n      sanitizedText = sanitizedText.trim();\n      sanitizedText = eol.lf(sanitizedText); // use '\\n' for all newlines\n      sanitizedText = _.replace(sanitizedText, /\\n[ |\\t]{1,}\\n/g, '\\n\\n'); // remove the spaces/tabs between newlines\n      sanitizedText = _.replace(sanitizedText, /[\\n]{3,}/g, '\\n\\n'); // have at most 2 consecutive newlines\n      sanitizedText = sanitizedText.substring(0, 5000); // prevent message from getting too large\n      errString = errString + '\\n' + sanitizedText; // add it to our existing errString (at this point the more info the better!)\n    } catch (e) {\n      // do nothing, the response's HTML was too wacky to be parsed cleanly\n      debug('got error with message \"%s\" while creating response error string from response: %s', e.message, res.text);\n    }\n  }\n\n  return errString;\n}\n\n/**\n * Serialize request data based on the request content type\n * Note: Not sure this is still needed or even useful. Consider removing.\n * @param req\n */\nexport function serializeRequestData(req: superagent.Request): string | undefined {\n  let data: string | Record<string, unknown> = (req as any)._data;\n  if (typeof data !== 'string') {\n    let contentType = req.get('Content-Type');\n    // Parse out just the content type from the header (ignore the charset)\n    if (contentType) {\n      contentType = contentType.split(';')[0];\n    }\n    let serialize = superagent.serialize[contentType];\n    if (!serialize && /[\\/+]json\\b/.test(contentType)) {\n      serialize = superagent.serialize['application/json'];\n    }\n    if (serialize) {\n      data = serialize(data);\n      (req as any)._data = data;\n      return data;\n    }\n  }\n}\n\n/**\n * Set the superagent query string correctly for browsers or node.\n * @param req\n */\nexport function setRequestQueryString(req: superagent.SuperAgentRequest): void {\n  const urlDetails = urlLib.parse(req.url);\n\n  let queryString: string | undefined;\n  const query: string[] = (req as any)._query;\n  const qs: { [key: string]: string } = (req as any).qs;\n  if (query && query.length > 0) {\n    // browser version\n    queryString = query.join('&');\n    (req as any)._query = [];\n  } else if (qs) {\n    // node version\n    queryString = querystring.stringify(qs);\n    (req as any).qs = null;\n  }\n\n  if (queryString) {\n    if (urlDetails.search) {\n      urlDetails.search += '&' + queryString;\n    } else {\n      urlDetails.search = '?' + queryString;\n    }\n    req.url = urlLib.format(urlDetails);\n  }\n}\n\n/**\n * Verify that the response received from the server is signed correctly.\n * Right now, it is very permissive with the timestamp variance.\n */\nexport function verifyResponse(\n  bitgo: BitGoAPI,\n  token: string | undefined,\n  method: VerifyResponseOptions['method'],\n  req: superagent.SuperAgentRequest,\n  response: superagent.Response\n): superagent.Response {\n  // we can't verify the response if we're not authenticated\n  if (!req.isV2Authenticated || !req.authenticationToken) {\n    return response;\n  }\n\n  const verificationResponse = bitgo.verifyResponse({\n    url: req.url,\n    hmac: response.header.hmac,\n    statusCode: response.status,\n    text: response.text,\n    timestamp: response.header.timestamp,\n    token: req.authenticationToken,\n    method,\n  });\n\n  if (!verificationResponse.isValid) {\n    // calculate the HMAC\n    const receivedHmac = response.header.hmac;\n    const expectedHmac = verificationResponse.expectedHmac;\n    const signatureSubject = verificationResponse.signatureSubject;\n    // Log only the first 10 characters of the token to ensure the full token isn't logged.\n    const partialBitgoToken = token ? token.substring(0, 10) : '';\n    const errorDetails = {\n      expectedHmac,\n      receivedHmac,\n      hmacInput: signatureSubject,\n      requestToken: req.authenticationToken,\n      bitgoToken: partialBitgoToken,\n    };\n    debug('Invalid response HMAC: %O', errorDetails);\n    throw new ApiResponseError('invalid response HMAC, possible man-in-the-middle-attack', 511, errorDetails);\n  }\n\n  if (bitgo.getAuthVersion() === 3 && !verificationResponse.isInResponseValidityWindow) {\n    const errorDetails = {\n      timestamp: response.header.timestamp,\n      verificationTime: verificationResponse.verificationTime,\n    };\n    debug('Server response outside response validity time window: %O', errorDetails);\n    throw new ApiResponseError(\n      'server response outside response validity time window, possible man-in-the-middle-attack',\n      511,\n      errorDetails\n    );\n  }\n  return response;\n}\n"]}
|
|
215
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api.js","sourceRoot":"","sources":["../../src/api.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @prettier\n */\nimport Debug from 'debug';\nimport eol from 'eol';\nimport _ from 'lodash';\nimport sanitizeHtml from 'sanitize-html';\nimport superagent from 'superagent';\nimport urlLib from 'url';\nimport querystring from 'querystring';\n\nimport { ApiResponseError, BitGoRequest } from '@bitgo-beta/sdk-core';\n\nimport { AuthVersion, VerifyResponseOptions } from './types';\nimport { BitGoAPI } from './bitgoAPI';\n\nconst debug = Debug('bitgo:api');\n\n/**\n * Add the bitgo-specific result() function on a superagent request.\n *\n * If the server response is successful, the `result()` function will return either the entire response body,\n * or the field from the response body specified by the `optionalField` parameter if it is provided.\n *\n * If the server response with an error, `result()` will handle HTTP errors appropriately by\n * rethrowing them as an `ApiResponseError` if possible, and otherwise rethrowing the underlying response error.\n *\n * @param req\n */\nexport function toBitgoRequest<ResponseResultType = any>(\n  req: superagent.SuperAgentRequest\n): BitGoRequest<ResponseResultType> {\n  return Object.assign(req, {\n    result(optionalField?: string) {\n      return req.then(\n        (response) => handleResponseResult<ResponseResultType>(optionalField)(response),\n        (error) => handleResponseError(error)\n      );\n    },\n  });\n}\n\n/**\n * Return a function which extracts the specified response body property from the response if successful,\n * otherwise throw an `ApiErrorResponse` parsed from the response body.\n * @param optionalField\n */\nexport function handleResponseResult<ResponseResultType>(\n  optionalField?: string\n): (res: superagent.Response) => ResponseResultType {\n  return function (res: superagent.Response): ResponseResultType {\n    if (_.isNumber(res.status) && res.status >= 200 && res.status < 300) {\n      return (\n        // If there's an optional field and the body is non-nullish with that property, return it;\n        // otherwise return the body if available; if not, return the text; and finally fallback to the entire response.\n        (optionalField && res.body && res.body[optionalField] !== undefined ? res.body[optionalField] : res.body) ??\n        res.text ??\n        res\n      );\n    }\n    throw errFromResponse(res);\n  };\n}\n\n/**\n * Extract relevant information from a successful response (that is, a response with an HTTP status code\n * between 200 and 299), but which resulted in an application specific error and use it to construct and\n * throw an `ApiErrorResponse`.\n *\n * @param res\n */\nfunction errFromResponse<ResponseBodyType>(res: superagent.Response): ApiResponseError {\n  const message = createResponseErrorString(res);\n  const status = res.status;\n  const result = res.body as ResponseBodyType;\n  const invalidToken = _.has(res.header, 'x-auth-required') && res.header['x-auth-required'] === 'true';\n  const needsOtp = res.body?.needsOTP !== undefined;\n  return new ApiResponseError(message, status, result, invalidToken, needsOtp);\n}\n\n/**\n * Handle an error or an error containing an HTTP response and use it to throw a well-formed error object.\n *\n * @param e\n */\nexport function handleResponseError(e: Error & { response?: superagent.Response }): never {\n  if (e.response) {\n    throw errFromResponse(e.response);\n  }\n  throw e;\n}\n\n/**\n * There are many ways a request can fail, and may ways information on that failure can be\n * communicated to the client. This function tries to handle those cases and create a sane error string\n * @param res Response from an HTTP request\n */\nfunction createResponseErrorString(res: superagent.Response): string {\n  let errString = res.status.toString(); // at the very least we'll have the status code\n  if (res.body?.error) {\n    // this is the case we hope for, where the server gives us a nice error from the JSON body\n    errString = res.body.error;\n  } else if (res.text) {\n    // if the response came back as text, we try to parse it as HTML and remove all tags, leaving us\n    // just the bare text, which we then trim of excessive newlines and limit to a certain length\n    try {\n      let sanitizedText = sanitizeHtml(res.text, { allowedTags: [] });\n      sanitizedText = sanitizedText.trim();\n      sanitizedText = eol.lf(sanitizedText); // use '\\n' for all newlines\n      sanitizedText = _.replace(sanitizedText, /\\n[ |\\t]{1,}\\n/g, '\\n\\n'); // remove the spaces/tabs between newlines\n      sanitizedText = _.replace(sanitizedText, /[\\n]{3,}/g, '\\n\\n'); // have at most 2 consecutive newlines\n      sanitizedText = sanitizedText.substring(0, 5000); // prevent message from getting too large\n      errString = errString + '\\n' + sanitizedText; // add it to our existing errString (at this point the more info the better!)\n    } catch (e) {\n      // do nothing, the response's HTML was too wacky to be parsed cleanly\n      debug('got error with message \"%s\" while creating response error string from response: %s', e.message, res.text);\n    }\n  }\n\n  return errString;\n}\n\n/**\n * Serialize request data based on the request content type\n * Note: Not sure this is still needed or even useful. Consider removing.\n * @param req\n */\nexport function serializeRequestData(req: superagent.Request): string | undefined {\n  let data: string | Record<string, unknown> = (req as any)._data;\n  if (typeof data !== 'string') {\n    let contentType = req.get('Content-Type');\n    // Parse out just the content type from the header (ignore the charset)\n    if (contentType) {\n      contentType = contentType.split(';')[0];\n    }\n    let serialize = superagent.serialize[contentType];\n    if (!serialize && /[\\/+]json\\b/.test(contentType)) {\n      serialize = superagent.serialize['application/json'];\n    }\n    if (serialize) {\n      data = serialize(data);\n      (req as any)._data = data;\n      return data;\n    }\n  }\n}\n\n/**\n * Set the superagent query string correctly for browsers or node.\n * @param req\n */\nexport function setRequestQueryString(req: superagent.SuperAgentRequest): void {\n  const urlDetails = urlLib.parse(req.url);\n\n  let queryString: string | undefined;\n  const query: string[] = (req as any)._query;\n  const qs: { [key: string]: string } = (req as any).qs;\n  if (query && query.length > 0) {\n    // browser version\n    queryString = query.join('&');\n    (req as any)._query = [];\n  } else if (qs) {\n    // node version\n    queryString = querystring.stringify(qs);\n    (req as any).qs = null;\n  }\n\n  if (queryString) {\n    if (urlDetails.search) {\n      urlDetails.search += '&' + queryString;\n    } else {\n      urlDetails.search = '?' + queryString;\n    }\n    req.url = urlLib.format(urlDetails);\n  }\n}\n\n/**\n * Verify that the response received from the server is signed correctly.\n * Right now, it is very permissive with the timestamp variance.\n */\nexport function verifyResponse(\n  bitgo: BitGoAPI,\n  token: string | undefined,\n  method: VerifyResponseOptions['method'],\n  req: superagent.SuperAgentRequest,\n  response: superagent.Response,\n  authVersion: AuthVersion\n): superagent.Response {\n  // we can't verify the response if we're not authenticated\n  if (!req.isV2Authenticated || !req.authenticationToken) {\n    return response;\n  }\n\n  const verificationResponse = bitgo.verifyResponse({\n    url: req.url,\n    hmac: response.header.hmac,\n    statusCode: response.status,\n    text: response.text,\n    timestamp: response.header.timestamp,\n    token: req.authenticationToken,\n    method,\n    authVersion,\n  });\n\n  if (!verificationResponse.isValid) {\n    // calculate the HMAC\n    const receivedHmac = response.header.hmac;\n    const expectedHmac = verificationResponse.expectedHmac;\n    const signatureSubject = verificationResponse.signatureSubject;\n    // Log only the first 10 characters of the token to ensure the full token isn't logged.\n    const partialBitgoToken = token ? token.substring(0, 10) : '';\n    const errorDetails = {\n      expectedHmac,\n      receivedHmac,\n      hmacInput: signatureSubject,\n      requestToken: req.authenticationToken,\n      bitgoToken: partialBitgoToken,\n    };\n    debug('Invalid response HMAC: %O', errorDetails);\n    throw new ApiResponseError('invalid response HMAC, possible man-in-the-middle-attack', 511, errorDetails);\n  }\n\n  if (bitgo.getAuthVersion() === 3 && !verificationResponse.isInResponseValidityWindow) {\n    const errorDetails = {\n      timestamp: response.header.timestamp,\n      verificationTime: verificationResponse.verificationTime,\n    };\n    debug('Server response outside response validity time window: %O', errorDetails);\n    throw new ApiResponseError(\n      'server response outside response validity time window, possible man-in-the-middle-attack',\n      511,\n      errorDetails\n    );\n  }\n  return response;\n}\n"]}
|
package/dist/src/bitgoAPI.d.ts
CHANGED
|
@@ -1,8 +1,7 @@
|
|
|
1
|
+
import { BaseCoin, BitGoBase, BitGoRequest, CoinConstructor, DecryptKeysOptions, DecryptOptions, EcdhDerivedKeypair, EncryptOptions, EnvironmentName, GetSharingKeyOptions, GetSigningKeyApi, IRequestTracer } from '@bitgo-beta/sdk-core';
|
|
1
2
|
import { ECPairInterface } from '@bitgo-beta/utxo-lib';
|
|
2
3
|
import * as superagent from 'superagent';
|
|
3
|
-
import {
|
|
4
|
-
import { AccessTokenOptions, AddAccessTokenResponse, AddAccessTokenOptions, AuthenticateOptions, AuthenticateWithAuthCodeOptions, BitGoAPIOptions, BitGoJson, BitGoSimulateWebhookOptions, CalculateHmacSubjectOptions, CalculateRequestHeadersOptions, CalculateRequestHmacOptions, ChangePasswordOptions, DeprecatedVerifyAddressOptions, EstimateFeeOptions, ExtendTokenOptions, GetEcdhSecretOptions, GetUserOptions, ListWebhookNotificationsOptions, PingOptions, ProcessedAuthenticationOptions, ReconstitutedSecret, ReconstituteSecretOptions, RegisterPushTokenOptions, RemoveAccessTokenOptions, RequestHeaders, SplitSecret, SplitSecretOptions, TokenIssuance, TokenIssuanceResponse, UnlockOptions, User, VerifyPasswordOptions, VerifyPushTokenOptions, VerifyResponseInfo, VerifyResponseOptions, VerifyShardsOptions, WebhookOptions } from './types';
|
|
5
|
-
declare const patchedRequestMethods: readonly ["get", "post", "put", "del", "patch"];
|
|
4
|
+
import { AccessTokenOptions, AddAccessTokenOptions, AddAccessTokenResponse, AuthenticateOptions, AuthenticateWithAuthCodeOptions, BitGoAPIOptions, BitGoJson, BitGoSimulateWebhookOptions, CalculateHmacSubjectOptions, CalculateRequestHeadersOptions, CalculateRequestHmacOptions, ChangePasswordOptions, DeprecatedVerifyAddressOptions, EstimateFeeOptions, ExtendTokenOptions, GetEcdhSecretOptions, GetUserOptions, ListWebhookNotificationsOptions, LoginResponse, PingOptions, ProcessedAuthenticationOptions, ReconstitutedSecret, ReconstituteSecretOptions, RegisterPushTokenOptions, RemoveAccessTokenOptions, RequestHeaders, RequestMethods, SplitSecret, SplitSecretOptions, TokenIssuance, TokenIssuanceResponse, UnlockOptions, User, VerifyPasswordOptions, VerifyPushTokenOptions, VerifyResponseInfo, VerifyResponseOptions, VerifyShardsOptions, WebhookOptions } from './types';
|
|
6
5
|
export declare class BitGoAPI implements BitGoBase {
|
|
7
6
|
protected _keychains: any;
|
|
8
7
|
protected _wallets: any;
|
|
@@ -17,6 +16,7 @@ export declare class BitGoAPI implements BitGoBase {
|
|
|
17
16
|
protected readonly _baseUrl: string;
|
|
18
17
|
protected readonly _baseApiUrl: string;
|
|
19
18
|
protected readonly _baseApiUrlV2: string;
|
|
19
|
+
protected readonly _baseApiUrlV3: string;
|
|
20
20
|
protected readonly _env: EnvironmentName;
|
|
21
21
|
protected readonly _authVersion: Exclude<BitGoAPIOptions['authVersion'], undefined>;
|
|
22
22
|
protected _hmacVerification: boolean;
|
|
@@ -33,13 +33,15 @@ export declare class BitGoAPI implements BitGoBase {
|
|
|
33
33
|
protected readonly _clientSecret?: string;
|
|
34
34
|
protected _validate: boolean;
|
|
35
35
|
readonly cookiesPropagationEnabled: boolean;
|
|
36
|
+
private _customProxyAgent?;
|
|
37
|
+
private getAdditionalHeadersCb?;
|
|
36
38
|
constructor(params?: BitGoAPIOptions);
|
|
37
39
|
/**
|
|
38
40
|
* Get a superagent request for specified http method and URL configured to the SDK configuration
|
|
39
41
|
* @param method - http method for the new request
|
|
40
42
|
* @param url - URL for the new request
|
|
41
43
|
*/
|
|
42
|
-
protected getAgentRequest(method:
|
|
44
|
+
protected getAgentRequest(method: RequestMethods, url: string): superagent.SuperAgentRequest;
|
|
43
45
|
/**
|
|
44
46
|
* Create a basecoin object
|
|
45
47
|
* @param name
|
|
@@ -64,6 +66,7 @@ export declare class BitGoAPI implements BitGoBase {
|
|
|
64
66
|
put(url: string): BitGoRequest;
|
|
65
67
|
del(url: string): BitGoRequest;
|
|
66
68
|
patch(url: string): BitGoRequest;
|
|
69
|
+
options(url: string): BitGoRequest;
|
|
67
70
|
/**
|
|
68
71
|
* Calculate the HMAC for the given key and message
|
|
69
72
|
* @param key {String} - the key to use for the HMAC
|
|
@@ -80,19 +83,19 @@ export declare class BitGoAPI implements BitGoBase {
|
|
|
80
83
|
* @param method request method
|
|
81
84
|
* @returns {string}
|
|
82
85
|
*/
|
|
83
|
-
calculateHMACSubject(
|
|
86
|
+
calculateHMACSubject(params: CalculateHmacSubjectOptions): string;
|
|
84
87
|
/**
|
|
85
88
|
* Calculate the HMAC for an HTTP request
|
|
86
89
|
*/
|
|
87
|
-
calculateRequestHMAC(
|
|
90
|
+
calculateRequestHMAC(params: CalculateRequestHmacOptions): string;
|
|
88
91
|
/**
|
|
89
92
|
* Calculate request headers with HMAC
|
|
90
93
|
*/
|
|
91
|
-
calculateRequestHeaders(
|
|
94
|
+
calculateRequestHeaders(params: CalculateRequestHeadersOptions): RequestHeaders;
|
|
92
95
|
/**
|
|
93
96
|
* Verify the HMAC for an HTTP response
|
|
94
97
|
*/
|
|
95
|
-
verifyResponse(
|
|
98
|
+
verifyResponse(params: VerifyResponseOptions): VerifyResponseInfo;
|
|
96
99
|
/**
|
|
97
100
|
* Fetch useful constant values from the BitGo server.
|
|
98
101
|
* These values do change infrequently, so they need to be fetched,
|
|
@@ -131,6 +134,14 @@ export declare class BitGoAPI implements BitGoBase {
|
|
|
131
134
|
* Decrypt an encrypted string locally.
|
|
132
135
|
*/
|
|
133
136
|
decrypt(params: DecryptOptions): string;
|
|
137
|
+
/**
|
|
138
|
+
* Attempt to decrypt multiple wallet keys with the provided passphrase
|
|
139
|
+
* @param {DecryptKeysOptions} params - Parameters object containing wallet key pairs and password
|
|
140
|
+
* @param {Array<{walletId: string, encryptedPrv: string}>} params.walletIdEncryptedKeyPairs - Array of wallet ID and encrypted private key pairs
|
|
141
|
+
* @param {string} params.password - The passphrase to attempt decryption with
|
|
142
|
+
* @returns {string[]} - Array of wallet IDs for which decryption failed
|
|
143
|
+
*/
|
|
144
|
+
decryptKeys(params: DecryptKeysOptions): string[];
|
|
134
145
|
/**
|
|
135
146
|
* Serialize this BitGo object to a JSON object.
|
|
136
147
|
*
|
|
@@ -154,15 +165,46 @@ export declare class BitGoAPI implements BitGoBase {
|
|
|
154
165
|
* Process the username, password and otp into an object containing the username and hashed password, ready to
|
|
155
166
|
* send to bitgo for authentication.
|
|
156
167
|
*/
|
|
157
|
-
preprocessAuthenticationParams({ username, password, otp, forceSMS, extensible, trust, }: AuthenticateOptions): ProcessedAuthenticationOptions;
|
|
168
|
+
preprocessAuthenticationParams({ username, password, otp, forceSMS, extensible, trust, forReset2FA, initialHash, fingerprintHash, }: AuthenticateOptions): ProcessedAuthenticationOptions;
|
|
169
|
+
/**
|
|
170
|
+
* Validate the passkey response is in the expected format
|
|
171
|
+
* Should be as is returned from navigator.credentials.get()
|
|
172
|
+
*/
|
|
173
|
+
validatePasskeyResponse(passkeyResponse: string): void;
|
|
158
174
|
/**
|
|
159
175
|
* Synchronous method for activating an access token.
|
|
160
176
|
*/
|
|
161
177
|
authenticateWithAccessToken({ accessToken }: AccessTokenOptions): void;
|
|
178
|
+
/**
|
|
179
|
+
* Creates a new ECDH keychain for the user.
|
|
180
|
+
* @param {string} loginPassword - The user's login password.
|
|
181
|
+
* @returns {Promise<any>} - A promise that resolves with the new ECDH keychain data.
|
|
182
|
+
* @throws {Error} - Throws an error if there is an issue creating the keychain.
|
|
183
|
+
*/
|
|
184
|
+
createUserEcdhKeychain(loginPassword: string): Promise<any>;
|
|
185
|
+
/**
|
|
186
|
+
* Updates the user's settings with the provided parameters.
|
|
187
|
+
* @param {Object} params - The parameters to update the user's settings with.
|
|
188
|
+
* @returns {Promise<any>}
|
|
189
|
+
* @throws {Error} - Throws an error if there is an issue updating the user's settings.
|
|
190
|
+
*/
|
|
191
|
+
private updateUserSettings;
|
|
192
|
+
/**
|
|
193
|
+
* Ensures that the user's ECDH keychain is created for wallet sharing and TSS wallets.
|
|
194
|
+
* If the keychain does not exist, it will be created and the user's settings will be updated.
|
|
195
|
+
* @param {string} loginPassword - The user's login password.
|
|
196
|
+
* @returns {Promise<any>} - A promise that resolves with the user's settings ensuring we have the ecdhKeychain in there.
|
|
197
|
+
* @throws {Error} - Throws an error if there is an issue creating the keychain or updating the user's settings.
|
|
198
|
+
*/
|
|
199
|
+
private ensureUserEcdhKeychainIsCreated;
|
|
162
200
|
/**
|
|
163
201
|
* Login to the bitgo platform.
|
|
164
202
|
*/
|
|
165
|
-
authenticate(params: AuthenticateOptions): Promise<any>;
|
|
203
|
+
authenticate(params: AuthenticateOptions): Promise<LoginResponse | any>;
|
|
204
|
+
/**
|
|
205
|
+
* Login to the bitgo platform with passkey.
|
|
206
|
+
*/
|
|
207
|
+
authenticateWithPasskey(passkey: string, initialHash?: string, fingerprintHash?: string): Promise<LoginResponse | any>;
|
|
166
208
|
/**
|
|
167
209
|
*
|
|
168
210
|
* @param responseBody Response body object
|
|
@@ -427,6 +469,12 @@ export declare class BitGoAPI implements BitGoBase {
|
|
|
427
469
|
* Gets the user's private ECDH keychain
|
|
428
470
|
*/
|
|
429
471
|
getECDHKeychain(ecdhKeychainPub?: string): Promise<any>;
|
|
472
|
+
/**
|
|
473
|
+
* Returns the user derived public and private ECDH keypair
|
|
474
|
+
* @param password password to decrypt the user's ECDH encrypted private key
|
|
475
|
+
* @param entId? optional enterprise id to check for permissions
|
|
476
|
+
*/
|
|
477
|
+
getEcdhKeypairPrivate(password: string, entId: string): Promise<EcdhDerivedKeypair>;
|
|
430
478
|
/**
|
|
431
479
|
* @param params
|
|
432
480
|
* - operatingSystem: one of ios, android
|
|
@@ -539,6 +587,11 @@ export declare class BitGoAPI implements BitGoBase {
|
|
|
539
587
|
* @return {Object} The client constants object
|
|
540
588
|
*/
|
|
541
589
|
getConstants(): any;
|
|
590
|
+
/**
|
|
591
|
+
* Execute an asset request which does not need HMAC validation
|
|
592
|
+
* @param url The URL for the asset request
|
|
593
|
+
* @returns {Promise<any>} The response body
|
|
594
|
+
*/
|
|
595
|
+
protected executeAssetRequest(url: string): Promise<any>;
|
|
542
596
|
}
|
|
543
|
-
export {};
|
|
544
597
|
//# sourceMappingURL=bitgoAPI.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"bitgoAPI.d.ts","sourceRoot":"","sources":["../../src/bitgoAPI.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"bitgoAPI.d.ts","sourceRoot":"","sources":["../../src/bitgoAPI.ts"],"names":[],"mappings":"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"}
|