@bitgo-beta/abstract-eth 1.2.3-alpha.405 → 1.2.3-alpha.407

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 (155) hide show
  1. package/dist/src/abstractEthLikeCoin.d.ts +95 -0
  2. package/dist/src/abstractEthLikeCoin.d.ts.map +1 -0
  3. package/dist/src/abstractEthLikeCoin.js +160 -0
  4. package/dist/src/abstractEthLikeNewCoins.d.ts +749 -0
  5. package/dist/src/abstractEthLikeNewCoins.d.ts.map +1 -0
  6. package/dist/src/abstractEthLikeNewCoins.js +2229 -0
  7. package/dist/src/ethLikeToken.d.ts +70 -0
  8. package/dist/src/ethLikeToken.d.ts.map +1 -0
  9. package/dist/src/ethLikeToken.js +360 -0
  10. package/dist/src/index.d.ts +5 -0
  11. package/dist/src/index.d.ts.map +1 -0
  12. package/dist/src/index.js +21 -0
  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 +133 -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 +16 -0
  20. package/dist/src/lib/index.d.ts.map +1 -0
  21. package/dist/src/lib/index.js +57 -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 +65 -0
  25. package/dist/src/lib/messages/eip191/eip191Message.d.ts +12 -0
  26. package/dist/src/lib/messages/eip191/eip191Message.d.ts.map +1 -0
  27. package/dist/src/lib/messages/eip191/eip191Message.js +25 -0
  28. package/dist/src/lib/messages/eip191/eip191MessageBuilder.d.ts +19 -0
  29. package/dist/src/lib/messages/eip191/eip191MessageBuilder.d.ts.map +1 -0
  30. package/dist/src/lib/messages/eip191/eip191MessageBuilder.js +27 -0
  31. package/dist/src/lib/messages/eip191/index.d.ts +3 -0
  32. package/dist/src/lib/messages/eip191/index.d.ts.map +1 -0
  33. package/dist/src/lib/messages/eip191/index.js +19 -0
  34. package/dist/src/lib/messages/eip712/eip712Message.d.ts +6 -0
  35. package/dist/src/lib/messages/eip712/eip712Message.d.ts.map +1 -0
  36. package/dist/src/lib/messages/eip712/eip712Message.js +27 -0
  37. package/dist/src/lib/messages/eip712/eip712MessageBuilder.d.ts +7 -0
  38. package/dist/src/lib/messages/eip712/eip712MessageBuilder.d.ts.map +1 -0
  39. package/dist/src/lib/messages/eip712/eip712MessageBuilder.js +15 -0
  40. package/dist/src/lib/messages/eip712/index.d.ts +3 -0
  41. package/dist/src/lib/messages/eip712/index.d.ts.map +1 -0
  42. package/dist/src/lib/messages/eip712/index.js +19 -0
  43. package/dist/src/lib/messages/index.d.ts +4 -0
  44. package/dist/src/lib/messages/index.d.ts.map +1 -0
  45. package/dist/src/lib/messages/index.js +20 -0
  46. package/dist/src/lib/messages/messageBuilderFactory.d.ts +7 -0
  47. package/dist/src/lib/messages/messageBuilderFactory.d.ts.map +1 -0
  48. package/dist/src/lib/messages/messageBuilderFactory.js +23 -0
  49. package/dist/src/lib/transaction.d.ts +67 -0
  50. package/dist/src/lib/transaction.d.ts.map +1 -0
  51. package/dist/src/lib/transaction.js +142 -0
  52. package/dist/src/lib/transactionBuilder.d.ts +270 -0
  53. package/dist/src/lib/transactionBuilder.d.ts.map +1 -0
  54. package/dist/src/lib/transactionBuilder.js +822 -0
  55. package/dist/src/lib/transferBuilder.d.ts +76 -0
  56. package/dist/src/lib/transferBuilder.d.ts.map +1 -0
  57. package/dist/src/lib/transferBuilder.js +307 -0
  58. package/dist/src/lib/transferBuilders/baseNFTTransferBuilder.d.ts +54 -0
  59. package/dist/src/lib/transferBuilders/baseNFTTransferBuilder.d.ts.map +1 -0
  60. package/dist/src/lib/transferBuilders/baseNFTTransferBuilder.js +120 -0
  61. package/dist/src/lib/transferBuilders/index.d.ts +4 -0
  62. package/dist/src/lib/transferBuilders/index.d.ts.map +1 -0
  63. package/dist/src/lib/transferBuilders/index.js +20 -0
  64. package/dist/src/lib/transferBuilders/transferBuilderERC1155.d.ts +17 -0
  65. package/dist/src/lib/transferBuilders/transferBuilderERC1155.d.ts.map +1 -0
  66. package/dist/src/lib/transferBuilders/transferBuilderERC1155.js +96 -0
  67. package/dist/src/lib/transferBuilders/transferBuilderERC721.d.ts +16 -0
  68. package/dist/src/lib/transferBuilders/transferBuilderERC721.d.ts.map +1 -0
  69. package/dist/src/lib/transferBuilders/transferBuilderERC721.js +81 -0
  70. package/dist/src/lib/types.d.ts +39 -0
  71. package/dist/src/lib/types.d.ts.map +1 -0
  72. package/dist/src/lib/types.js +137 -0
  73. package/dist/src/lib/utils.d.ts +310 -0
  74. package/dist/src/lib/utils.d.ts.map +1 -0
  75. package/dist/src/lib/utils.js +829 -0
  76. package/dist/src/lib/walletUtil.d.ts +40 -0
  77. package/dist/src/lib/walletUtil.d.ts.map +1 -0
  78. package/dist/src/lib/walletUtil.js +43 -0
  79. package/dist/src/types.d.ts +9 -0
  80. package/dist/src/types.d.ts.map +1 -0
  81. package/dist/src/types.js +3 -0
  82. package/dist/test/index.d.ts +2 -0
  83. package/dist/test/index.d.ts.map +1 -0
  84. package/dist/test/index.js +18 -0
  85. package/dist/test/unit/coin.d.ts +8 -0
  86. package/dist/test/unit/coin.d.ts.map +1 -0
  87. package/dist/test/unit/coin.js +577 -0
  88. package/dist/test/unit/index.d.ts +6 -0
  89. package/dist/test/unit/index.d.ts.map +1 -0
  90. package/dist/test/unit/index.js +22 -0
  91. package/dist/test/unit/messages/abstractEthMessageBuilderTests.d.ts +3 -0
  92. package/dist/test/unit/messages/abstractEthMessageBuilderTests.d.ts.map +1 -0
  93. package/dist/test/unit/messages/abstractEthMessageBuilderTests.js +110 -0
  94. package/dist/test/unit/messages/abstractEthMessageTestTypes.d.ts +43 -0
  95. package/dist/test/unit/messages/abstractEthMessageTestTypes.d.ts.map +1 -0
  96. package/dist/test/unit/messages/abstractEthMessageTestTypes.js +3 -0
  97. package/dist/test/unit/messages/abstractEthMessagesTests.d.ts +3 -0
  98. package/dist/test/unit/messages/abstractEthMessagesTests.d.ts.map +1 -0
  99. package/dist/test/unit/messages/abstractEthMessagesTests.js +129 -0
  100. package/dist/test/unit/messages/eip191/eip191Message.d.ts +2 -0
  101. package/dist/test/unit/messages/eip191/eip191Message.d.ts.map +1 -0
  102. package/dist/test/unit/messages/eip191/eip191Message.js +15 -0
  103. package/dist/test/unit/messages/eip191/eip191MessageBuilder.d.ts +2 -0
  104. package/dist/test/unit/messages/eip191/eip191MessageBuilder.d.ts.map +1 -0
  105. package/dist/test/unit/messages/eip191/eip191MessageBuilder.js +16 -0
  106. package/dist/test/unit/messages/eip191/fixtures.d.ts +109 -0
  107. package/dist/test/unit/messages/eip191/fixtures.d.ts.map +1 -0
  108. package/dist/test/unit/messages/eip191/fixtures.js +63 -0
  109. package/dist/test/unit/messages/eip712/eip712Message.d.ts +2 -0
  110. package/dist/test/unit/messages/eip712/eip712Message.d.ts.map +1 -0
  111. package/dist/test/unit/messages/eip712/eip712Message.js +15 -0
  112. package/dist/test/unit/messages/eip712/eip712MessageBuilder.d.ts +2 -0
  113. package/dist/test/unit/messages/eip712/eip712MessageBuilder.d.ts.map +1 -0
  114. package/dist/test/unit/messages/eip712/eip712MessageBuilder.js +16 -0
  115. package/dist/test/unit/messages/eip712/fixtures.d.ts +76 -0
  116. package/dist/test/unit/messages/eip712/fixtures.d.ts.map +1 -0
  117. package/dist/test/unit/messages/eip712/fixtures.js +120 -0
  118. package/dist/test/unit/messages/index.d.ts +4 -0
  119. package/dist/test/unit/messages/index.d.ts.map +1 -0
  120. package/dist/test/unit/messages/index.js +20 -0
  121. package/dist/test/unit/messages/messageBuilderFactory.d.ts +2 -0
  122. package/dist/test/unit/messages/messageBuilderFactory.d.ts.map +1 -0
  123. package/dist/test/unit/messages/messageBuilderFactory.js +52 -0
  124. package/dist/test/unit/token.d.ts +2 -0
  125. package/dist/test/unit/token.d.ts.map +1 -0
  126. package/dist/test/unit/token.js +37 -0
  127. package/dist/test/unit/transaction.d.ts +3 -0
  128. package/dist/test/unit/transaction.d.ts.map +1 -0
  129. package/dist/test/unit/transaction.js +60 -0
  130. package/dist/test/unit/transactionBuilder/addressInitialization.d.ts +8 -0
  131. package/dist/test/unit/transactionBuilder/addressInitialization.d.ts.map +1 -0
  132. package/dist/test/unit/transactionBuilder/addressInitialization.js +95 -0
  133. package/dist/test/unit/transactionBuilder/flushNft.d.ts +2 -0
  134. package/dist/test/unit/transactionBuilder/flushNft.d.ts.map +1 -0
  135. package/dist/test/unit/transactionBuilder/flushNft.js +381 -0
  136. package/dist/test/unit/transactionBuilder/index.d.ts +5 -0
  137. package/dist/test/unit/transactionBuilder/index.d.ts.map +1 -0
  138. package/dist/test/unit/transactionBuilder/index.js +21 -0
  139. package/dist/test/unit/transactionBuilder/send.d.ts +3 -0
  140. package/dist/test/unit/transactionBuilder/send.d.ts.map +1 -0
  141. package/dist/test/unit/transactionBuilder/send.js +197 -0
  142. package/dist/test/unit/transactionBuilder/walletInitialization.d.ts +10 -0
  143. package/dist/test/unit/transactionBuilder/walletInitialization.d.ts.map +1 -0
  144. package/dist/test/unit/transactionBuilder/walletInitialization.js +124 -0
  145. package/dist/test/unit/transferBuilder.d.ts +2 -0
  146. package/dist/test/unit/transferBuilder.d.ts.map +1 -0
  147. package/dist/test/unit/transferBuilder.js +76 -0
  148. package/dist/test/unit/utils.d.ts +2 -0
  149. package/dist/test/unit/utils.d.ts.map +1 -0
  150. package/dist/test/unit/utils.js +184 -0
  151. package/dist/tsconfig.tsbuildinfo +1 -1
  152. package/package.json +11 -8
  153. package/.eslintignore +0 -5
  154. package/CHANGELOG.md +0 -1941
  155. package/index.ts +0 -2
@@ -0,0 +1,76 @@
1
+ /** ETH transfer builder */
2
+ export declare class TransferBuilder {
3
+ private readonly _EMPTY_HEX_VALUE;
4
+ protected _amount: string;
5
+ protected _toAddress: string;
6
+ protected _sequenceId: number;
7
+ protected _signKey: string | null;
8
+ protected _expirationTime: number;
9
+ protected _signature: string;
10
+ protected _isFirstSigner: boolean | undefined;
11
+ private _data;
12
+ private _tokenContractAddress?;
13
+ private _coin;
14
+ private _chainId?;
15
+ private _coinUsesNonPackedEncodingForTxData?;
16
+ private _walletVersion?;
17
+ constructor(serializedData?: string, isFirstSigner?: boolean);
18
+ /**
19
+ * A method to set the native coin or ERC20 token to be transferred.
20
+ * This ERC20 token may not be compatible with the network.
21
+ *
22
+ * @param {string} coin - the native coin or ERC20 token to be set
23
+ * @returns {TransferBuilder} the transfer builder instance modified
24
+ */
25
+ coin(coin: string): TransferBuilder;
26
+ getIsFirstSigner(): boolean;
27
+ walletVersion(version: number): TransferBuilder;
28
+ data(additionalData: string): TransferBuilder;
29
+ amount(amount: string): this;
30
+ to(address: string): TransferBuilder;
31
+ contractSequenceId(counter: number): TransferBuilder;
32
+ key(signKey: string): TransferBuilder;
33
+ expirationTime(date: number): TransferBuilder;
34
+ isFirstSigner(isFirstSigner: boolean): TransferBuilder;
35
+ tokenContractAddress(tokenContractAddress: string): TransferBuilder;
36
+ setCoinUsesNonPackedEncodingForTxData(isCoinUsesNonPackedEncodingForTxData: boolean): TransferBuilder;
37
+ setSignature(signature: string): TransferBuilder;
38
+ signAndBuild(chainId: string, coinUsesNonPackedEncodingForTxData?: boolean): string;
39
+ private hasMandatoryFields;
40
+ /**
41
+ * Obtains the proper operation hash to sign either a sendMultiSig data
42
+ * or a sendMultiSigToken data
43
+ *
44
+ * @returns {string} the operation hash
45
+ */
46
+ getOperationHash(): string;
47
+ protected getOperationData(): (string | number | Buffer)[][];
48
+ private getOperationHashPrefix;
49
+ /**
50
+ * Get the prefix used in generating an operation hash for sending tokens
51
+ *
52
+ * @returns the string prefix
53
+ */
54
+ protected getTokenOperationHashPrefix(): string;
55
+ /**
56
+ * Get the prefix used in generating an operation hash for sending native coins
57
+ *
58
+ * @returns the string prefix
59
+ */
60
+ protected getNativeOperationHashPrefix(): string;
61
+ /** Return an expiration time, in seconds, set to one hour from now
62
+ *
63
+ * @returns {number} expiration time
64
+ */
65
+ private getExpirationTime;
66
+ /**
67
+ * If a signing key is set for this builder, recalculates the signature
68
+ *
69
+ * @returns {string} the signature value
70
+ */
71
+ protected getSignature(): string;
72
+ protected ethSignMsgHash(): string;
73
+ private decodeTransferData;
74
+ getSignatureData(): Buffer<ArrayBuffer>;
75
+ }
76
+ //# sourceMappingURL=transferBuilder.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"transferBuilder.d.ts","sourceRoot":"","sources":["../../../src/lib/transferBuilder.ts"],"names":[],"mappings":"AAUA,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,GAAG,IAAI,CAAC;IAClC,SAAS,CAAC,eAAe,EAAE,MAAM,CAAC;IAClC,SAAS,CAAC,UAAU,EAAE,MAAM,CAAC;IAC7B,SAAS,CAAC,cAAc,EAAE,OAAO,GAAG,SAAS,CAAC;IAC9C,OAAO,CAAC,KAAK,CAAS;IACtB,OAAO,CAAC,qBAAqB,CAAC,CAAS;IACvC,OAAO,CAAC,KAAK,CAAqB;IAClC,OAAO,CAAC,QAAQ,CAAC,CAAS;IAC1B,OAAO,CAAC,mCAAmC,CAAC,CAAU;IACtD,OAAO,CAAC,cAAc,CAAC,CAAS;gBAEpB,cAAc,CAAC,EAAE,MAAM,EAAE,aAAa,CAAC,EAAE,OAAO;IAY5D;;;;;;OAMG;IACH,IAAI,CAAC,IAAI,EAAE,MAAM,GAAG,eAAe;IASnC,gBAAgB,IAAI,OAAO;IAI3B,aAAa,CAAC,OAAO,EAAE,MAAM,GAAG,eAAe;IAK/C,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,aAAa,CAAC,aAAa,EAAE,OAAO,GAAG,eAAe;IAKtD,oBAAoB,CAAC,oBAAoB,EAAE,MAAM,GAAG,eAAe;IAKnE,qCAAqC,CAAC,oCAAoC,EAAE,OAAO,GAAG,eAAe;IAKrG,YAAY,CAAC,SAAS,EAAE,MAAM,GAAG,eAAe;IAMhD,YAAY,CAAC,OAAO,EAAE,MAAM,EAAE,kCAAkC,CAAC,EAAE,OAAO,GAAG,MAAM;IAsCnF,OAAO,CAAC,kBAAkB;IAI1B;;;;;OAKG;IACI,gBAAgB,IAAI,MAAM;IAiBjC,SAAS,CAAC,gBAAgB,IAAI,CAAC,MAAM,GAAG,MAAM,GAAG,MAAM,CAAC,EAAE,EAAE;IAkC5D,OAAO,CAAC,sBAAsB;IAO9B;;;;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;IAqBlC,OAAO,CAAC,kBAAkB;IAkBnB,gBAAgB,IAAI,MAAM,CAAC,WAAW,CAAC;CAY/C"}
@@ -0,0 +1,307 @@
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
+ var __importDefault = (this && this.__importDefault) || function (mod) {
36
+ return (mod && mod.__esModule) ? mod : { "default": mod };
37
+ };
38
+ Object.defineProperty(exports, "__esModule", { value: true });
39
+ exports.TransferBuilder = void 0;
40
+ const assert_1 = __importDefault(require("assert"));
41
+ const ethUtil = __importStar(require("ethereumjs-util"));
42
+ const ethereumjs_abi_1 = __importDefault(require("ethereumjs-abi"));
43
+ const bn_js_1 = __importDefault(require("bn.js"));
44
+ const statics_1 = require("@bitgo-beta/statics");
45
+ const sdk_core_1 = require("@bitgo-beta/sdk-core");
46
+ const utils_1 = require("./utils");
47
+ const utils_2 = require("ethers/lib/utils");
48
+ const walletUtil_1 = require("./walletUtil");
49
+ /** ETH transfer builder */
50
+ class TransferBuilder {
51
+ constructor(serializedData, isFirstSigner) {
52
+ this._EMPTY_HEX_VALUE = '0x';
53
+ this._isFirstSigner = isFirstSigner;
54
+ if (serializedData) {
55
+ this.decodeTransferData(serializedData);
56
+ }
57
+ else {
58
+ // initialize with default values for non mandatory fields
59
+ this._expirationTime = this.getExpirationTime();
60
+ this._data = this._EMPTY_HEX_VALUE;
61
+ this._signature = this._EMPTY_HEX_VALUE;
62
+ }
63
+ }
64
+ /**
65
+ * A method to set the native coin or ERC20 token to be transferred.
66
+ * This ERC20 token may not be compatible with the network.
67
+ *
68
+ * @param {string} coin - the native coin or ERC20 token to be set
69
+ * @returns {TransferBuilder} the transfer builder instance modified
70
+ */
71
+ coin(coin) {
72
+ this._coin = statics_1.coins.get(coin);
73
+ if (this._coin instanceof statics_1.ContractAddressDefinedToken) {
74
+ this._tokenContractAddress = this._coin.contractAddress.toString();
75
+ }
76
+ return this;
77
+ }
78
+ getIsFirstSigner() {
79
+ return this._isFirstSigner ? this._isFirstSigner : false;
80
+ }
81
+ walletVersion(version) {
82
+ this._walletVersion = version;
83
+ return this;
84
+ }
85
+ data(additionalData) {
86
+ this._signature = this._EMPTY_HEX_VALUE;
87
+ this._data = additionalData;
88
+ return this;
89
+ }
90
+ amount(amount) {
91
+ if (!(0, utils_1.isValidAmount)(amount)) {
92
+ throw new sdk_core_1.InvalidParameterValueError('Invalid amount');
93
+ }
94
+ this._signature = this._EMPTY_HEX_VALUE;
95
+ this._amount = amount;
96
+ return this;
97
+ }
98
+ to(address) {
99
+ if ((0, utils_1.isValidEthAddress)(address)) {
100
+ this._signature = this._EMPTY_HEX_VALUE;
101
+ this._toAddress = address;
102
+ return this;
103
+ }
104
+ throw new sdk_core_1.InvalidParameterValueError('Invalid address');
105
+ }
106
+ contractSequenceId(counter) {
107
+ if (counter >= 0) {
108
+ this._signature = this._EMPTY_HEX_VALUE;
109
+ this._sequenceId = counter;
110
+ return this;
111
+ }
112
+ throw new sdk_core_1.InvalidParameterValueError('Invalid contract sequence id');
113
+ }
114
+ key(signKey) {
115
+ this._signKey = signKey;
116
+ return this;
117
+ }
118
+ expirationTime(date) {
119
+ if (date > 0) {
120
+ this._signature = this._EMPTY_HEX_VALUE;
121
+ this._expirationTime = date;
122
+ return this;
123
+ }
124
+ throw new sdk_core_1.InvalidParameterValueError('Invalid expiration time');
125
+ }
126
+ isFirstSigner(isFirstSigner) {
127
+ this._isFirstSigner = isFirstSigner;
128
+ return this;
129
+ }
130
+ tokenContractAddress(tokenContractAddress) {
131
+ this._tokenContractAddress = tokenContractAddress;
132
+ return this;
133
+ }
134
+ setCoinUsesNonPackedEncodingForTxData(isCoinUsesNonPackedEncodingForTxData) {
135
+ this._coinUsesNonPackedEncodingForTxData = isCoinUsesNonPackedEncodingForTxData;
136
+ return this;
137
+ }
138
+ setSignature(signature) {
139
+ this._signKey = null;
140
+ this._signature = ethUtil.addHexPrefix(signature);
141
+ return this;
142
+ }
143
+ signAndBuild(chainId, coinUsesNonPackedEncodingForTxData) {
144
+ this._chainId = chainId;
145
+ // If the coin uses non-packed encoding for tx data, the operation hash is calculated differently
146
+ // This new encoding type is applicable only for native coins and not tokens
147
+ this._coinUsesNonPackedEncodingForTxData =
148
+ coinUsesNonPackedEncodingForTxData && this._tokenContractAddress === undefined;
149
+ if (this.hasMandatoryFields()) {
150
+ if (this._isFirstSigner) {
151
+ // First signer signs different data than the second signer in multisig evm contracts.
152
+ return ethUtil.addHexPrefix(this.getSignatureData().toString('hex'));
153
+ }
154
+ else {
155
+ if (this._tokenContractAddress !== undefined) {
156
+ return (0, utils_1.sendMultiSigTokenData)(this._toAddress, this._amount, this._tokenContractAddress, this._expirationTime, this._sequenceId, this.getSignature());
157
+ }
158
+ else {
159
+ return (0, utils_1.sendMultiSigData)(this._toAddress, this._amount, this._data, this._expirationTime, this._sequenceId, this.getSignature());
160
+ }
161
+ }
162
+ }
163
+ throw new sdk_core_1.BuildTransactionError('Missing transfer mandatory fields. Amount, destination (to) address and sequenceID are mandatory');
164
+ }
165
+ hasMandatoryFields() {
166
+ return this._amount !== undefined && this._toAddress !== undefined && this._sequenceId !== undefined;
167
+ }
168
+ /**
169
+ * Obtains the proper operation hash to sign either a sendMultiSig data
170
+ * or a sendMultiSigToken data
171
+ *
172
+ * @returns {string} the operation hash
173
+ */
174
+ getOperationHash() {
175
+ const operationData = this.getOperationData();
176
+ let operationHash;
177
+ if (this._coinUsesNonPackedEncodingForTxData) {
178
+ const types = operationData[0];
179
+ const values = operationData[1].map((item) => typeof item === 'string' || typeof item === 'number' ? item : '0x' + item.toString('hex'));
180
+ operationHash = (0, utils_2.keccak256)(utils_2.defaultAbiCoder.encode(types, values));
181
+ }
182
+ else {
183
+ // If the coin uses packed encoding for tx data or it is a token, the operation hash is calculated using the Ethereum ABI
184
+ operationHash = ethUtil.bufferToHex(ethereumjs_abi_1.default.soliditySHA3(...operationData));
185
+ }
186
+ return operationHash;
187
+ }
188
+ getOperationData() {
189
+ let operationData;
190
+ const prefix = this.getOperationHashPrefix();
191
+ if (this._tokenContractAddress !== undefined) {
192
+ operationData = [
193
+ ['string', 'address', 'uint', 'address', 'uint', 'uint'],
194
+ [
195
+ prefix,
196
+ new bn_js_1.default(ethUtil.stripHexPrefix(this._toAddress), 16),
197
+ this._amount,
198
+ new bn_js_1.default(ethUtil.stripHexPrefix(this._tokenContractAddress), 16),
199
+ this._expirationTime,
200
+ this._sequenceId,
201
+ ],
202
+ ];
203
+ }
204
+ else {
205
+ const toAddress = this._coinUsesNonPackedEncodingForTxData
206
+ ? this._toAddress
207
+ : new bn_js_1.default(ethUtil.stripHexPrefix(this._toAddress), 16);
208
+ operationData = [
209
+ ['string', 'address', 'uint', 'bytes', 'uint', 'uint'],
210
+ [
211
+ prefix,
212
+ toAddress,
213
+ this._amount,
214
+ Buffer.from(ethUtil.padToEven(ethUtil.stripHexPrefix(this._data)) || '', 'hex'),
215
+ this._expirationTime,
216
+ this._sequenceId,
217
+ ],
218
+ ];
219
+ }
220
+ return operationData;
221
+ }
222
+ getOperationHashPrefix() {
223
+ if (this._walletVersion === 4) {
224
+ return this._tokenContractAddress ? `${this._chainId}-ERC20` : `${this._chainId}`;
225
+ }
226
+ return this._tokenContractAddress ? this.getTokenOperationHashPrefix() : this.getNativeOperationHashPrefix();
227
+ }
228
+ /**
229
+ * Get the prefix used in generating an operation hash for sending tokens
230
+ *
231
+ * @returns the string prefix
232
+ */
233
+ getTokenOperationHashPrefix() {
234
+ return this._coin?.network?.tokenOperationHashPrefix ?? `${this._chainId}-ERC20` ?? 'ERC20';
235
+ }
236
+ /**
237
+ * Get the prefix used in generating an operation hash for sending native coins
238
+ *
239
+ * @returns the string prefix
240
+ */
241
+ getNativeOperationHashPrefix() {
242
+ return this._coin?.network?.nativeCoinOperationHashPrefix ?? `${this._chainId}` ?? 'ETHER';
243
+ }
244
+ /** Return an expiration time, in seconds, set to one hour from now
245
+ *
246
+ * @returns {number} expiration time
247
+ */
248
+ getExpirationTime() {
249
+ const currentDate = new Date();
250
+ currentDate.setHours(currentDate.getHours() + 1);
251
+ return currentDate.getTime() / 1000;
252
+ }
253
+ /**
254
+ * If a signing key is set for this builder, recalculates the signature
255
+ *
256
+ * @returns {string} the signature value
257
+ */
258
+ getSignature() {
259
+ if (this._signKey) {
260
+ this._signature = this.ethSignMsgHash();
261
+ }
262
+ return this._signature;
263
+ }
264
+ ethSignMsgHash() {
265
+ const data = this.getOperationHash();
266
+ (0, assert_1.default)(this._signKey);
267
+ const keyBuffer = Buffer.from(ethUtil.padToEven(this._signKey), 'hex');
268
+ if (keyBuffer.length !== 32) {
269
+ throw new Error('private key length is invalid');
270
+ }
271
+ const signatureInParts = ethUtil.ecsign(Buffer.from(ethUtil.padToEven(ethUtil.stripHexPrefix(data)), 'hex'), keyBuffer);
272
+ // Assemble strings from r, s and v
273
+ const r = ethUtil.setLengthLeft(signatureInParts.r, 32).toString('hex');
274
+ const s = ethUtil.setLengthLeft(signatureInParts.s, 32).toString('hex');
275
+ const v = ethUtil.stripHexPrefix(ethUtil.intToHex(signatureInParts.v));
276
+ // Concatenate the r, s and v parts to make the signature string
277
+ return ethUtil.addHexPrefix(r.concat(s, v));
278
+ }
279
+ decodeTransferData(data) {
280
+ const transferData = (0, utils_1.decodeTransferData)(data, this._isFirstSigner);
281
+ this._toAddress = transferData.to;
282
+ this._amount = transferData.amount;
283
+ this._expirationTime = transferData.expireTime;
284
+ this._sequenceId = transferData.sequenceId;
285
+ this._signature = transferData.signature;
286
+ if (transferData.data) {
287
+ this._data = transferData.data;
288
+ }
289
+ if (transferData.tokenContractAddress) {
290
+ this._tokenContractAddress = transferData.tokenContractAddress;
291
+ }
292
+ }
293
+ getSignatureData() {
294
+ const method = this._tokenContractAddress
295
+ ? ethereumjs_abi_1.default.methodID('sendMultiSigToken', walletUtil_1.sendMultiSigTokenTypes)
296
+ : ethereumjs_abi_1.default.methodID('sendMultiSig', walletUtil_1.sendMultiSigTypes);
297
+ const operationData = this.getOperationData();
298
+ const rawEncodedOperationData = ethereumjs_abi_1.default.rawEncode(...operationData);
299
+ return Buffer.concat([
300
+ method,
301
+ rawEncodedOperationData,
302
+ Buffer.from([this._coinUsesNonPackedEncodingForTxData ? 1 : 0]),
303
+ ]);
304
+ }
305
+ }
306
+ exports.TransferBuilder = TransferBuilder;
307
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transferBuilder.js","sourceRoot":"","sources":["../../../src/lib/transferBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\nimport * as ethUtil from 'ethereumjs-util';\nimport EthereumAbi from 'ethereumjs-abi';\nimport BN from 'bn.js';\nimport { coins, BaseCoin, ContractAddressDefinedToken, EthereumNetwork as EthLikeNetwork } from '@bitgo-beta/statics';\nimport { BuildTransactionError, InvalidParameterValueError } from '@bitgo-beta/sdk-core';\nimport { decodeTransferData, sendMultiSigData, sendMultiSigTokenData, isValidEthAddress, isValidAmount } from './utils';\nimport { defaultAbiCoder, keccak256 } from 'ethers/lib/utils';\nimport { sendMultiSigTokenTypes, sendMultiSigTypes } from './walletUtil';\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 | null;\n  protected _expirationTime: number;\n  protected _signature: string;\n  protected _isFirstSigner: boolean | undefined;\n  private _data: string;\n  private _tokenContractAddress?: string;\n  private _coin: Readonly<BaseCoin>;\n  private _chainId?: string;\n  private _coinUsesNonPackedEncodingForTxData?: boolean;\n  private _walletVersion?: number;\n\n  constructor(serializedData?: string, isFirstSigner?: boolean) {\n    this._isFirstSigner = isFirstSigner;\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 native coin or ERC20 token to be transferred.\n   * This ERC20 token may not be compatible with the network.\n   *\n   * @param {string} coin - the native coin or ERC20 token to be set\n   * @returns {TransferBuilder} the transfer builder instance modified\n   */\n  coin(coin: string): TransferBuilder {\n    this._coin = coins.get(coin);\n    if (this._coin instanceof ContractAddressDefinedToken) {\n      this._tokenContractAddress = this._coin.contractAddress.toString();\n    }\n\n    return this;\n  }\n\n  getIsFirstSigner(): boolean {\n    return this._isFirstSigner ? this._isFirstSigner : false;\n  }\n\n  walletVersion(version: number): TransferBuilder {\n    this._walletVersion = version;\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  isFirstSigner(isFirstSigner: boolean): TransferBuilder {\n    this._isFirstSigner = isFirstSigner;\n    return this;\n  }\n\n  tokenContractAddress(tokenContractAddress: string): TransferBuilder {\n    this._tokenContractAddress = tokenContractAddress;\n    return this;\n  }\n\n  setCoinUsesNonPackedEncodingForTxData(isCoinUsesNonPackedEncodingForTxData: boolean): TransferBuilder {\n    this._coinUsesNonPackedEncodingForTxData = isCoinUsesNonPackedEncodingForTxData;\n    return this;\n  }\n\n  setSignature(signature: string): TransferBuilder {\n    this._signKey = null;\n    this._signature = ethUtil.addHexPrefix(signature);\n    return this;\n  }\n\n  signAndBuild(chainId: string, coinUsesNonPackedEncodingForTxData?: boolean): string {\n    this._chainId = chainId;\n\n    // If the coin uses non-packed encoding for tx data, the operation hash is calculated differently\n    // This new encoding type is applicable only for native coins and not tokens\n    this._coinUsesNonPackedEncodingForTxData =\n      coinUsesNonPackedEncodingForTxData && this._tokenContractAddress === undefined;\n    if (this.hasMandatoryFields()) {\n      if (this._isFirstSigner) {\n        // First signer signs different data than the second signer in multisig evm contracts.\n        return ethUtil.addHexPrefix(this.getSignatureData().toString('hex'));\n      } else {\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    }\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  public getOperationHash(): string {\n    const operationData = this.getOperationData();\n    let operationHash: string;\n\n    if (this._coinUsesNonPackedEncodingForTxData) {\n      const types: string[] = operationData[0] as string[];\n      const values: (string | number)[] = operationData[1].map((item) =>\n        typeof item === 'string' || typeof item === 'number' ? item : '0x' + item.toString('hex')\n      );\n      operationHash = keccak256(defaultAbiCoder.encode(types, values));\n    } else {\n      // If the coin uses packed encoding for tx data or it is a token, the operation hash is calculated using the Ethereum ABI\n      operationHash = ethUtil.bufferToHex(EthereumAbi.soliditySHA3(...operationData));\n    }\n    return operationHash;\n  }\n\n  protected getOperationData(): (string | number | Buffer)[][] {\n    let operationData;\n    const prefix = this.getOperationHashPrefix();\n    if (this._tokenContractAddress !== undefined) {\n      operationData = [\n        ['string', 'address', 'uint', 'address', 'uint', 'uint'],\n        [\n          prefix,\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      const toAddress = this._coinUsesNonPackedEncodingForTxData\n        ? this._toAddress\n        : new BN(ethUtil.stripHexPrefix(this._toAddress), 16);\n      operationData = [\n        ['string', 'address', 'uint', 'bytes', 'uint', 'uint'],\n        [\n          prefix,\n          toAddress,\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  private getOperationHashPrefix(): string {\n    if (this._walletVersion === 4) {\n      return this._tokenContractAddress ? `${this._chainId}-ERC20` : `${this._chainId}`;\n    }\n    return this._tokenContractAddress ? this.getTokenOperationHashPrefix() : this.getNativeOperationHashPrefix();\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 (this._coin?.network as EthLikeNetwork)?.tokenOperationHashPrefix ?? `${this._chainId}-ERC20` ?? '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 (this._coin?.network as EthLikeNetwork)?.nativeCoinOperationHashPrefix ?? `${this._chainId}` ?? '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    assert(this._signKey);\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, this._isFirstSigner);\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  public getSignatureData(): Buffer<ArrayBuffer> {\n    const method = this._tokenContractAddress\n      ? EthereumAbi.methodID('sendMultiSigToken', sendMultiSigTokenTypes)\n      : EthereumAbi.methodID('sendMultiSig', sendMultiSigTypes);\n    const operationData = this.getOperationData();\n    const rawEncodedOperationData = EthereumAbi.rawEncode(...operationData);\n    return Buffer.concat([\n      method,\n      rawEncodedOperationData,\n      Buffer.from([this._coinUsesNonPackedEncodingForTxData ? 1 : 0]),\n    ]);\n  }\n}\n"]}
@@ -0,0 +1,54 @@
1
+ import { BaseCoin } from '@bitgo-beta/statics';
2
+ export declare abstract class BaseNFTTransferBuilder {
3
+ protected readonly _EMPTY_HEX_VALUE = "0x";
4
+ protected _fromAddress: string;
5
+ protected _toAddress: string;
6
+ protected _sequenceId: number;
7
+ protected _signKey: string;
8
+ protected _expirationTime: number;
9
+ protected _signature: string;
10
+ protected _data: string;
11
+ protected _tokenContractAddress: string;
12
+ protected _coin: Readonly<BaseCoin>;
13
+ protected _nativeCoinOperationHashPrefix?: string;
14
+ protected _chainId?: string;
15
+ protected _walletVersion?: number;
16
+ abstract build(): string;
17
+ protected constructor(serializedData?: string);
18
+ expirationTime(date: number): this;
19
+ walletVersion(version: number): this;
20
+ key(signKey: string): this;
21
+ contractSequenceId(counter: number): this;
22
+ to(address: string): this;
23
+ from(address: string): this;
24
+ /** Return an expiration time, in seconds, set to one hour from now
25
+ *
26
+ * @returns {number} expiration time
27
+ */
28
+ private static getExpirationTime;
29
+ /**
30
+ * If a signing key is set for this builder, recalculates the signature
31
+ *
32
+ * @returns {string} the signature value
33
+ */
34
+ protected getSignature(): string;
35
+ /**
36
+ * Get the prefix used in generating an operation hash for sending native coins
37
+ *
38
+ * @returns the string prefix
39
+ */
40
+ protected getNativeOperationHashPrefix(): string;
41
+ /**
42
+ * Obtains the proper operation hash to sign either a sendMultiSig data
43
+ * or a sendMultiSigToken data
44
+ *
45
+ * @returns {string} the operation hash
46
+ */
47
+ private getOperationHash;
48
+ /**
49
+ * Signs the Message with the given private key
50
+ * @returns {string} 65 byte long raw signature
51
+ */
52
+ protected ethSignMsgHash(): string;
53
+ }
54
+ //# sourceMappingURL=baseNFTTransferBuilder.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"baseNFTTransferBuilder.d.ts","sourceRoot":"","sources":["../../../../src/lib/transferBuilders/baseNFTTransferBuilder.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAC;AAE/C,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;IACxC,SAAS,CAAC,KAAK,EAAE,QAAQ,CAAC,QAAQ,CAAC,CAAC;IACpC,SAAS,CAAC,8BAA8B,CAAC,EAAE,MAAM,CAAC;IAClD,SAAS,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAC5B,SAAS,CAAC,cAAc,CAAC,EAAE,MAAM,CAAC;aAElB,KAAK,IAAI,MAAM;IAE/B,SAAS,aAAa,cAAc,CAAC,EAAE,MAAM;IAS7C,cAAc,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI;IASlC,aAAa,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI;IAKpC,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;IAOhD;;;;;OAKG;IACH,OAAO,CAAC,gBAAgB;IAexB;;;OAGG;IACH,SAAS,CAAC,cAAc,IAAI,MAAM;CAOnC"}
@@ -0,0 +1,120 @@
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
+ walletVersion(version) {
26
+ this._walletVersion = version;
27
+ return this;
28
+ }
29
+ key(signKey) {
30
+ this._signKey = signKey;
31
+ return this;
32
+ }
33
+ contractSequenceId(counter) {
34
+ if (counter >= 0) {
35
+ this._signature = this._EMPTY_HEX_VALUE;
36
+ this._sequenceId = counter;
37
+ return this;
38
+ }
39
+ throw new sdk_core_1.InvalidParameterValueError('Invalid contract sequence id');
40
+ }
41
+ to(address) {
42
+ if ((0, utils_1.isValidEthAddress)(address)) {
43
+ this._signature = this._EMPTY_HEX_VALUE;
44
+ this._toAddress = address;
45
+ return this;
46
+ }
47
+ throw new sdk_core_1.InvalidParameterValueError('Invalid address');
48
+ }
49
+ from(address) {
50
+ if ((0, utils_1.isValidEthAddress)(address)) {
51
+ this._signature = this._EMPTY_HEX_VALUE;
52
+ this._fromAddress = address;
53
+ return this;
54
+ }
55
+ throw new sdk_core_1.InvalidParameterValueError('Invalid address');
56
+ }
57
+ /** Return an expiration time, in seconds, set to one hour from now
58
+ *
59
+ * @returns {number} expiration time
60
+ */
61
+ static getExpirationTime() {
62
+ const currentDate = new Date();
63
+ currentDate.setHours(currentDate.getHours() + 1);
64
+ return currentDate.getTime() / 1000;
65
+ }
66
+ /**
67
+ * If a signing key is set for this builder, recalculates the signature
68
+ *
69
+ * @returns {string} the signature value
70
+ */
71
+ getSignature() {
72
+ if (this._signKey) {
73
+ this._signature = this.ethSignMsgHash();
74
+ }
75
+ if (this._signature === null) {
76
+ throw new sdk_core_1.InvalidSignatureError('Null signature value');
77
+ }
78
+ return this._signature;
79
+ }
80
+ /**
81
+ * Get the prefix used in generating an operation hash for sending native coins
82
+ *
83
+ * @returns the string prefix
84
+ */
85
+ getNativeOperationHashPrefix() {
86
+ if (this._walletVersion === 4) {
87
+ return this._chainId ?? 'ETHER';
88
+ }
89
+ return this._nativeCoinOperationHashPrefix ?? this._chainId ?? 'ETHER';
90
+ }
91
+ /**
92
+ * Obtains the proper operation hash to sign either a sendMultiSig data
93
+ * or a sendMultiSigToken data
94
+ *
95
+ * @returns {string} the operation hash
96
+ */
97
+ getOperationHash() {
98
+ const hash = (0, utils_2.solidityKeccak256)(['string', 'address', 'uint', 'bytes', 'uint', 'uint'], [
99
+ this.getNativeOperationHashPrefix(),
100
+ this._toAddress,
101
+ '0', // dummy amount value
102
+ this._data,
103
+ this._expirationTime,
104
+ this._sequenceId,
105
+ ]);
106
+ return hash;
107
+ }
108
+ /**
109
+ * Signs the Message with the given private key
110
+ * @returns {string} 65 byte long raw signature
111
+ */
112
+ ethSignMsgHash() {
113
+ const signKey = new utils_2.SigningKey('0x'.concat(this._signKey));
114
+ const digest = signKey.signDigest(this.getOperationHash());
115
+ const rawSignature = (0, utils_2.joinSignature)(digest);
116
+ return rawSignature;
117
+ }
118
+ }
119
+ exports.BaseNFTTransferBuilder = BaseNFTTransferBuilder;
120
+ //# 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';\nimport { BaseCoin } from '@bitgo-beta/statics';\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  protected _coin: Readonly<BaseCoin>;\n  protected _nativeCoinOperationHashPrefix?: string;\n  protected _chainId?: string;\n  protected _walletVersion?: number;\n\n  public abstract build(): 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  walletVersion(version: number): this {\n    this._walletVersion = version;\n    return this;\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    if (this._walletVersion === 4) {\n      return this._chainId ?? 'ETHER';\n    }\n    return this._nativeCoinOperationHashPrefix ?? this._chainId ?? '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"}