@bitgo-beta/abstract-eth 1.2.3-alpha.89 → 1.2.3-alpha.90

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.
Files changed (62) hide show
  1. package/dist/src/abstractEthLikeCoin.d.ts +3 -2
  2. package/dist/src/abstractEthLikeCoin.d.ts.map +1 -1
  3. package/dist/src/abstractEthLikeCoin.js +9 -9
  4. package/dist/src/abstractEthLikeNewCoins.d.ts +93 -0
  5. package/dist/src/abstractEthLikeNewCoins.d.ts.map +1 -0
  6. package/dist/src/abstractEthLikeNewCoins.js +147 -0
  7. package/dist/src/ethLikeToken.d.ts +7 -2
  8. package/dist/src/ethLikeToken.d.ts.map +1 -1
  9. package/dist/src/ethLikeToken.js +8 -5
  10. package/dist/src/index.d.ts +2 -2
  11. package/dist/src/index.d.ts.map +1 -1
  12. package/dist/src/index.js +3 -3
  13. package/dist/src/lib/contractCall.d.ts +8 -0
  14. package/dist/src/lib/contractCall.d.ts.map +1 -0
  15. package/dist/src/lib/contractCall.js +17 -0
  16. package/dist/src/lib/iface.d.ts +130 -0
  17. package/dist/src/lib/iface.d.ts.map +1 -0
  18. package/dist/src/lib/iface.js +8 -0
  19. package/dist/src/lib/index.d.ts +15 -0
  20. package/dist/src/lib/index.d.ts.map +1 -0
  21. package/dist/src/lib/index.js +42 -0
  22. package/dist/src/lib/keyPair.d.ts +26 -0
  23. package/dist/src/lib/keyPair.d.ts.map +1 -0
  24. package/dist/src/lib/keyPair.js +66 -0
  25. package/dist/src/lib/transaction.d.ts +64 -0
  26. package/dist/src/lib/transaction.d.ts.map +1 -0
  27. package/dist/src/lib/transaction.js +137 -0
  28. package/dist/src/lib/transactionBuilder.d.ts +231 -0
  29. package/dist/src/lib/transactionBuilder.d.ts.map +1 -0
  30. package/dist/src/lib/transactionBuilder.js +674 -0
  31. package/dist/src/lib/transferBuilder.d.ts +65 -0
  32. package/dist/src/lib/transferBuilder.d.ts.map +1 -0
  33. package/dist/src/lib/transferBuilder.js +221 -0
  34. package/dist/src/lib/transferBuilders/baseNFTTransferBuilder.d.ts +47 -0
  35. package/dist/src/lib/transferBuilders/baseNFTTransferBuilder.d.ts.map +1 -0
  36. package/dist/src/lib/transferBuilders/baseNFTTransferBuilder.js +113 -0
  37. package/dist/src/lib/transferBuilders/index.d.ts +4 -0
  38. package/dist/src/lib/transferBuilders/index.d.ts.map +1 -0
  39. package/dist/src/lib/transferBuilders/index.js +16 -0
  40. package/dist/src/lib/transferBuilders/transferBuilderERC1155.d.ts +14 -0
  41. package/dist/src/lib/transferBuilders/transferBuilderERC1155.d.ts.map +1 -0
  42. package/dist/src/lib/transferBuilders/transferBuilderERC1155.js +83 -0
  43. package/dist/src/lib/transferBuilders/transferBuilderERC721.d.ts +13 -0
  44. package/dist/src/lib/transferBuilders/transferBuilderERC721.d.ts.map +1 -0
  45. package/dist/src/lib/transferBuilders/transferBuilderERC721.js +68 -0
  46. package/dist/src/lib/types.d.ts +39 -0
  47. package/dist/src/lib/types.d.ts.map +1 -0
  48. package/dist/src/lib/types.js +137 -0
  49. package/dist/src/lib/utils.d.ts +228 -0
  50. package/dist/src/lib/utils.d.ts.map +1 -0
  51. package/dist/src/lib/utils.js +577 -0
  52. package/dist/src/lib/walletUtil.d.ts +26 -0
  53. package/dist/src/lib/walletUtil.d.ts.map +1 -0
  54. package/dist/src/lib/walletUtil.js +29 -0
  55. package/dist/tsconfig.tsbuildinfo +1 -1
  56. package/package.json +13 -7
  57. package/dist/src/abstractEthLikeMPCCoin.d.ts +0 -12
  58. package/dist/src/abstractEthLikeMPCCoin.d.ts.map +0 -1
  59. package/dist/src/abstractEthLikeMPCCoin.js +0 -16
  60. package/dist/src/ethLikeMPCToken.d.ts +0 -12
  61. package/dist/src/ethLikeMPCToken.d.ts.map +0 -1
  62. package/dist/src/ethLikeMPCToken.js +0 -16
@@ -0,0 +1,65 @@
1
+ /// <reference types="node" />
2
+ /** ETH transfer builder */
3
+ export declare class TransferBuilder {
4
+ private readonly _EMPTY_HEX_VALUE;
5
+ protected _amount: string;
6
+ protected _toAddress: string;
7
+ protected _sequenceId: number;
8
+ protected _signKey: string;
9
+ protected _expirationTime: number;
10
+ protected _signature: string;
11
+ private _data;
12
+ private _tokenContractAddress?;
13
+ private _coin;
14
+ constructor(serializedData?: string);
15
+ /**
16
+ * A method to set the ERC20 token to be transferred.
17
+ * This ERC20 token may not be compatible with the network.
18
+ *
19
+ * @param {string} coin the ERC20 coin to be set
20
+ * @returns {TransferBuilder} the transfer builder instance modified
21
+ */
22
+ coin(coin: string): TransferBuilder;
23
+ data(additionalData: string): TransferBuilder;
24
+ amount(amount: string): this;
25
+ to(address: string): TransferBuilder;
26
+ contractSequenceId(counter: number): TransferBuilder;
27
+ key(signKey: string): TransferBuilder;
28
+ expirationTime(date: number): TransferBuilder;
29
+ signAndBuild(): string;
30
+ private hasMandatoryFields;
31
+ /**
32
+ * Obtains the proper operation hash to sign either a sendMultiSig data
33
+ * or a sendMultiSigToken data
34
+ *
35
+ * @returns {string} the operation hash
36
+ */
37
+ private getOperationHash;
38
+ protected getOperationData(): (string | Buffer)[][];
39
+ /**
40
+ * Get the prefix used in generating an operation hash for sending tokens
41
+ *
42
+ * @returns the string prefix
43
+ */
44
+ protected getTokenOperationHashPrefix(): string;
45
+ /**
46
+ * Get the prefix used in generating an operation hash for sending native coins
47
+ *
48
+ * @returns the string prefix
49
+ */
50
+ protected getNativeOperationHashPrefix(): string;
51
+ /** Return an expiration time, in seconds, set to one hour from now
52
+ *
53
+ * @returns {number} expiration time
54
+ */
55
+ private getExpirationTime;
56
+ /**
57
+ * If a signing key is set for this builder, recalculates the signature
58
+ *
59
+ * @returns {string} the signature value
60
+ */
61
+ protected getSignature(): string;
62
+ protected ethSignMsgHash(): string;
63
+ private decodeTransferData;
64
+ }
65
+ //# sourceMappingURL=transferBuilder.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"transferBuilder.d.ts","sourceRoot":"","sources":["../../../src/lib/transferBuilder.ts"],"names":[],"mappings":";AAOA,2BAA2B;AAC3B,qBAAa,eAAe;IAC1B,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAQ;IACzC,SAAS,CAAC,OAAO,EAAE,MAAM,CAAC;IAC1B,SAAS,CAAC,UAAU,EAAE,MAAM,CAAC;IAC7B,SAAS,CAAC,WAAW,EAAE,MAAM,CAAC;IAC9B,SAAS,CAAC,QAAQ,EAAE,MAAM,CAAC;IAC3B,SAAS,CAAC,eAAe,EAAE,MAAM,CAAC;IAClC,SAAS,CAAC,UAAU,EAAE,MAAM,CAAC;IAC7B,OAAO,CAAC,KAAK,CAAS;IACtB,OAAO,CAAC,qBAAqB,CAAC,CAAS;IACvC,OAAO,CAAC,KAAK,CAAqB;gBAEtB,cAAc,CAAC,EAAE,MAAM;IAWnC;;;;;;OAMG;IACH,IAAI,CAAC,IAAI,EAAE,MAAM,GAAG,eAAe;IAUnC,IAAI,CAAC,cAAc,EAAE,MAAM,GAAG,eAAe;IAM7C,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;IAS5B,EAAE,CAAC,OAAO,EAAE,MAAM,GAAG,eAAe;IASpC,kBAAkB,CAAC,OAAO,EAAE,MAAM,GAAG,eAAe;IASpD,GAAG,CAAC,OAAO,EAAE,MAAM,GAAG,eAAe;IAKrC,cAAc,CAAC,IAAI,EAAE,MAAM,GAAG,eAAe;IAS7C,YAAY,IAAI,MAAM;IA2BtB,OAAO,CAAC,kBAAkB;IAI1B;;;;;OAKG;IACH,OAAO,CAAC,gBAAgB;IAKxB,SAAS,CAAC,gBAAgB,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,EAAE,EAAE;IA8BnD;;;;OAIG;IACH,SAAS,CAAC,2BAA2B,IAAI,MAAM;IAI/C;;;;OAIG;IACH,SAAS,CAAC,4BAA4B,IAAI,MAAM;IAIhD;;;OAGG;IACH,OAAO,CAAC,iBAAiB;IAMzB;;;;OAIG;IACH,SAAS,CAAC,YAAY,IAAI,MAAM;IAOhC,SAAS,CAAC,cAAc,IAAI,MAAM;IAoBlC,OAAO,CAAC,kBAAkB;CAiB3B"}
@@ -0,0 +1,221 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5
+ }) : (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ o[k2] = m[k];
8
+ }));
9
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
10
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
11
+ }) : function(o, v) {
12
+ o["default"] = v;
13
+ });
14
+ var __importStar = (this && this.__importStar) || function (mod) {
15
+ if (mod && mod.__esModule) return mod;
16
+ var result = {};
17
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
18
+ __setModuleDefault(result, mod);
19
+ return result;
20
+ };
21
+ var __importDefault = (this && this.__importDefault) || function (mod) {
22
+ return (mod && mod.__esModule) ? mod : { "default": mod };
23
+ };
24
+ Object.defineProperty(exports, "__esModule", { value: true });
25
+ exports.TransferBuilder = void 0;
26
+ const ethUtil = __importStar(require("ethereumjs-util"));
27
+ const ethereumjs_abi_1 = __importDefault(require("ethereumjs-abi"));
28
+ const bn_js_1 = __importDefault(require("bn.js"));
29
+ const statics_1 = require("@bitgo-beta/statics");
30
+ const sdk_core_1 = require("@bitgo-beta/sdk-core");
31
+ const utils_1 = require("./utils");
32
+ /** ETH transfer builder */
33
+ class TransferBuilder {
34
+ constructor(serializedData) {
35
+ this._EMPTY_HEX_VALUE = '0x';
36
+ if (serializedData) {
37
+ this.decodeTransferData(serializedData);
38
+ }
39
+ else {
40
+ // initialize with default values for non mandatory fields
41
+ this._expirationTime = this.getExpirationTime();
42
+ this._data = this._EMPTY_HEX_VALUE;
43
+ this._signature = this._EMPTY_HEX_VALUE;
44
+ }
45
+ }
46
+ /**
47
+ * A method to set the ERC20 token to be transferred.
48
+ * This ERC20 token may not be compatible with the network.
49
+ *
50
+ * @param {string} coin the ERC20 coin to be set
51
+ * @returns {TransferBuilder} the transfer builder instance modified
52
+ */
53
+ coin(coin) {
54
+ this._coin = statics_1.coins.get(coin);
55
+ if (this._coin instanceof statics_1.ContractAddressDefinedToken) {
56
+ this._tokenContractAddress = this._coin.contractAddress.toString();
57
+ }
58
+ return this;
59
+ }
60
+ data(additionalData) {
61
+ this._signature = this._EMPTY_HEX_VALUE;
62
+ this._data = additionalData;
63
+ return this;
64
+ }
65
+ amount(amount) {
66
+ if (!utils_1.isValidAmount(amount)) {
67
+ throw new sdk_core_1.InvalidParameterValueError('Invalid amount');
68
+ }
69
+ this._signature = this._EMPTY_HEX_VALUE;
70
+ this._amount = amount;
71
+ return this;
72
+ }
73
+ to(address) {
74
+ if (utils_1.isValidEthAddress(address)) {
75
+ this._signature = this._EMPTY_HEX_VALUE;
76
+ this._toAddress = address;
77
+ return this;
78
+ }
79
+ throw new sdk_core_1.InvalidParameterValueError('Invalid address');
80
+ }
81
+ contractSequenceId(counter) {
82
+ if (counter >= 0) {
83
+ this._signature = this._EMPTY_HEX_VALUE;
84
+ this._sequenceId = counter;
85
+ return this;
86
+ }
87
+ throw new sdk_core_1.InvalidParameterValueError('Invalid contract sequence id');
88
+ }
89
+ key(signKey) {
90
+ this._signKey = signKey;
91
+ return this;
92
+ }
93
+ expirationTime(date) {
94
+ if (date > 0) {
95
+ this._signature = this._EMPTY_HEX_VALUE;
96
+ this._expirationTime = date;
97
+ return this;
98
+ }
99
+ throw new sdk_core_1.InvalidParameterValueError('Invalid expiration time');
100
+ }
101
+ signAndBuild() {
102
+ if (this.hasMandatoryFields()) {
103
+ if (this._tokenContractAddress !== undefined) {
104
+ return utils_1.sendMultiSigTokenData(this._toAddress, this._amount, this._tokenContractAddress, this._expirationTime, this._sequenceId, this.getSignature());
105
+ }
106
+ else {
107
+ return utils_1.sendMultiSigData(this._toAddress, this._amount, this._data, this._expirationTime, this._sequenceId, this.getSignature());
108
+ }
109
+ }
110
+ throw new sdk_core_1.BuildTransactionError('Missing transfer mandatory fields. Amount, destination (to) address and sequenceID are mandatory');
111
+ }
112
+ hasMandatoryFields() {
113
+ return this._amount !== undefined && this._toAddress !== undefined && this._sequenceId !== undefined;
114
+ }
115
+ /**
116
+ * Obtains the proper operation hash to sign either a sendMultiSig data
117
+ * or a sendMultiSigToken data
118
+ *
119
+ * @returns {string} the operation hash
120
+ */
121
+ getOperationHash() {
122
+ const operationData = this.getOperationData();
123
+ return ethUtil.bufferToHex(ethereumjs_abi_1.default.soliditySHA3(...operationData));
124
+ }
125
+ getOperationData() {
126
+ let operationData;
127
+ if (this._tokenContractAddress !== undefined) {
128
+ operationData = [
129
+ ['string', 'address', 'uint', 'address', 'uint', 'uint'],
130
+ [
131
+ this.getTokenOperationHashPrefix(),
132
+ new bn_js_1.default(ethUtil.stripHexPrefix(this._toAddress), 16),
133
+ this._amount,
134
+ new bn_js_1.default(ethUtil.stripHexPrefix(this._tokenContractAddress), 16),
135
+ this._expirationTime,
136
+ this._sequenceId,
137
+ ],
138
+ ];
139
+ }
140
+ else {
141
+ operationData = [
142
+ ['string', 'address', 'uint', 'bytes', 'uint', 'uint'],
143
+ [
144
+ this.getNativeOperationHashPrefix(),
145
+ new bn_js_1.default(ethUtil.stripHexPrefix(this._toAddress), 16),
146
+ this._amount,
147
+ Buffer.from(ethUtil.padToEven(ethUtil.stripHexPrefix(this._data)) || '', 'hex'),
148
+ this._expirationTime,
149
+ this._sequenceId,
150
+ ],
151
+ ];
152
+ }
153
+ return operationData;
154
+ }
155
+ /**
156
+ * Get the prefix used in generating an operation hash for sending tokens
157
+ *
158
+ * @returns the string prefix
159
+ */
160
+ getTokenOperationHashPrefix() {
161
+ return 'ERC20';
162
+ }
163
+ /**
164
+ * Get the prefix used in generating an operation hash for sending native coins
165
+ *
166
+ * @returns the string prefix
167
+ */
168
+ getNativeOperationHashPrefix() {
169
+ return 'ETHER';
170
+ }
171
+ /** Return an expiration time, in seconds, set to one hour from now
172
+ *
173
+ * @returns {number} expiration time
174
+ */
175
+ getExpirationTime() {
176
+ const currentDate = new Date();
177
+ currentDate.setHours(currentDate.getHours() + 1);
178
+ return currentDate.getTime() / 1000;
179
+ }
180
+ /**
181
+ * If a signing key is set for this builder, recalculates the signature
182
+ *
183
+ * @returns {string} the signature value
184
+ */
185
+ getSignature() {
186
+ if (this._signKey) {
187
+ this._signature = this.ethSignMsgHash();
188
+ }
189
+ return this._signature;
190
+ }
191
+ ethSignMsgHash() {
192
+ const data = this.getOperationHash();
193
+ const keyBuffer = Buffer.from(ethUtil.padToEven(this._signKey), 'hex');
194
+ if (keyBuffer.length != 32) {
195
+ throw new Error('private key length is invalid');
196
+ }
197
+ const signatureInParts = ethUtil.ecsign(Buffer.from(ethUtil.padToEven(ethUtil.stripHexPrefix(data)), 'hex'), keyBuffer);
198
+ // Assemble strings from r, s and v
199
+ const r = ethUtil.setLengthLeft(signatureInParts.r, 32).toString('hex');
200
+ const s = ethUtil.setLengthLeft(signatureInParts.s, 32).toString('hex');
201
+ const v = ethUtil.stripHexPrefix(ethUtil.intToHex(signatureInParts.v));
202
+ // Concatenate the r, s and v parts to make the signature string
203
+ return ethUtil.addHexPrefix(r.concat(s, v));
204
+ }
205
+ decodeTransferData(data) {
206
+ const transferData = utils_1.decodeTransferData(data);
207
+ this._toAddress = transferData.to;
208
+ this._amount = transferData.amount;
209
+ this._expirationTime = transferData.expireTime;
210
+ this._sequenceId = transferData.sequenceId;
211
+ this._signature = transferData.signature;
212
+ if (transferData.data) {
213
+ this._data = transferData.data;
214
+ }
215
+ if (transferData.tokenContractAddress) {
216
+ this._tokenContractAddress = transferData.tokenContractAddress;
217
+ }
218
+ }
219
+ }
220
+ exports.TransferBuilder = TransferBuilder;
221
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transferBuilder.js","sourceRoot":"","sources":["../../../src/lib/transferBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import * as ethUtil from 'ethereumjs-util';\nimport EthereumAbi from 'ethereumjs-abi';\nimport BN from 'bn.js';\nimport { coins, BaseCoin, ContractAddressDefinedToken } from '@bitgo-beta/statics';\nimport { BuildTransactionError, InvalidParameterValueError } from '@bitgo-beta/sdk-core';\nimport { decodeTransferData, sendMultiSigData, sendMultiSigTokenData, isValidEthAddress, isValidAmount } from './utils';\n\n/** ETH transfer builder */\nexport class TransferBuilder {\n  private readonly _EMPTY_HEX_VALUE = '0x';\n  protected _amount: string;\n  protected _toAddress: string;\n  protected _sequenceId: number;\n  protected _signKey: string;\n  protected _expirationTime: number;\n  protected _signature: string;\n  private _data: string;\n  private _tokenContractAddress?: string;\n  private _coin: Readonly<BaseCoin>;\n\n  constructor(serializedData?: string) {\n    if (serializedData) {\n      this.decodeTransferData(serializedData);\n    } else {\n      // initialize with default values for non mandatory fields\n      this._expirationTime = this.getExpirationTime();\n      this._data = this._EMPTY_HEX_VALUE;\n      this._signature = this._EMPTY_HEX_VALUE;\n    }\n  }\n\n  /**\n   * A method to set the ERC20 token to be transferred.\n   * This ERC20 token may not be compatible with the network.\n   *\n   * @param {string} coin the ERC20 coin to be set\n   * @returns {TransferBuilder} the transfer builder instance modified\n   */\n  coin(coin: string): TransferBuilder {\n    this._coin = coins.get(coin);\n\n    if (this._coin instanceof ContractAddressDefinedToken) {\n      this._tokenContractAddress = this._coin.contractAddress.toString();\n    }\n\n    return this;\n  }\n\n  data(additionalData: string): TransferBuilder {\n    this._signature = this._EMPTY_HEX_VALUE;\n    this._data = additionalData;\n    return this;\n  }\n\n  amount(amount: string): this {\n    if (!isValidAmount(amount)) {\n      throw new InvalidParameterValueError('Invalid amount');\n    }\n    this._signature = this._EMPTY_HEX_VALUE;\n    this._amount = amount;\n    return this;\n  }\n\n  to(address: string): TransferBuilder {\n    if (isValidEthAddress(address)) {\n      this._signature = this._EMPTY_HEX_VALUE;\n      this._toAddress = address;\n      return this;\n    }\n    throw new InvalidParameterValueError('Invalid address');\n  }\n\n  contractSequenceId(counter: number): TransferBuilder {\n    if (counter >= 0) {\n      this._signature = this._EMPTY_HEX_VALUE;\n      this._sequenceId = counter;\n      return this;\n    }\n    throw new InvalidParameterValueError('Invalid contract sequence id');\n  }\n\n  key(signKey: string): TransferBuilder {\n    this._signKey = signKey;\n    return this;\n  }\n\n  expirationTime(date: number): TransferBuilder {\n    if (date > 0) {\n      this._signature = this._EMPTY_HEX_VALUE;\n      this._expirationTime = date;\n      return this;\n    }\n    throw new InvalidParameterValueError('Invalid expiration time');\n  }\n\n  signAndBuild(): string {\n    if (this.hasMandatoryFields()) {\n      if (this._tokenContractAddress !== undefined) {\n        return sendMultiSigTokenData(\n          this._toAddress,\n          this._amount,\n          this._tokenContractAddress,\n          this._expirationTime,\n          this._sequenceId,\n          this.getSignature()\n        );\n      } else {\n        return sendMultiSigData(\n          this._toAddress,\n          this._amount,\n          this._data,\n          this._expirationTime,\n          this._sequenceId,\n          this.getSignature()\n        );\n      }\n    }\n    throw new BuildTransactionError(\n      'Missing transfer mandatory fields. Amount, destination (to) address and sequenceID are mandatory'\n    );\n  }\n\n  private hasMandatoryFields(): boolean {\n    return this._amount !== undefined && this._toAddress !== undefined && this._sequenceId !== undefined;\n  }\n\n  /**\n   * Obtains the proper operation hash to sign either a sendMultiSig data\n   * or a sendMultiSigToken data\n   *\n   * @returns {string} the operation hash\n   */\n  private getOperationHash(): string {\n    const operationData = this.getOperationData();\n    return ethUtil.bufferToHex(EthereumAbi.soliditySHA3(...operationData));\n  }\n\n  protected getOperationData(): (string | Buffer)[][] {\n    let operationData;\n    if (this._tokenContractAddress !== undefined) {\n      operationData = [\n        ['string', 'address', 'uint', 'address', 'uint', 'uint'],\n        [\n          this.getTokenOperationHashPrefix(),\n          new BN(ethUtil.stripHexPrefix(this._toAddress), 16),\n          this._amount,\n          new BN(ethUtil.stripHexPrefix(this._tokenContractAddress), 16),\n          this._expirationTime,\n          this._sequenceId,\n        ],\n      ];\n    } else {\n      operationData = [\n        ['string', 'address', 'uint', 'bytes', 'uint', 'uint'],\n        [\n          this.getNativeOperationHashPrefix(),\n          new BN(ethUtil.stripHexPrefix(this._toAddress), 16),\n          this._amount,\n          Buffer.from(ethUtil.padToEven(ethUtil.stripHexPrefix(this._data)) || '', 'hex'),\n          this._expirationTime,\n          this._sequenceId,\n        ],\n      ];\n    }\n    return operationData;\n  }\n\n  /**\n   * Get the prefix used in generating an operation hash for sending tokens\n   *\n   * @returns the string prefix\n   */\n  protected getTokenOperationHashPrefix(): string {\n    return 'ERC20';\n  }\n\n  /**\n   * Get the prefix used in generating an operation hash for sending native coins\n   *\n   * @returns the string prefix\n   */\n  protected getNativeOperationHashPrefix(): string {\n    return 'ETHER';\n  }\n\n  /** Return an expiration time, in seconds, set to one hour from now\n   *\n   * @returns {number} expiration time\n   */\n  private getExpirationTime(): number {\n    const currentDate = new Date();\n    currentDate.setHours(currentDate.getHours() + 1);\n    return currentDate.getTime() / 1000;\n  }\n\n  /**\n   * If a signing key is set for this builder, recalculates the signature\n   *\n   * @returns {string} the signature value\n   */\n  protected getSignature(): string {\n    if (this._signKey) {\n      this._signature = this.ethSignMsgHash();\n    }\n    return this._signature!;\n  }\n\n  protected ethSignMsgHash(): string {\n    const data = this.getOperationHash();\n    const keyBuffer = Buffer.from(ethUtil.padToEven(this._signKey), 'hex');\n    if (keyBuffer.length != 32) {\n      throw new Error('private key length is invalid');\n    }\n    const signatureInParts = ethUtil.ecsign(\n      Buffer.from(ethUtil.padToEven(ethUtil.stripHexPrefix(data)), 'hex'),\n      keyBuffer\n    );\n\n    // Assemble strings from r, s and v\n    const r = ethUtil.setLengthLeft(signatureInParts.r, 32).toString('hex');\n    const s = ethUtil.setLengthLeft(signatureInParts.s, 32).toString('hex');\n    const v = ethUtil.stripHexPrefix(ethUtil.intToHex(signatureInParts.v));\n\n    // Concatenate the r, s and v parts to make the signature string\n    return ethUtil.addHexPrefix(r.concat(s, v));\n  }\n\n  private decodeTransferData(data: string): void {\n    const transferData = decodeTransferData(data);\n\n    this._toAddress = transferData.to;\n    this._amount = transferData.amount;\n    this._expirationTime = transferData.expireTime;\n    this._sequenceId = transferData.sequenceId;\n    this._signature = transferData.signature;\n\n    if (transferData.data) {\n      this._data = transferData.data;\n    }\n\n    if (transferData.tokenContractAddress) {\n      this._tokenContractAddress = transferData.tokenContractAddress;\n    }\n  }\n}\n"]}
@@ -0,0 +1,47 @@
1
+ export declare abstract class BaseNFTTransferBuilder {
2
+ protected readonly _EMPTY_HEX_VALUE = "0x";
3
+ protected _fromAddress: string;
4
+ protected _toAddress: string;
5
+ protected _sequenceId: number;
6
+ protected _signKey: string;
7
+ protected _expirationTime: number;
8
+ protected _signature: string;
9
+ protected _data: string;
10
+ protected _tokenContractAddress: string;
11
+ protected constructor(serializedData?: string);
12
+ expirationTime(date: number): this;
13
+ key(signKey: string): this;
14
+ contractSequenceId(counter: number): this;
15
+ to(address: string): this;
16
+ from(address: string): this;
17
+ /** Return an expiration time, in seconds, set to one hour from now
18
+ *
19
+ * @returns {number} expiration time
20
+ */
21
+ private static getExpirationTime;
22
+ /**
23
+ * If a signing key is set for this builder, recalculates the signature
24
+ *
25
+ * @returns {string} the signature value
26
+ */
27
+ protected getSignature(): string;
28
+ /**
29
+ * Get the prefix used in generating an operation hash for sending native coins
30
+ *
31
+ * @returns the string prefix
32
+ */
33
+ protected getNativeOperationHashPrefix(): string;
34
+ /**
35
+ * Obtains the proper operation hash to sign either a sendMultiSig data
36
+ * or a sendMultiSigToken data
37
+ *
38
+ * @returns {string} the operation hash
39
+ */
40
+ private getOperationHash;
41
+ /**
42
+ * Signs the Message with the given private key
43
+ * @returns {string} 65 byte long raw signature
44
+ */
45
+ protected ethSignMsgHash(): string;
46
+ }
47
+ //# sourceMappingURL=baseNFTTransferBuilder.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"baseNFTTransferBuilder.d.ts","sourceRoot":"","sources":["../../../../src/lib/transferBuilders/baseNFTTransferBuilder.ts"],"names":[],"mappings":"AAIA,8BAAsB,sBAAsB;IAC1C,SAAS,CAAC,QAAQ,CAAC,gBAAgB,QAAQ;IAE3C,SAAS,CAAC,YAAY,EAAE,MAAM,CAAC;IAC/B,SAAS,CAAC,UAAU,EAAE,MAAM,CAAC;IAC7B,SAAS,CAAC,WAAW,EAAE,MAAM,CAAC;IAC9B,SAAS,CAAC,QAAQ,EAAE,MAAM,CAAC;IAC3B,SAAS,CAAC,eAAe,EAAE,MAAM,CAAC;IAClC,SAAS,CAAC,UAAU,EAAE,MAAM,CAAC;IAC7B,SAAS,CAAC,KAAK,EAAE,MAAM,CAAC;IACxB,SAAS,CAAC,qBAAqB,EAAE,MAAM,CAAC;IAExC,SAAS,aAAa,cAAc,CAAC,EAAE,MAAM;IAS7C,cAAc,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI;IASlC,GAAG,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI;IAK1B,kBAAkB,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI;IASzC,EAAE,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI;IASzB,IAAI,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI;IAS3B;;;OAGG;IACH,OAAO,CAAC,MAAM,CAAC,iBAAiB;IAMhC;;;;OAIG;IACH,SAAS,CAAC,YAAY,IAAI,MAAM;IAUhC;;;;OAIG;IACH,SAAS,CAAC,4BAA4B,IAAI,MAAM;IAIhD;;;;;OAKG;IACH,OAAO,CAAC,gBAAgB;IAexB;;;OAGG;IACH,SAAS,CAAC,cAAc,IAAI,MAAM;CAOnC"}
@@ -0,0 +1,113 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.BaseNFTTransferBuilder = void 0;
4
+ const sdk_core_1 = require("@bitgo-beta/sdk-core");
5
+ const utils_1 = require("../utils");
6
+ const utils_2 = require("ethers/lib/utils");
7
+ class BaseNFTTransferBuilder {
8
+ constructor(serializedData) {
9
+ this._EMPTY_HEX_VALUE = '0x';
10
+ if (serializedData === undefined) {
11
+ // initialize with default values for non mandatory fields
12
+ this._expirationTime = BaseNFTTransferBuilder.getExpirationTime();
13
+ this._data = this._EMPTY_HEX_VALUE;
14
+ this._signature = this._EMPTY_HEX_VALUE;
15
+ }
16
+ }
17
+ expirationTime(date) {
18
+ if (date > 0) {
19
+ this._signature = this._EMPTY_HEX_VALUE;
20
+ this._expirationTime = date;
21
+ return this;
22
+ }
23
+ throw new sdk_core_1.InvalidParameterValueError('Invalid expiration time');
24
+ }
25
+ key(signKey) {
26
+ this._signKey = signKey;
27
+ return this;
28
+ }
29
+ contractSequenceId(counter) {
30
+ if (counter >= 0) {
31
+ this._signature = this._EMPTY_HEX_VALUE;
32
+ this._sequenceId = counter;
33
+ return this;
34
+ }
35
+ throw new sdk_core_1.InvalidParameterValueError('Invalid contract sequence id');
36
+ }
37
+ to(address) {
38
+ if (utils_1.isValidEthAddress(address)) {
39
+ this._signature = this._EMPTY_HEX_VALUE;
40
+ this._toAddress = address;
41
+ return this;
42
+ }
43
+ throw new sdk_core_1.InvalidParameterValueError('Invalid address');
44
+ }
45
+ from(address) {
46
+ if (utils_1.isValidEthAddress(address)) {
47
+ this._signature = this._EMPTY_HEX_VALUE;
48
+ this._fromAddress = address;
49
+ return this;
50
+ }
51
+ throw new sdk_core_1.InvalidParameterValueError('Invalid address');
52
+ }
53
+ /** Return an expiration time, in seconds, set to one hour from now
54
+ *
55
+ * @returns {number} expiration time
56
+ */
57
+ static getExpirationTime() {
58
+ const currentDate = new Date();
59
+ currentDate.setHours(currentDate.getHours() + 1);
60
+ return currentDate.getTime() / 1000;
61
+ }
62
+ /**
63
+ * If a signing key is set for this builder, recalculates the signature
64
+ *
65
+ * @returns {string} the signature value
66
+ */
67
+ getSignature() {
68
+ if (this._signKey) {
69
+ this._signature = this.ethSignMsgHash();
70
+ }
71
+ if (this._signature == null) {
72
+ throw new sdk_core_1.InvalidSignatureError('Null signature value');
73
+ }
74
+ return this._signature;
75
+ }
76
+ /**
77
+ * Get the prefix used in generating an operation hash for sending native coins
78
+ *
79
+ * @returns the string prefix
80
+ */
81
+ getNativeOperationHashPrefix() {
82
+ return 'ETHER';
83
+ }
84
+ /**
85
+ * Obtains the proper operation hash to sign either a sendMultiSig data
86
+ * or a sendMultiSigToken data
87
+ *
88
+ * @returns {string} the operation hash
89
+ */
90
+ getOperationHash() {
91
+ const hash = utils_2.solidityKeccak256(['string', 'address', 'uint', 'bytes', 'uint', 'uint'], [
92
+ this.getNativeOperationHashPrefix(),
93
+ this._toAddress,
94
+ '0',
95
+ this._data,
96
+ this._expirationTime,
97
+ this._sequenceId,
98
+ ]);
99
+ return hash;
100
+ }
101
+ /**
102
+ * Signs the Message with the given private key
103
+ * @returns {string} 65 byte long raw signature
104
+ */
105
+ ethSignMsgHash() {
106
+ const signKey = new utils_2.SigningKey('0x'.concat(this._signKey));
107
+ const digest = signKey.signDigest(this.getOperationHash());
108
+ const rawSignature = utils_2.joinSignature(digest);
109
+ return rawSignature;
110
+ }
111
+ }
112
+ exports.BaseNFTTransferBuilder = BaseNFTTransferBuilder;
113
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"baseNFTTransferBuilder.js","sourceRoot":"","sources":["../../../../src/lib/transferBuilders/baseNFTTransferBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import { InvalidParameterValueError, InvalidSignatureError } from '@bitgo-beta/sdk-core';\nimport { isValidEthAddress } from '../utils';\nimport { joinSignature, solidityKeccak256, SigningKey } from 'ethers/lib/utils';\n\nexport abstract class BaseNFTTransferBuilder {\n  protected readonly _EMPTY_HEX_VALUE = '0x';\n  // dummy account value, for compatibility with SendMultiSig\n  protected _fromAddress: string;\n  protected _toAddress: string;\n  protected _sequenceId: number;\n  protected _signKey: string;\n  protected _expirationTime: number;\n  protected _signature: string;\n  protected _data: string;\n  protected _tokenContractAddress: string;\n\n  protected constructor(serializedData?: string) {\n    if (serializedData === undefined) {\n      // initialize with default values for non mandatory fields\n      this._expirationTime = BaseNFTTransferBuilder.getExpirationTime();\n      this._data = this._EMPTY_HEX_VALUE;\n      this._signature = this._EMPTY_HEX_VALUE;\n    }\n  }\n\n  expirationTime(date: number): this {\n    if (date > 0) {\n      this._signature = this._EMPTY_HEX_VALUE;\n      this._expirationTime = date;\n      return this;\n    }\n    throw new InvalidParameterValueError('Invalid expiration time');\n  }\n\n  key(signKey: string): this {\n    this._signKey = signKey;\n    return this;\n  }\n\n  contractSequenceId(counter: number): this {\n    if (counter >= 0) {\n      this._signature = this._EMPTY_HEX_VALUE;\n      this._sequenceId = counter;\n      return this;\n    }\n    throw new InvalidParameterValueError('Invalid contract sequence id');\n  }\n\n  to(address: string): this {\n    if (isValidEthAddress(address)) {\n      this._signature = this._EMPTY_HEX_VALUE;\n      this._toAddress = address;\n      return this;\n    }\n    throw new InvalidParameterValueError('Invalid address');\n  }\n\n  from(address: string): this {\n    if (isValidEthAddress(address)) {\n      this._signature = this._EMPTY_HEX_VALUE;\n      this._fromAddress = address;\n      return this;\n    }\n    throw new InvalidParameterValueError('Invalid address');\n  }\n\n  /** Return an expiration time, in seconds, set to one hour from now\n   *\n   * @returns {number} expiration time\n   */\n  private static getExpirationTime(): number {\n    const currentDate = new Date();\n    currentDate.setHours(currentDate.getHours() + 1);\n    return currentDate.getTime() / 1000;\n  }\n\n  /**\n   * If a signing key is set for this builder, recalculates the signature\n   *\n   * @returns {string} the signature value\n   */\n  protected getSignature(): string {\n    if (this._signKey) {\n      this._signature = this.ethSignMsgHash();\n    }\n    if (this._signature == null) {\n      throw new InvalidSignatureError('Null signature value');\n    }\n    return this._signature;\n  }\n\n  /**\n   * Get the prefix used in generating an operation hash for sending native coins\n   *\n   * @returns the string prefix\n   */\n  protected getNativeOperationHashPrefix(): string {\n    return 'ETHER';\n  }\n\n  /**\n   * Obtains the proper operation hash to sign either a sendMultiSig data\n   * or a sendMultiSigToken data\n   *\n   * @returns {string} the operation hash\n   */\n  private getOperationHash(): string {\n    const hash = solidityKeccak256(\n      ['string', 'address', 'uint', 'bytes', 'uint', 'uint'],\n      [\n        this.getNativeOperationHashPrefix(),\n        this._toAddress,\n        '0', // dummy amount value\n        this._data,\n        this._expirationTime,\n        this._sequenceId,\n      ]\n    );\n    return hash;\n  }\n\n  /**\n   * Signs the Message with the given private key\n   * @returns {string} 65 byte long raw signature\n   */\n  protected ethSignMsgHash(): string {\n    const signKey = new SigningKey('0x'.concat(this._signKey));\n    const digest = signKey.signDigest(this.getOperationHash());\n    const rawSignature = joinSignature(digest);\n\n    return rawSignature;\n  }\n}\n"]}
@@ -0,0 +1,4 @@
1
+ export * from './baseNFTTransferBuilder';
2
+ export * from './transferBuilderERC1155';
3
+ export * from './transferBuilderERC721';
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/lib/transferBuilders/index.ts"],"names":[],"mappings":"AAAA,cAAc,0BAA0B,CAAC;AACzC,cAAc,0BAA0B,CAAC;AACzC,cAAc,yBAAyB,CAAC"}
@@ -0,0 +1,16 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5
+ }) : (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ o[k2] = m[k];
8
+ }));
9
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
10
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
11
+ };
12
+ Object.defineProperty(exports, "__esModule", { value: true });
13
+ __exportStar(require("./baseNFTTransferBuilder"), exports);
14
+ __exportStar(require("./transferBuilderERC1155"), exports);
15
+ __exportStar(require("./transferBuilderERC721"), exports);
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGliL3RyYW5zZmVyQnVpbGRlcnMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBQUEsMkRBQXlDO0FBQ3pDLDJEQUF5QztBQUN6QywwREFBd0MiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2Jhc2VORlRUcmFuc2ZlckJ1aWxkZXInO1xuZXhwb3J0ICogZnJvbSAnLi90cmFuc2ZlckJ1aWxkZXJFUkMxMTU1JztcbmV4cG9ydCAqIGZyb20gJy4vdHJhbnNmZXJCdWlsZGVyRVJDNzIxJztcbiJdfQ==
@@ -0,0 +1,14 @@
1
+ import { BaseNFTTransferBuilder } from './baseNFTTransferBuilder';
2
+ export declare class ERC1155TransferBuilder extends BaseNFTTransferBuilder {
3
+ private _tokenIds;
4
+ private _values;
5
+ private _bytes;
6
+ constructor(serializedData?: string);
7
+ tokenContractAddress(address: string): ERC1155TransferBuilder;
8
+ entry(tokenId: number, value: number): ERC1155TransferBuilder;
9
+ bytes(bytesInNumber: number): ERC1155TransferBuilder;
10
+ signAndBuild(): string;
11
+ private hasMandatoryFields;
12
+ private decodeTransferData;
13
+ }
14
+ //# sourceMappingURL=transferBuilderERC1155.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"transferBuilderERC1155.d.ts","sourceRoot":"","sources":["../../../../src/lib/transferBuilders/transferBuilderERC1155.ts"],"names":[],"mappings":"AAWA,OAAO,EAAE,sBAAsB,EAAE,MAAM,0BAA0B,CAAC;AAElE,qBAAa,sBAAuB,SAAQ,sBAAsB;IAChE,OAAO,CAAC,SAAS,CAAW;IAC5B,OAAO,CAAC,OAAO,CAAW;IAC1B,OAAO,CAAC,MAAM,CAAS;gBAEX,cAAc,CAAC,EAAE,MAAM;IAWnC,oBAAoB,CAAC,OAAO,EAAE,MAAM,GAAG,sBAAsB;IAQ7D,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,sBAAsB;IAM7D,KAAK,CAAC,aAAa,EAAE,MAAM,GAAG,sBAAsB;IAKpD,YAAY,IAAI,MAAM;IA4BtB,OAAO,CAAC,kBAAkB;IAY1B,OAAO,CAAC,kBAAkB;CAc3B"}
@@ -0,0 +1,83 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ERC1155TransferBuilder = void 0;
4
+ const sdk_core_1 = require("@bitgo-beta/sdk-core");
5
+ const utils_1 = require("ethers/lib/utils");
6
+ const contractCall_1 = require("../contractCall");
7
+ const utils_2 = require("../utils");
8
+ const walletUtil_1 = require("../walletUtil");
9
+ const baseNFTTransferBuilder_1 = require("./baseNFTTransferBuilder");
10
+ class ERC1155TransferBuilder extends baseNFTTransferBuilder_1.BaseNFTTransferBuilder {
11
+ constructor(serializedData) {
12
+ super(serializedData);
13
+ this.bytes(0);
14
+ if (serializedData) {
15
+ this.decodeTransferData(serializedData);
16
+ }
17
+ else {
18
+ this._tokenIds = [];
19
+ this._values = [];
20
+ }
21
+ }
22
+ tokenContractAddress(address) {
23
+ if (utils_2.isValidEthAddress(address)) {
24
+ this._tokenContractAddress = address;
25
+ return this;
26
+ }
27
+ throw new sdk_core_1.InvalidParameterValueError('Invalid address');
28
+ }
29
+ entry(tokenId, value) {
30
+ this._tokenIds.push(tokenId.toString());
31
+ this._values.push(value.toString());
32
+ return this;
33
+ }
34
+ bytes(bytesInNumber) {
35
+ this._bytes = utils_1.hexZeroPad(utils_1.hexlify(bytesInNumber), 32);
36
+ return this;
37
+ }
38
+ signAndBuild() {
39
+ const hasMandatoryFields = this.hasMandatoryFields();
40
+ if (hasMandatoryFields) {
41
+ if (this._tokenIds.length === 1) {
42
+ const values = [this._fromAddress, this._toAddress, this._tokenIds[0], this._values[0], this._bytes];
43
+ const contractCall = new contractCall_1.ContractCall(walletUtil_1.ERC1155SafeTransferTypeMethodId, walletUtil_1.ERC1155SafeTransferTypes, values);
44
+ this._data = contractCall.serialize();
45
+ }
46
+ else {
47
+ const values = [this._fromAddress, this._toAddress, this._tokenIds, this._values, this._bytes];
48
+ const contractCall = new contractCall_1.ContractCall(walletUtil_1.ERC1155BatchTransferTypeMethodId, walletUtil_1.ERC1155BatchTransferTypes, values);
49
+ this._data = contractCall.serialize();
50
+ }
51
+ return utils_2.sendMultiSigData(this._tokenContractAddress, '0', // dummy amount value
52
+ this._data, this._expirationTime, this._sequenceId, this.getSignature());
53
+ }
54
+ throw new sdk_core_1.BuildTransactionError(`Missing transfer mandatory fields.
55
+ Destination (to) address, source (from) address, sequenceID, the token contract address, tokenIDs and their values are mandatory`);
56
+ }
57
+ hasMandatoryFields() {
58
+ return (this._tokenIds !== undefined &&
59
+ this._tokenIds.length !== 0 &&
60
+ this._values.length !== 0 &&
61
+ this._tokenIds.length === this._values.length &&
62
+ this._toAddress !== undefined &&
63
+ this._fromAddress !== undefined &&
64
+ this._tokenContractAddress !== undefined &&
65
+ this._sequenceId !== undefined);
66
+ }
67
+ decodeTransferData(data) {
68
+ const transferData = utils_2.decodeERC1155TransferData(data);
69
+ this._toAddress = transferData.to;
70
+ this._fromAddress = transferData.from;
71
+ this._expirationTime = transferData.expireTime;
72
+ this._sequenceId = transferData.sequenceId;
73
+ this._signature = transferData.signature;
74
+ this._tokenContractAddress = transferData.tokenContractAddress;
75
+ this._tokenIds = transferData.tokenIds;
76
+ this._values = transferData.values;
77
+ if (transferData.data) {
78
+ this._data = transferData.data;
79
+ }
80
+ }
81
+ }
82
+ exports.ERC1155TransferBuilder = ERC1155TransferBuilder;
83
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transferBuilderERC1155.js","sourceRoot":"","sources":["../../../../src/lib/transferBuilders/transferBuilderERC1155.ts"],"names":[],"mappings":";;;AAAA,mDAAyF;AACzF,4CAAuD;AAEvD,kDAA+C;AAC/C,oCAA0F;AAC1F,8CAKuB;AACvB,qEAAkE;AAElE,MAAa,sBAAuB,SAAQ,+CAAsB;IAKhE,YAAY,cAAuB;QACjC,KAAK,CAAC,cAAc,CAAC,CAAC;QACtB,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACd,IAAI,cAAc,EAAE;YAClB,IAAI,CAAC,kBAAkB,CAAC,cAAc,CAAC,CAAC;SACzC;aAAM;YACL,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;YACpB,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;SACnB;IACH,CAAC;IAED,oBAAoB,CAAC,OAAe;QAClC,IAAI,yBAAiB,CAAC,OAAO,CAAC,EAAE;YAC9B,IAAI,CAAC,qBAAqB,GAAG,OAAO,CAAC;YACrC,OAAO,IAAI,CAAC;SACb;QACD,MAAM,IAAI,qCAA0B,CAAC,iBAAiB,CAAC,CAAC;IAC1D,CAAC;IAED,KAAK,CAAC,OAAe,EAAE,KAAa;QAClC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAC;QACxC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC,CAAC;QACpC,OAAO,IAAI,CAAC;IACd,CAAC;IAED,KAAK,CAAC,aAAqB;QACzB,IAAI,CAAC,MAAM,GAAG,kBAAU,CAAC,eAAO,CAAC,aAAa,CAAC,EAAE,EAAE,CAAC,CAAC;QACrD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,YAAY;QACV,MAAM,kBAAkB,GAAG,IAAI,CAAC,kBAAkB,EAAE,CAAC;QACrD,IAAI,kBAAkB,EAAE;YACtB,IAAI,IAAI,CAAC,SAAS,CAAC,MAAM,KAAK,CAAC,EAAE;gBAC/B,MAAM,MAAM,GAAG,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;gBACrG,MAAM,YAAY,GAAG,IAAI,2BAAY,CAAC,4CAA+B,EAAE,qCAAwB,EAAE,MAAM,CAAC,CAAC;gBACzG,IAAI,CAAC,KAAK,GAAG,YAAY,CAAC,SAAS,EAAE,CAAC;aACvC;iBAAM;gBACL,MAAM,MAAM,GAAG,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;gBAC/F,MAAM,YAAY,GAAG,IAAI,2BAAY,CAAC,6CAAgC,EAAE,sCAAyB,EAAE,MAAM,CAAC,CAAC;gBAC3G,IAAI,CAAC,KAAK,GAAG,YAAY,CAAC,SAAS,EAAE,CAAC;aACvC;YAED,OAAO,wBAAgB,CACrB,IAAI,CAAC,qBAAqB,EAC1B,GAAG,EAAE,qBAAqB;YAC1B,IAAI,CAAC,KAAK,EACV,IAAI,CAAC,eAAe,EACpB,IAAI,CAAC,WAAW,EAChB,IAAI,CAAC,YAAY,EAAE,CACpB,CAAC;SACH;QACD,MAAM,IAAI,gCAAqB,CAC7B;wIACkI,CACnI,CAAC;IACJ,CAAC;IAEO,kBAAkB;QACxB,OAAO,CACL,IAAI,CAAC,SAAS,KAAK,SAAS;YAC5B,IAAI,CAAC,SAAS,CAAC,MAAM,KAAK,CAAC;YAC3B,IAAI,CAAC,OAAO,CAAC,MAAM,KAAK,CAAC;YACzB,IAAI,CAAC,SAAS,CAAC,MAAM,KAAK,IAAI,CAAC,OAAO,CAAC,MAAM;YAC7C,IAAI,CAAC,UAAU,KAAK,SAAS;YAC7B,IAAI,CAAC,YAAY,KAAK,SAAS;YAC/B,IAAI,CAAC,qBAAqB,KAAK,SAAS;YACxC,IAAI,CAAC,WAAW,KAAK,SAAS,CAC/B,CAAC;IACJ,CAAC;IACO,kBAAkB,CAAC,IAAY;QACrC,MAAM,YAAY,GAAG,iCAAyB,CAAC,IAAI,CAAC,CAAC;QACrD,IAAI,CAAC,UAAU,GAAG,YAAY,CAAC,EAAE,CAAC;QAClC,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC,IAAI,CAAC;QACtC,IAAI,CAAC,eAAe,GAAG,YAAY,CAAC,UAAU,CAAC;QAC/C,IAAI,CAAC,WAAW,GAAG,YAAY,CAAC,UAAU,CAAC;QAC3C,IAAI,CAAC,UAAU,GAAG,YAAY,CAAC,SAAS,CAAC;QACzC,IAAI,CAAC,qBAAqB,GAAG,YAAY,CAAC,oBAAoB,CAAC;QAC/D,IAAI,CAAC,SAAS,GAAG,YAAY,CAAC,QAAQ,CAAC;QACvC,IAAI,CAAC,OAAO,GAAG,YAAY,CAAC,MAAM,CAAC;QACnC,IAAI,YAAY,CAAC,IAAI,EAAE;YACrB,IAAI,CAAC,KAAK,GAAG,YAAY,CAAC,IAAI,CAAC;SAChC;IACH,CAAC;CACF;AAzFD,wDAyFC","sourcesContent":["import { BuildTransactionError, InvalidParameterValueError } from '@bitgo-beta/sdk-core';\nimport { hexlify, hexZeroPad } from 'ethers/lib/utils';\n\nimport { ContractCall } from '../contractCall';\nimport { decodeERC1155TransferData, isValidEthAddress, sendMultiSigData } from '../utils';\nimport {\n  ERC1155BatchTransferTypes,\n  ERC1155SafeTransferTypes,\n  ERC1155BatchTransferTypeMethodId,\n  ERC1155SafeTransferTypeMethodId,\n} from '../walletUtil';\nimport { BaseNFTTransferBuilder } from './baseNFTTransferBuilder';\n\nexport class ERC1155TransferBuilder extends BaseNFTTransferBuilder {\n  private _tokenIds: string[];\n  private _values: string[];\n  private _bytes: string;\n\n  constructor(serializedData?: string) {\n    super(serializedData);\n    this.bytes(0);\n    if (serializedData) {\n      this.decodeTransferData(serializedData);\n    } else {\n      this._tokenIds = [];\n      this._values = [];\n    }\n  }\n\n  tokenContractAddress(address: string): ERC1155TransferBuilder {\n    if (isValidEthAddress(address)) {\n      this._tokenContractAddress = address;\n      return this;\n    }\n    throw new InvalidParameterValueError('Invalid address');\n  }\n\n  entry(tokenId: number, value: number): ERC1155TransferBuilder {\n    this._tokenIds.push(tokenId.toString());\n    this._values.push(value.toString());\n    return this;\n  }\n\n  bytes(bytesInNumber: number): ERC1155TransferBuilder {\n    this._bytes = hexZeroPad(hexlify(bytesInNumber), 32);\n    return this;\n  }\n\n  signAndBuild(): string {\n    const hasMandatoryFields = this.hasMandatoryFields();\n    if (hasMandatoryFields) {\n      if (this._tokenIds.length === 1) {\n        const values = [this._fromAddress, this._toAddress, this._tokenIds[0], this._values[0], this._bytes];\n        const contractCall = new ContractCall(ERC1155SafeTransferTypeMethodId, ERC1155SafeTransferTypes, values);\n        this._data = contractCall.serialize();\n      } else {\n        const values = [this._fromAddress, this._toAddress, this._tokenIds, this._values, this._bytes];\n        const contractCall = new ContractCall(ERC1155BatchTransferTypeMethodId, ERC1155BatchTransferTypes, values);\n        this._data = contractCall.serialize();\n      }\n\n      return sendMultiSigData(\n        this._tokenContractAddress,\n        '0', // dummy amount value\n        this._data,\n        this._expirationTime,\n        this._sequenceId,\n        this.getSignature()\n      );\n    }\n    throw new BuildTransactionError(\n      `Missing transfer mandatory fields. \n       Destination (to) address, source (from) address, sequenceID, the token contract address, tokenIDs and their values are mandatory`\n    );\n  }\n\n  private hasMandatoryFields(): boolean {\n    return (\n      this._tokenIds !== undefined &&\n      this._tokenIds.length !== 0 &&\n      this._values.length !== 0 &&\n      this._tokenIds.length === this._values.length &&\n      this._toAddress !== undefined &&\n      this._fromAddress !== undefined &&\n      this._tokenContractAddress !== undefined &&\n      this._sequenceId !== undefined\n    );\n  }\n  private decodeTransferData(data: string): void {\n    const transferData = decodeERC1155TransferData(data);\n    this._toAddress = transferData.to;\n    this._fromAddress = transferData.from;\n    this._expirationTime = transferData.expireTime;\n    this._sequenceId = transferData.sequenceId;\n    this._signature = transferData.signature;\n    this._tokenContractAddress = transferData.tokenContractAddress;\n    this._tokenIds = transferData.tokenIds;\n    this._values = transferData.values;\n    if (transferData.data) {\n      this._data = transferData.data;\n    }\n  }\n}\n"]}