@bitgo-beta/sdk-core 8.2.1-beta.1135 → 8.2.1-beta.1136
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/dist/src/bitgo/index.d.ts +1 -0
- package/dist/src/bitgo/index.d.ts.map +1 -1
- package/dist/src/bitgo/index.js +3 -2
- package/dist/src/bitgo/walletUtil/index.d.ts +2 -0
- package/dist/src/bitgo/walletUtil/index.d.ts.map +1 -0
- package/dist/src/bitgo/walletUtil/index.js +18 -0
- package/dist/src/bitgo/walletUtil/utxoMessageProof.d.ts +37 -0
- package/dist/src/bitgo/walletUtil/utxoMessageProof.d.ts.map +1 -0
- package/dist/src/bitgo/walletUtil/utxoMessageProof.js +122 -0
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +9 -9
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/bitgo/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,WAAW,MAAM,WAAW,CAAC;AACzC,OAAO,KAAK,GAAG,MAAM,OAAO,CAAC;AAE7B,cAAc,YAAY,CAAC;AAC3B,cAAc,aAAa,CAAC;AAC5B,cAAc,WAAW,CAAC;AAC1B,cAAc,aAAa,CAAC;AAC5B,cAAc,UAAU,CAAC;AACzB,cAAc,eAAe,CAAC;AAC9B,cAAc,QAAQ,CAAC;AACvB,cAAc,cAAc,CAAC;AAC7B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,UAAU,CAAC;AACzB,cAAc,sBAAsB,CAAC;AACrC,cAAc,YAAY,CAAC;AAC3B,cAAc,YAAY,CAAC;AAC3B,OAAO,KAAK,OAAO,MAAM,iBAAiB,CAAC;AAC3C,cAAc,UAAU,CAAC;AACzB,cAAc,mBAAmB,CAAC;AAClC,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AACxC,cAAc,YAAY,CAAC;AAC3B,cAAc,WAAW,CAAC;AAC1B,cAAc,WAAW,CAAC;AAC1B,cAAc,OAAO,CAAC;AACtB,OAAO,EAAE,kBAAkB,EAAE,MAAM,OAAO,CAAC;AAC3C,cAAc,SAAS,CAAC;AACxB,cAAc,SAAS,CAAC;AACxB,cAAc,UAAU,CAAC;AACzB,cAAc,WAAW,CAAC;AAC1B,OAAO,EAAE,WAAW,EAAE,CAAC;AACvB,OAAO,EAAE,GAAG,EAAE,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/bitgo/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,WAAW,MAAM,WAAW,CAAC;AACzC,OAAO,KAAK,GAAG,MAAM,OAAO,CAAC;AAE7B,OAAO,KAAK,UAAU,MAAM,cAAc,CAAC;AAC3C,cAAc,YAAY,CAAC;AAC3B,cAAc,aAAa,CAAC;AAC5B,cAAc,WAAW,CAAC;AAC1B,cAAc,aAAa,CAAC;AAC5B,cAAc,UAAU,CAAC;AACzB,cAAc,eAAe,CAAC;AAC9B,cAAc,QAAQ,CAAC;AACvB,cAAc,cAAc,CAAC;AAC7B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,UAAU,CAAC;AACzB,cAAc,sBAAsB,CAAC;AACrC,cAAc,YAAY,CAAC;AAC3B,cAAc,YAAY,CAAC;AAC3B,OAAO,KAAK,OAAO,MAAM,iBAAiB,CAAC;AAC3C,cAAc,UAAU,CAAC;AACzB,cAAc,mBAAmB,CAAC;AAClC,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AACxC,cAAc,YAAY,CAAC;AAC3B,cAAc,WAAW,CAAC;AAC1B,cAAc,WAAW,CAAC;AAC1B,cAAc,OAAO,CAAC;AACtB,OAAO,EAAE,kBAAkB,EAAE,MAAM,OAAO,CAAC;AAC3C,cAAc,SAAS,CAAC;AACxB,cAAc,SAAS,CAAC;AACxB,cAAc,UAAU,CAAC;AACzB,cAAc,WAAW,CAAC;AAC1B,OAAO,EAAE,WAAW,EAAE,CAAC;AACvB,OAAO,EAAE,GAAG,EAAE,CAAC"}
|
package/dist/src/bitgo/index.js
CHANGED
|
@@ -36,11 +36,12 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
36
36
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
37
37
|
};
|
|
38
38
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
|
-
exports.tss = exports.bitcoinUtil = exports.sendSignatureShare = exports.WalletProofs = exports.bitcoin = void 0;
|
|
39
|
+
exports.tss = exports.bitcoinUtil = exports.sendSignatureShare = exports.WalletProofs = exports.bitcoin = exports.walletUtil = void 0;
|
|
40
40
|
const bitcoinUtil = __importStar(require("./bitcoin"));
|
|
41
41
|
exports.bitcoinUtil = bitcoinUtil;
|
|
42
42
|
const tss = __importStar(require("./tss"));
|
|
43
43
|
exports.tss = tss;
|
|
44
|
+
exports.walletUtil = __importStar(require("./walletUtil"));
|
|
44
45
|
__exportStar(require("./baseCoin"), exports);
|
|
45
46
|
__exportStar(require("./bip32util"), exports);
|
|
46
47
|
__exportStar(require("./bitcoin"), exports);
|
|
@@ -69,4 +70,4 @@ __exportStar(require("./types"), exports);
|
|
|
69
70
|
__exportStar(require("./utils"), exports);
|
|
70
71
|
__exportStar(require("./wallet"), exports);
|
|
71
72
|
__exportStar(require("./webhook"), exports);
|
|
72
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
73
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYml0Z28vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsdURBQXlDO0FBOEJoQyxrQ0FBVztBQTdCcEIsMkNBQTZCO0FBOEJwQixrQkFBRztBQTVCWiwyREFBMkM7QUFDM0MsNkNBQTJCO0FBQzNCLDhDQUE0QjtBQUM1Qiw0Q0FBMEI7QUFDMUIsOENBQTRCO0FBQzVCLDJDQUF5QjtBQUN6QixnREFBOEI7QUFDOUIseUNBQXVCO0FBQ3ZCLCtDQUE2QjtBQUM3QixpREFBK0I7QUFDL0IsMkNBQXlCO0FBQ3pCLHVEQUFxQztBQUNyQyw2Q0FBMkI7QUFDM0IsNkNBQTJCO0FBQzNCLDJEQUEyQztBQUMzQywyQ0FBeUI7QUFDekIsb0RBQWtDO0FBQ2xDLG1DQUF3QztBQUEvQixzR0FBQSxZQUFZLE9BQUE7QUFDckIsNkNBQTJCO0FBQzNCLDRDQUEwQjtBQUMxQiw0Q0FBMEI7QUFDMUIsd0NBQXNCO0FBQ3RCLDZCQUEyQztBQUFsQyx5R0FBQSxrQkFBa0IsT0FBQTtBQUMzQiwwQ0FBd0I7QUFDeEIsMENBQXdCO0FBQ3hCLDJDQUF5QjtBQUN6Qiw0Q0FBMEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBiaXRjb2luVXRpbCBmcm9tICcuL2JpdGNvaW4nO1xuaW1wb3J0ICogYXMgdHNzIGZyb20gJy4vdHNzJztcblxuZXhwb3J0ICogYXMgd2FsbGV0VXRpbCBmcm9tICcuL3dhbGxldFV0aWwnO1xuZXhwb3J0ICogZnJvbSAnLi9iYXNlQ29pbic7XG5leHBvcnQgKiBmcm9tICcuL2JpcDMydXRpbCc7XG5leHBvcnQgKiBmcm9tICcuL2JpdGNvaW4nO1xuZXhwb3J0ICogZnJvbSAnLi9iaXRnb0Jhc2UnO1xuZXhwb3J0ICogZnJvbSAnLi9jb25maWcnO1xuZXhwb3J0ICogZnJvbSAnLi9jb2luRmFjdG9yeSc7XG5leHBvcnQgKiBmcm9tICcuL2VjZGgnO1xuZXhwb3J0ICogZnJvbSAnLi9lbnRlcnByaXNlJztcbmV4cG9ydCAqIGZyb20gJy4vZW52aXJvbm1lbnRzJztcbmV4cG9ydCAqIGZyb20gJy4vZXJyb3JzJztcbmV4cG9ydCAqIGZyb20gJy4vaW5zY3JpcHRpb25CdWlsZGVyJztcbmV4cG9ydCAqIGZyb20gJy4vaW50ZXJuYWwnO1xuZXhwb3J0ICogZnJvbSAnLi9rZXljaGFpbic7XG5leHBvcnQgKiBhcyBiaXRjb2luIGZyb20gJy4vbGVnYWN5Qml0Y29pbic7XG5leHBvcnQgKiBmcm9tICcuL21hcmtldCc7XG5leHBvcnQgKiBmcm9tICcuL3BlbmRpbmdBcHByb3ZhbCc7XG5leHBvcnQgeyBXYWxsZXRQcm9vZnMgfSBmcm9tICcuL3Byb29mcyc7XG5leHBvcnQgKiBmcm9tICcuL3JlY292ZXJ5JztcbmV4cG9ydCAqIGZyb20gJy4vc3Rha2luZyc7XG5leHBvcnQgKiBmcm9tICcuL3RyYWRpbmcnO1xuZXhwb3J0ICogZnJvbSAnLi90c3MnO1xuZXhwb3J0IHsgc2VuZFNpZ25hdHVyZVNoYXJlIH0gZnJvbSAnLi90c3MnO1xuZXhwb3J0ICogZnJvbSAnLi90eXBlcyc7XG5leHBvcnQgKiBmcm9tICcuL3V0aWxzJztcbmV4cG9ydCAqIGZyb20gJy4vd2FsbGV0JztcbmV4cG9ydCAqIGZyb20gJy4vd2ViaG9vayc7XG5leHBvcnQgeyBiaXRjb2luVXRpbCB9O1xuZXhwb3J0IHsgdHNzIH07XG4iXX0=
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/walletUtil/index.ts"],"names":[],"mappings":"AAAA,cAAc,oBAAoB,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./utxoMessageProof"), exports);
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvYml0Z28vd2FsbGV0VXRpbC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7O0FBQUEscURBQW1DIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi91dHhvTWVzc2FnZVByb29mJztcbiJdfQ==
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import * as utxolib from '@bitgo-beta/utxo-lib';
|
|
2
|
+
import { IWallet } from '../wallet/iWallet';
|
|
3
|
+
type MessageInfo = {
|
|
4
|
+
message: string;
|
|
5
|
+
address: string;
|
|
6
|
+
};
|
|
7
|
+
type BulkMessageResponse = {
|
|
8
|
+
success: boolean;
|
|
9
|
+
numMessages: number;
|
|
10
|
+
transactions: Record<string, unknown>[];
|
|
11
|
+
};
|
|
12
|
+
export interface IMessageProvider {
|
|
13
|
+
/**
|
|
14
|
+
* Returns the messages and addresses that we want to sign. We call this function multiple times until there are no more
|
|
15
|
+
* messages. If there are no more messages, an empty array is returned. Note that we only return messages in sets of 200.
|
|
16
|
+
*/
|
|
17
|
+
getMessagesAndAddressesToSign(): Promise<MessageInfo[]>;
|
|
18
|
+
}
|
|
19
|
+
/**
|
|
20
|
+
* The Midnight drop service can return up to 1000 messages per request. However, UTXO coins
|
|
21
|
+
* can only have a maximum of 200 messages per transaction. We make this wrapper function that
|
|
22
|
+
* handles the pagination and batching of messages, keeping a local cache of the unprocessed messages.
|
|
23
|
+
*/
|
|
24
|
+
export declare class MidnightMessageProvider implements IMessageProvider {
|
|
25
|
+
private wallet;
|
|
26
|
+
private message;
|
|
27
|
+
protected messageCache: MessageInfo[];
|
|
28
|
+
protected network: utxolib.Network;
|
|
29
|
+
protected midnightClaimUrl: string;
|
|
30
|
+
protected prevId: string | undefined;
|
|
31
|
+
protected ranOnce: boolean;
|
|
32
|
+
constructor(wallet: IWallet, message: string);
|
|
33
|
+
getMessagesAndAddressesToSign(): Promise<MessageInfo[]>;
|
|
34
|
+
}
|
|
35
|
+
export declare function bulkSignBip322MidnightMessages(wallet: IWallet, message: string, walletPassphrase?: string): Promise<BulkMessageResponse>;
|
|
36
|
+
export {};
|
|
37
|
+
//# sourceMappingURL=utxoMessageProof.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utxoMessageProof.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/walletUtil/utxoMessageProof.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAEhD,OAAO,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAM5C,KAAK,WAAW,GAAG;IACjB,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;CACjB,CAAC;AASF,KAAK,mBAAmB,GAAG;IACzB,OAAO,EAAE,OAAO,CAAC;IACjB,WAAW,EAAE,MAAM,CAAC;IACpB,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAC;CACzC,CAAC;AAEF,MAAM,WAAW,gBAAgB;IAC/B;;;OAGG;IACH,6BAA6B,IAAI,OAAO,CAAC,WAAW,EAAE,CAAC,CAAC;CACzD;AAED;;;;GAIG;AACH,qBAAa,uBAAwB,YAAW,gBAAgB;IAMlD,OAAO,CAAC,MAAM;IAAW,OAAO,CAAC,OAAO;IALpD,SAAS,CAAC,YAAY,EAAE,WAAW,EAAE,CAAC;IACtC,SAAS,CAAC,OAAO,EAAE,OAAO,CAAC,OAAO,CAAC;IACnC,SAAS,CAAC,gBAAgB,EAAE,MAAM,CAAC;IACnC,SAAS,CAAC,MAAM,EAAE,MAAM,GAAG,SAAS,CAAC;IACrC,SAAS,CAAC,OAAO,UAAS;gBACN,MAAM,EAAE,OAAO,EAAU,OAAO,EAAE,MAAM;IAQtD,6BAA6B,IAAI,OAAO,CAAC,WAAW,EAAE,CAAC;CAqC9D;AAED,wBAAsB,8BAA8B,CAClD,MAAM,EAAE,OAAO,EACf,OAAO,EAAE,MAAM,EACf,gBAAgB,CAAC,EAAE,MAAM,GACxB,OAAO,CAAC,mBAAmB,CAAC,CAG9B"}
|
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.MidnightMessageProvider = void 0;
|
|
37
|
+
exports.bulkSignBip322MidnightMessages = bulkSignBip322MidnightMessages;
|
|
38
|
+
const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
|
|
39
|
+
const environments_1 = require("../environments");
|
|
40
|
+
const NUM_MESSAGES_PER_TRANSACTION = 2;
|
|
41
|
+
const NUM_MESSAGES_PER_QUERY = 1000;
|
|
42
|
+
/**
|
|
43
|
+
* The Midnight drop service can return up to 1000 messages per request. However, UTXO coins
|
|
44
|
+
* can only have a maximum of 200 messages per transaction. We make this wrapper function that
|
|
45
|
+
* handles the pagination and batching of messages, keeping a local cache of the unprocessed messages.
|
|
46
|
+
*/
|
|
47
|
+
class MidnightMessageProvider {
|
|
48
|
+
constructor(wallet, message) {
|
|
49
|
+
this.wallet = wallet;
|
|
50
|
+
this.message = message;
|
|
51
|
+
this.ranOnce = false;
|
|
52
|
+
this.messageCache = [];
|
|
53
|
+
this.network = utxolib.networks[wallet.coin()];
|
|
54
|
+
this.midnightClaimUrl = `${environments_1.Environments[wallet.bitgo.env].uri}/api/airdrop-claim/v1/midnight/claims/${wallet.coin()}/${wallet.id()}`;
|
|
55
|
+
}
|
|
56
|
+
async getMessagesAndAddressesToSign() {
|
|
57
|
+
if (this.messageCache.length > 0) {
|
|
58
|
+
return this.messageCache.splice(0, NUM_MESSAGES_PER_TRANSACTION);
|
|
59
|
+
}
|
|
60
|
+
else if (this.messageCache.length === 0 && this.ranOnce && this.prevId === undefined) {
|
|
61
|
+
return [];
|
|
62
|
+
}
|
|
63
|
+
this.ranOnce = true;
|
|
64
|
+
const query = {
|
|
65
|
+
status: 'UNINITIALIZED',
|
|
66
|
+
limit: NUM_MESSAGES_PER_QUERY,
|
|
67
|
+
};
|
|
68
|
+
if (this.prevId !== undefined) {
|
|
69
|
+
query.prevId = this.prevId;
|
|
70
|
+
}
|
|
71
|
+
const response = await this.wallet.bitgo.get(this.midnightClaimUrl).query(query).result();
|
|
72
|
+
if (response.status !== 'success') {
|
|
73
|
+
throw new Error(`Unexpected status code ${response.status} from ${this.midnightClaimUrl}`);
|
|
74
|
+
}
|
|
75
|
+
if (response?.pagination?.hasNext) {
|
|
76
|
+
this.prevId = response?.pagination?.nextPrevId;
|
|
77
|
+
}
|
|
78
|
+
else {
|
|
79
|
+
this.prevId = undefined;
|
|
80
|
+
}
|
|
81
|
+
this.messageCache = response.claims.map((claim) => {
|
|
82
|
+
if (!claim.originAddress) {
|
|
83
|
+
throw new Error(`Claim ${JSON.stringify(claim)} is missing originAddress`);
|
|
84
|
+
}
|
|
85
|
+
return {
|
|
86
|
+
message: this.message,
|
|
87
|
+
address: claim.originAddress,
|
|
88
|
+
};
|
|
89
|
+
});
|
|
90
|
+
const toReturn = this.messageCache.splice(0, NUM_MESSAGES_PER_TRANSACTION);
|
|
91
|
+
return toReturn;
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
exports.MidnightMessageProvider = MidnightMessageProvider;
|
|
95
|
+
async function bulkSignBip322MidnightMessages(wallet, message, walletPassphrase) {
|
|
96
|
+
const provider = new MidnightMessageProvider(wallet, message);
|
|
97
|
+
return bulkSignBip322MessagesWithProvider(provider, wallet, walletPassphrase);
|
|
98
|
+
}
|
|
99
|
+
async function bulkSignBip322MessagesWithProvider(provider, wallet, walletPassphrase) {
|
|
100
|
+
let numMessages = 0;
|
|
101
|
+
let messages = await provider.getMessagesAndAddressesToSign();
|
|
102
|
+
const sendingFunction = wallet.type() === 'cold' ? wallet.prebuildTransaction : wallet.sendMany;
|
|
103
|
+
const transactions = [];
|
|
104
|
+
while (messages.length > 0) {
|
|
105
|
+
// Sign the messages with the wallet
|
|
106
|
+
const result = await sendingFunction.call(wallet, {
|
|
107
|
+
messages,
|
|
108
|
+
// Recipients must be empty
|
|
109
|
+
recipients: [],
|
|
110
|
+
// txFormat must be psbt
|
|
111
|
+
txFormat: 'psbt',
|
|
112
|
+
// Pass in the optional wallet passphrase
|
|
113
|
+
walletPassphrase,
|
|
114
|
+
offlineVerification: wallet.type() === 'cold',
|
|
115
|
+
});
|
|
116
|
+
transactions.push(result);
|
|
117
|
+
numMessages += messages.length;
|
|
118
|
+
messages = await provider.getMessagesAndAddressesToSign();
|
|
119
|
+
}
|
|
120
|
+
return { success: true, numMessages, transactions };
|
|
121
|
+
}
|
|
122
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utxoMessageProof.js","sourceRoot":"","sources":["../../../../src/bitgo/walletUtil/utxoMessageProof.ts"],"names":[],"mappings":"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","sourcesContent":["import * as utxolib from '@bitgo-beta/utxo-lib';\n\nimport { IWallet } from '../wallet/iWallet';\nimport { Environments } from '../environments';\n\nconst NUM_MESSAGES_PER_TRANSACTION = 2;\nconst NUM_MESSAGES_PER_QUERY = 1000;\n\ntype MessageInfo = {\n  message: string;\n  address: string;\n};\n\ntype Claim = {\n  originWalletId: string;\n  status: string;\n  originAddress?: string;\n  allocationAmount: string;\n};\n\ntype BulkMessageResponse = {\n  success: boolean;\n  numMessages: number;\n  transactions: Record<string, unknown>[];\n};\n\nexport interface IMessageProvider {\n  /**\n   * Returns the messages and addresses that we want to sign. We call this function multiple times until there are no more\n   * messages. If there are no more messages, an empty array is returned. Note that we only return messages in sets of 200.\n   */\n  getMessagesAndAddressesToSign(): Promise<MessageInfo[]>;\n}\n\n/**\n * The Midnight drop service can return up to 1000 messages per request. However, UTXO coins\n * can only have a maximum of 200 messages per transaction. We make this wrapper function that\n * handles the pagination and batching of messages, keeping a local cache of the unprocessed messages.\n */\nexport class MidnightMessageProvider implements IMessageProvider {\n  protected messageCache: MessageInfo[];\n  protected network: utxolib.Network;\n  protected midnightClaimUrl: string;\n  protected prevId: string | undefined;\n  protected ranOnce = false;\n  constructor(private wallet: IWallet, private message: string) {\n    this.messageCache = [];\n    this.network = utxolib.networks[wallet.coin()];\n    this.midnightClaimUrl = `${\n      Environments[wallet.bitgo.env].uri\n    }/api/airdrop-claim/v1/midnight/claims/${wallet.coin()}/${wallet.id()}`;\n  }\n\n  async getMessagesAndAddressesToSign(): Promise<MessageInfo[]> {\n    if (this.messageCache.length > 0) {\n      return this.messageCache.splice(0, NUM_MESSAGES_PER_TRANSACTION);\n    } else if (this.messageCache.length === 0 && this.ranOnce && this.prevId === undefined) {\n      return [];\n    }\n\n    this.ranOnce = true;\n    const query: Record<string, unknown> = {\n      status: 'UNINITIALIZED',\n      limit: NUM_MESSAGES_PER_QUERY,\n    };\n    if (this.prevId !== undefined) {\n      query.prevId = this.prevId;\n    }\n    const response = await this.wallet.bitgo.get(this.midnightClaimUrl).query(query).result();\n    if (response.status !== 'success') {\n      throw new Error(`Unexpected status code ${response.status} from ${this.midnightClaimUrl}`);\n    }\n    if (response?.pagination?.hasNext) {\n      this.prevId = response?.pagination?.nextPrevId;\n    } else {\n      this.prevId = undefined;\n    }\n\n    this.messageCache = response.claims.map((claim: Claim) => {\n      if (!claim.originAddress) {\n        throw new Error(`Claim ${JSON.stringify(claim)} is missing originAddress`);\n      }\n      return {\n        message: this.message,\n        address: claim.originAddress,\n      };\n    });\n    const toReturn = this.messageCache.splice(0, NUM_MESSAGES_PER_TRANSACTION);\n    return toReturn;\n  }\n}\n\nexport async function bulkSignBip322MidnightMessages(\n  wallet: IWallet,\n  message: string,\n  walletPassphrase?: string\n): Promise<BulkMessageResponse> {\n  const provider = new MidnightMessageProvider(wallet, message);\n  return bulkSignBip322MessagesWithProvider(provider, wallet, walletPassphrase);\n}\n\nasync function bulkSignBip322MessagesWithProvider(\n  provider: IMessageProvider,\n  wallet: IWallet,\n  walletPassphrase?: string\n): Promise<BulkMessageResponse> {\n  let numMessages = 0;\n  let messages: MessageInfo[] = await provider.getMessagesAndAddressesToSign();\n  const sendingFunction = wallet.type() === 'cold' ? wallet.prebuildTransaction : wallet.sendMany;\n  const transactions: Record<string, unknown>[] = [];\n  while (messages.length > 0) {\n    // Sign the messages with the wallet\n    const result = await sendingFunction.call(wallet, {\n      messages,\n      // Recipients must be empty\n      recipients: [],\n      // txFormat must be psbt\n      txFormat: 'psbt',\n      // Pass in the optional wallet passphrase\n      walletPassphrase,\n      offlineVerification: wallet.type() === 'cold',\n    });\n    transactions.push(result);\n    numMessages += messages.length;\n    messages = await provider.getMessagesAndAddressesToSign();\n  }\n  return { success: true, numMessages, transactions };\n}\n"]}
|