@bitgo/sdk-coin-xtz 2.4.12 → 2.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -3,6 +3,16 @@
3
3
  All notable changes to this project will be documented in this file.
4
4
  See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
5
5
 
6
+ # [2.5.0](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-coin-xtz@2.4.13...@bitgo/sdk-coin-xtz@2.5.0) (2025-08-19)
7
+
8
+ ### Features
9
+
10
+ - **sdk-coin-xtz:** add xtz recovery ([8875500](https://github.com/BitGo/BitGoJS/commit/8875500a979e61c51a092c1e9c48810b906e1c16))
11
+
12
+ ## [2.4.13](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-coin-xtz@2.4.12...@bitgo/sdk-coin-xtz@2.4.13) (2025-08-14)
13
+
14
+ **Note:** Version bump only for package @bitgo/sdk-coin-xtz
15
+
6
16
  ## [2.4.12](https://github.com/BitGo/BitGoJS/compare/@bitgo/sdk-coin-xtz@2.4.11...@bitgo/sdk-coin-xtz@2.4.12) (2025-08-07)
7
17
 
8
18
  **Note:** Version bump only for package @bitgo/sdk-coin-xtz
@@ -111,4 +111,38 @@ export interface Key extends BaseKey, IndexedData {
111
111
  export interface IndexedSignature extends IndexedData {
112
112
  signature: string;
113
113
  }
114
+ export type RecoverOptions = {
115
+ userKey: string;
116
+ backupKey: string;
117
+ walletPassphrase?: string;
118
+ walletContractAddress: string;
119
+ recoveryDestination: string;
120
+ krsProvider?: string;
121
+ gasPrice?: number;
122
+ gasLimit?: number;
123
+ bitgoFeeAddress?: string;
124
+ bitgoDestinationAddress?: string;
125
+ tokenContractAddress?: string;
126
+ intendedChain?: string;
127
+ derivationSeed?: string;
128
+ apiKey?: string;
129
+ isUnsignedSweep?: boolean;
130
+ };
131
+ export interface OfflineVaultTxInfo {
132
+ nextContractSequenceId?: string;
133
+ contractSequenceId?: string;
134
+ tx?: string;
135
+ txHex?: string;
136
+ userKey?: string;
137
+ backupKey?: string;
138
+ coin: string;
139
+ gasPrice: number;
140
+ gasLimit: number;
141
+ recipients: Recipient[];
142
+ walletContractAddress: string;
143
+ amount: string;
144
+ backupKeyNonce: number;
145
+ isEvmBasedCrossChainRecovery?: boolean;
146
+ walletVersion?: number;
147
+ }
114
148
  //# sourceMappingURL=iface.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"iface.d.ts","sourceRoot":"","sources":["../../../src/lib/iface.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"iface.d.ts","sourceRoot":"","sources":["../../../src/lib/iface.ts"],"names":[],"mappings":"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"}
@@ -1,3 +1,3 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL2lmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBCYXNlRmVlLFxuICBCYXNlS2V5LFxuICBTaWduVHJhbnNhY3Rpb25PcHRpb25zLFxuICBUcmFuc2FjdGlvbkZlZSxcbiAgVHJhbnNhY3Rpb25SZWNpcGllbnQgYXMgUmVjaXBpZW50LFxuICBUcmFuc2FjdGlvblByZWJ1aWxkIGFzIEJhc2VUcmFuc2FjdGlvblByZWJ1aWxkLFxufSBmcm9tICdAYml0Z28vc2RrLWNvcmUnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFh0elNpZ25UcmFuc2FjdGlvbk9wdGlvbnMgZXh0ZW5kcyBTaWduVHJhbnNhY3Rpb25PcHRpb25zIHtcbiAgdHhQcmVidWlsZDogVHJhbnNhY3Rpb25QcmVidWlsZDtcbiAgcHJ2OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVHhJbmZvIHtcbiAgcmVjaXBpZW50czogUmVjaXBpZW50W107XG4gIGZyb206IHN0cmluZztcbiAgdHhpZDogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFkZHJlc3NJbmZvIHtcbiAgYWRkcmVzczogc3RyaW5nO1xuICBjaGFpbjogbnVtYmVyO1xuICBpbmRleDogbnVtYmVyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFRyYW5zYWN0aW9uUHJlYnVpbGQgZXh0ZW5kcyBCYXNlVHJhbnNhY3Rpb25QcmVidWlsZCB7XG4gIHR4SGV4OiBzdHJpbmc7XG4gIHR4SW5mbzogVHhJbmZvO1xuICBhZGRyZXNzSW5mbzogQWRkcmVzc0luZm87XG4gIGZlZUluZm86IFh0elRyYW5zYWN0aW9uRmVlO1xuICBzb3VyY2U6IHN0cmluZztcbiAgZGF0YVRvU2lnbjogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFh0elRyYW5zYWN0aW9uRmVlIHtcbiAgZmVlOiBzdHJpbmc7XG4gIGdhc0xpbWl0Pzogc3RyaW5nO1xuICBzdG9yYWdlTGltaXQ/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRXhwbGFpblRyYW5zYWN0aW9uT3B0aW9ucyB7XG4gIHR4SGV4Pzogc3RyaW5nO1xuICBoYWxmU2lnbmVkPzoge1xuICAgIHR4SGV4OiBzdHJpbmc7XG4gIH07XG4gIGZlZUluZm86IFRyYW5zYWN0aW9uRmVlO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEhhc2hUeXBlIHtcbiAgcHJlZml4OiBCdWZmZXI7XG4gIGJ5dGVMZW5ndGg6IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBPcGVyYXRpb24ge1xuICBraW5kOiBzdHJpbmc7XG4gIGNvdW50ZXI6IHN0cmluZztcbiAgc291cmNlOiBzdHJpbmc7XG4gIGZlZTogc3RyaW5nO1xuICBnYXNfbGltaXQ6IHN0cmluZztcbiAgc3RvcmFnZV9saW1pdDogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFJldmVhbE9wIGV4dGVuZHMgT3BlcmF0aW9uIHtcbiAgcHVibGljX2tleTogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE9yaWdpbmF0aW9uT3AgZXh0ZW5kcyBPcGVyYXRpb24ge1xuICBiYWxhbmNlOiBzdHJpbmc7XG4gIHNjcmlwdDogYW55O1xuICBkZWxlZ2F0ZT86IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBUcmFuc2FjdGlvbk9wIGV4dGVuZHMgT3BlcmF0aW9uIHtcbiAgcGFyYW1ldGVycz86IGFueTtcbiAgZGVzdGluYXRpb246IHN0cmluZztcbiAgYW1vdW50OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGFyc2VkVHJhbnNhY3Rpb24ge1xuICBicmFuY2g6IHN0cmluZztcbiAgY29udGVudHM6IE9wZXJhdGlvbltdO1xufVxuXG4vKipcbiAqIERpZmZlcmVudCBUZXpvcyBzcGVjaWZpYyBmZWVzXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRmVlIGV4dGVuZHMgQmFzZUZlZSB7XG4gIGdhc0xpbWl0Pzogc3RyaW5nO1xuICBzdG9yYWdlTGltaXQ/OiBzdHJpbmc7XG59XG5cbi8qKlxuICogU2VuZCB0cmFuc2FjdGlvbiBpbmZvcm1hdGlvblxuICovXG5leHBvcnQgaW50ZXJmYWNlIFRyYW5zZmVyRGF0YSB7XG4gIGFtb3VudDogc3RyaW5nO1xuICBjb2luPzogc3RyaW5nO1xuICBmcm9tOiBzdHJpbmc7XG4gIHRvOiBzdHJpbmc7XG4gIGZlZTogRmVlO1xuICBkYXRhVG9TaWduPzogc3RyaW5nO1xuICBjb3VudGVyPzogc3RyaW5nO1xufVxuXG4vKipcbiAqIE9yaWdpbmF0aW9uIHRyYW5zYWN0aW9uIGluZm9ybWF0aW9uXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgT3JpZ2luYXRpb25EYXRhIHtcbiAgZmVlOiBGZWU7XG4gIGNvdW50ZXI/OiBzdHJpbmc7XG4gIGJhbGFuY2U/OiBzdHJpbmc7XG4gIGZyb20/OiBzdHJpbmc7XG4gIGZvcndhcmRlckRlc3RpbmF0aW9uPzogc3RyaW5nO1xufVxuLyoqXG4gKiBUYXF1aXRvIHJldHVybiB0eXBlIGZvciBzaWduIG9wZXJhdGlvbnNcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBTaWduUmVzcG9uc2Uge1xuICBieXRlczogc3RyaW5nO1xuICBzaWc6IGFueTtcbiAgcHJlZml4U2lnOiBhbnk7XG4gIHNieXRlczogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEluZGV4ZWREYXRhIHtcbiAgaW5kZXg/OiBudW1iZXI7XG59XG5cbi8qKlxuICogVGV6b3Mga2V5cyBjYW4gaGF2ZSBhIHNwZWNpZmljIG9yZGVyIGluIHRoZSBzbWFydCBjb250cmFjdHMsIGhlbmNlIHRoZSBuZWVkIHRvIGFkZCBhbiBpbmRleCBmaWVsZFxuICovXG5leHBvcnQgaW50ZXJmYWNlIEtleSBleHRlbmRzIEJhc2VLZXksIEluZGV4ZWREYXRhIHt9XG5cbmV4cG9ydCBpbnRlcmZhY2UgSW5kZXhlZFNpZ25hdHVyZSBleHRlbmRzIEluZGV4ZWREYXRhIHtcbiAgc2lnbmF0dXJlOiBzdHJpbmc7XG59XG4iXX0=
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL2lmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBCYXNlRmVlLFxuICBCYXNlS2V5LFxuICBTaWduVHJhbnNhY3Rpb25PcHRpb25zLFxuICBUcmFuc2FjdGlvbkZlZSxcbiAgVHJhbnNhY3Rpb25SZWNpcGllbnQgYXMgUmVjaXBpZW50LFxuICBUcmFuc2FjdGlvblByZWJ1aWxkIGFzIEJhc2VUcmFuc2FjdGlvblByZWJ1aWxkLFxufSBmcm9tICdAYml0Z28vc2RrLWNvcmUnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFh0elNpZ25UcmFuc2FjdGlvbk9wdGlvbnMgZXh0ZW5kcyBTaWduVHJhbnNhY3Rpb25PcHRpb25zIHtcbiAgdHhQcmVidWlsZDogVHJhbnNhY3Rpb25QcmVidWlsZDtcbiAgcHJ2OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVHhJbmZvIHtcbiAgcmVjaXBpZW50czogUmVjaXBpZW50W107XG4gIGZyb206IHN0cmluZztcbiAgdHhpZDogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFkZHJlc3NJbmZvIHtcbiAgYWRkcmVzczogc3RyaW5nO1xuICBjaGFpbjogbnVtYmVyO1xuICBpbmRleDogbnVtYmVyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFRyYW5zYWN0aW9uUHJlYnVpbGQgZXh0ZW5kcyBCYXNlVHJhbnNhY3Rpb25QcmVidWlsZCB7XG4gIHR4SGV4OiBzdHJpbmc7XG4gIHR4SW5mbzogVHhJbmZvO1xuICBhZGRyZXNzSW5mbzogQWRkcmVzc0luZm87XG4gIGZlZUluZm86IFh0elRyYW5zYWN0aW9uRmVlO1xuICBzb3VyY2U6IHN0cmluZztcbiAgZGF0YVRvU2lnbjogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFh0elRyYW5zYWN0aW9uRmVlIHtcbiAgZmVlOiBzdHJpbmc7XG4gIGdhc0xpbWl0Pzogc3RyaW5nO1xuICBzdG9yYWdlTGltaXQ/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRXhwbGFpblRyYW5zYWN0aW9uT3B0aW9ucyB7XG4gIHR4SGV4Pzogc3RyaW5nO1xuICBoYWxmU2lnbmVkPzoge1xuICAgIHR4SGV4OiBzdHJpbmc7XG4gIH07XG4gIGZlZUluZm86IFRyYW5zYWN0aW9uRmVlO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEhhc2hUeXBlIHtcbiAgcHJlZml4OiBCdWZmZXI7XG4gIGJ5dGVMZW5ndGg6IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBPcGVyYXRpb24ge1xuICBraW5kOiBzdHJpbmc7XG4gIGNvdW50ZXI6IHN0cmluZztcbiAgc291cmNlOiBzdHJpbmc7XG4gIGZlZTogc3RyaW5nO1xuICBnYXNfbGltaXQ6IHN0cmluZztcbiAgc3RvcmFnZV9saW1pdDogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFJldmVhbE9wIGV4dGVuZHMgT3BlcmF0aW9uIHtcbiAgcHVibGljX2tleTogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE9yaWdpbmF0aW9uT3AgZXh0ZW5kcyBPcGVyYXRpb24ge1xuICBiYWxhbmNlOiBzdHJpbmc7XG4gIHNjcmlwdDogYW55O1xuICBkZWxlZ2F0ZT86IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBUcmFuc2FjdGlvbk9wIGV4dGVuZHMgT3BlcmF0aW9uIHtcbiAgcGFyYW1ldGVycz86IGFueTtcbiAgZGVzdGluYXRpb246IHN0cmluZztcbiAgYW1vdW50OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGFyc2VkVHJhbnNhY3Rpb24ge1xuICBicmFuY2g6IHN0cmluZztcbiAgY29udGVudHM6IE9wZXJhdGlvbltdO1xufVxuXG4vKipcbiAqIERpZmZlcmVudCBUZXpvcyBzcGVjaWZpYyBmZWVzXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRmVlIGV4dGVuZHMgQmFzZUZlZSB7XG4gIGdhc0xpbWl0Pzogc3RyaW5nO1xuICBzdG9yYWdlTGltaXQ/OiBzdHJpbmc7XG59XG5cbi8qKlxuICogU2VuZCB0cmFuc2FjdGlvbiBpbmZvcm1hdGlvblxuICovXG5leHBvcnQgaW50ZXJmYWNlIFRyYW5zZmVyRGF0YSB7XG4gIGFtb3VudDogc3RyaW5nO1xuICBjb2luPzogc3RyaW5nO1xuICBmcm9tOiBzdHJpbmc7XG4gIHRvOiBzdHJpbmc7XG4gIGZlZTogRmVlO1xuICBkYXRhVG9TaWduPzogc3RyaW5nO1xuICBjb3VudGVyPzogc3RyaW5nO1xufVxuXG4vKipcbiAqIE9yaWdpbmF0aW9uIHRyYW5zYWN0aW9uIGluZm9ybWF0aW9uXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgT3JpZ2luYXRpb25EYXRhIHtcbiAgZmVlOiBGZWU7XG4gIGNvdW50ZXI/OiBzdHJpbmc7XG4gIGJhbGFuY2U/OiBzdHJpbmc7XG4gIGZyb20/OiBzdHJpbmc7XG4gIGZvcndhcmRlckRlc3RpbmF0aW9uPzogc3RyaW5nO1xufVxuLyoqXG4gKiBUYXF1aXRvIHJldHVybiB0eXBlIGZvciBzaWduIG9wZXJhdGlvbnNcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBTaWduUmVzcG9uc2Uge1xuICBieXRlczogc3RyaW5nO1xuICBzaWc6IGFueTtcbiAgcHJlZml4U2lnOiBhbnk7XG4gIHNieXRlczogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEluZGV4ZWREYXRhIHtcbiAgaW5kZXg/OiBudW1iZXI7XG59XG5cbi8qKlxuICogVGV6b3Mga2V5cyBjYW4gaGF2ZSBhIHNwZWNpZmljIG9yZGVyIGluIHRoZSBzbWFydCBjb250cmFjdHMsIGhlbmNlIHRoZSBuZWVkIHRvIGFkZCBhbiBpbmRleCBmaWVsZFxuICovXG5leHBvcnQgaW50ZXJmYWNlIEtleSBleHRlbmRzIEJhc2VLZXksIEluZGV4ZWREYXRhIHt9XG5cbmV4cG9ydCBpbnRlcmZhY2UgSW5kZXhlZFNpZ25hdHVyZSBleHRlbmRzIEluZGV4ZWREYXRhIHtcbiAgc2lnbmF0dXJlOiBzdHJpbmc7XG59XG5cbmV4cG9ydCB0eXBlIFJlY292ZXJPcHRpb25zID0ge1xuICB1c2VyS2V5OiBzdHJpbmc7XG4gIGJhY2t1cEtleTogc3RyaW5nO1xuICB3YWxsZXRQYXNzcGhyYXNlPzogc3RyaW5nO1xuICB3YWxsZXRDb250cmFjdEFkZHJlc3M6IHN0cmluZzsgLy8gdXNlIHRoaXMgYXMgd2FsbGV0QmFzZUFkZHJlc3MgZm9yIFRTU1xuICByZWNvdmVyeURlc3RpbmF0aW9uOiBzdHJpbmc7XG4gIGtyc1Byb3ZpZGVyPzogc3RyaW5nO1xuICBnYXNQcmljZT86IG51bWJlcjtcbiAgZ2FzTGltaXQ/OiBudW1iZXI7XG4gIGJpdGdvRmVlQWRkcmVzcz86IHN0cmluZztcbiAgYml0Z29EZXN0aW5hdGlvbkFkZHJlc3M/OiBzdHJpbmc7XG4gIHRva2VuQ29udHJhY3RBZGRyZXNzPzogc3RyaW5nO1xuICBpbnRlbmRlZENoYWluPzogc3RyaW5nO1xuICBkZXJpdmF0aW9uU2VlZD86IHN0cmluZztcbiAgYXBpS2V5Pzogc3RyaW5nO1xuICBpc1Vuc2lnbmVkU3dlZXA/OiBib29sZWFuO1xufTtcblxuZXhwb3J0IGludGVyZmFjZSBPZmZsaW5lVmF1bHRUeEluZm8ge1xuICBuZXh0Q29udHJhY3RTZXF1ZW5jZUlkPzogc3RyaW5nO1xuICBjb250cmFjdFNlcXVlbmNlSWQ/OiBzdHJpbmc7XG4gIHR4Pzogc3RyaW5nO1xuICB0eEhleD86IHN0cmluZztcbiAgdXNlcktleT86IHN0cmluZztcbiAgYmFja3VwS2V5Pzogc3RyaW5nO1xuICBjb2luOiBzdHJpbmc7XG4gIGdhc1ByaWNlOiBudW1iZXI7XG4gIGdhc0xpbWl0OiBudW1iZXI7XG4gIHJlY2lwaWVudHM6IFJlY2lwaWVudFtdO1xuICB3YWxsZXRDb250cmFjdEFkZHJlc3M6IHN0cmluZztcbiAgYW1vdW50OiBzdHJpbmc7XG4gIGJhY2t1cEtleU5vbmNlOiBudW1iZXI7XG4gIGlzRXZtQmFzZWRDcm9zc0NoYWluUmVjb3Zlcnk/OiBib29sZWFuO1xuICB3YWxsZXRWZXJzaW9uPzogbnVtYmVyO1xufVxuIl19
@@ -261,4 +261,20 @@ export declare enum DEFAULT_STORAGE_LIMIT {
261
261
  TRANSFER = 257,
262
262
  REVEAL = 0
263
263
  }
264
+ export declare enum TRANSACTION_FEE {
265
+ ORIGINATION = 47640,
266
+ TRANSFER = 47640,
267
+ REVEAL = 1420
268
+ }
269
+ export declare enum TRANSACTION_STORAGE_LIMIT {
270
+ ORIGINATION = 3000,
271
+ TRANSFER = 300,
272
+ REVEAL = 5
273
+ }
274
+ export declare enum TRANSACTION_GAS_LIMIT {
275
+ ORIGINATION = 4600,
276
+ TRANSFER = 6000,
277
+ CONTRACT_TRANSFER = 20000,
278
+ REVEAL = 1500
279
+ }
264
280
  //# sourceMappingURL=utils.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/lib/utils.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/lib/utils.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AACjD,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAIpC,eAAO,MAAM,iBAAiB,yBAAsB,CAAC;AAErD;;;;;;GAMG;AACH,wBAAgB,YAAY,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,MAAM,CAMpE;AAED;;;;;GAKG;AACH,wBAAsB,sBAAsB,CAAC,kBAAkB,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAKxF;AAED;;;;;;GAMG;AACH,wBAAsB,0BAA0B,CAAC,aAAa,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAmBtG;AAED;;;;;;;GAOG;AACH,wBAAsB,IAAI,CACxB,OAAO,EAAE,OAAO,EAChB,IAAI,EAAE,MAAM,EACZ,SAAS,GAAE,UAA8B,GACxC,OAAO,CAAC,YAAY,CAAC,CAMvB;AAED;;;;;;;;GAQG;AACH,wBAAsB,eAAe,CACnC,OAAO,EAAE,MAAM,EACf,SAAS,EAAE,MAAM,EACjB,SAAS,EAAE,MAAM,EACjB,SAAS,GAAE,UAA8B,GACxC,OAAO,CAAC,OAAO,CAAC,CAelB;AAED;;;;;;;;GAQG;AACH,wBAAgB,kBAAkB,CAChC,eAAe,EAAE,MAAM,EACvB,kBAAkB,EAAE,MAAM,EAC1B,MAAM,EAAE,MAAM,EACd,eAAe,EAAE,MAAM,GACtB,GAAG,CAQL;AAED;;;;;;GAMG;AACH,wBAAgB,WAAW,CAAC,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,GAAG,OAAO,CAkBrE;AAED;;;;;GAKG;AACH,wBAAgB,cAAc,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAEpD;AAED;;;;;GAKG;AACH,wBAAgB,sBAAsB,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAE5D;AAED;;;;;GAKG;AACH,wBAAgB,wBAAwB,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAE9D;AAED;;;;;GAKG;AACH,wBAAgB,gBAAgB,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAOtD;AAED;;;;;GAKG;AACH,wBAAgB,gBAAgB,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAO3D;AAED;;;;;GAKG;AACH,wBAAgB,iBAAiB,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAO7D;AAED;;;;;GAKG;AACH,wBAAgB,gBAAgB,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAEtD;AAED;;;;;GAKG;AACH,wBAAgB,sBAAsB,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAE5D;AAED;;;;;;GAMG;AACH,wBAAgB,UAAU,CAAC,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,GAAG,OAAO,CAEpE;AAED;;;;;;GAMG;AACH,wBAAgB,SAAS,CAAC,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,GAAG,MAAM,CAMlE;AAED;;;;;;GAMG;AACH,wBAAgB,eAAe,CAAC,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,GAAG,MAAM,CAM7E;AAKD,eAAO,MAAM,SAAS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAoIrB,CAAC;AAIF,oBAAY,iBAAiB;IAC3B,UAAU,QAAQ;IAClB,WAAW,QAAQ;IACnB,QAAQ,QAAQ;IAChB,MAAM,QAAQ;CACf;AAED,oBAAY,WAAW;IACrB,UAAU,OAAO;IACjB,WAAW,QAAQ;IACnB,QAAQ,QAAQ;IAChB,MAAM,OAAO;CACd;AAED,oBAAY,qBAAqB;IAC/B,UAAU,IAAI;IACd,WAAW,MAAM;IACjB,QAAQ,MAAM;IACd,MAAM,IAAI;CACX;AAED,oBAAY,eAAe;IACzB,WAAW,QAAQ;IACnB,QAAQ,QAAQ;IAChB,MAAM,OAAO;CACd;AAED,oBAAY,yBAAyB;IACnC,WAAW,OAAO;IAClB,QAAQ,MAAM;IACd,MAAM,IAAI;CACX;AAED,oBAAY,qBAAqB;IAC/B,WAAW,OAAO;IAClB,QAAQ,OAAO;IACf,iBAAiB,QAAQ;IACzB,MAAM,OAAO;CACd"}
@@ -36,7 +36,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
36
36
  return (mod && mod.__esModule) ? mod : { "default": mod };
37
37
  };
38
38
  Object.defineProperty(exports, "__esModule", { value: true });
39
- exports.DEFAULT_STORAGE_LIMIT = exports.DEFAULT_FEE = exports.DEFAULT_GAS_LIMIT = exports.hashTypes = exports.DEFAULT_WATERMARK = void 0;
39
+ exports.TRANSACTION_GAS_LIMIT = exports.TRANSACTION_STORAGE_LIMIT = exports.TRANSACTION_FEE = exports.DEFAULT_STORAGE_LIMIT = exports.DEFAULT_FEE = exports.DEFAULT_GAS_LIMIT = exports.hashTypes = exports.DEFAULT_WATERMARK = void 0;
40
40
  exports.base58encode = base58encode;
41
41
  exports.calculateTransactionId = calculateTransactionId;
42
42
  exports.calculateOriginatedAddress = calculateOriginatedAddress;
@@ -470,4 +470,23 @@ var DEFAULT_STORAGE_LIMIT;
470
470
  DEFAULT_STORAGE_LIMIT[DEFAULT_STORAGE_LIMIT["TRANSFER"] = 257] = "TRANSFER";
471
471
  DEFAULT_STORAGE_LIMIT[DEFAULT_STORAGE_LIMIT["REVEAL"] = 0] = "REVEAL";
472
472
  })(DEFAULT_STORAGE_LIMIT || (exports.DEFAULT_STORAGE_LIMIT = DEFAULT_STORAGE_LIMIT = {}));
473
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/lib/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { isValidXpub, SigningError } from '@bitgo/sdk-core';\nimport { InMemorySigner } from '@taquito/signer';\nimport * as base58check from 'bs58check';\nimport { secp256k1 } from '@noble/curves/secp256k1';\nimport sodium from 'libsodium-wrappers';\nimport { HashType, SignResponse } from './iface';\nimport { KeyPair } from './keyPair';\nimport { genericMultisigDataToSign } from './multisigUtils';\n\n// By default, use the transactions prefix\nexport const DEFAULT_WATERMARK = new Uint8Array([3]);\n\n/**\n * Encode the payload to base58 with a specific Tezos prefix.\n *\n * @param {Buffer} prefix to add to the encoded payload\n * @param {Buffer} payload to encode\n * @returns {any} base58 payload with a Tezos prefix\n */\nexport function base58encode(prefix: Buffer, payload: Buffer): string {\n  const n = Buffer.alloc(prefix.length + payload.length);\n  n.set(prefix);\n  n.set(payload, prefix.length);\n\n  return base58check.encode(n);\n}\n\n/**\n * Calculate the transaction id for a for a signed transaction.\n *\n * @param {string} encodedTransaction Signed transaction in hexadecimal\n * @returns {Promise<string>} The transaction id\n */\nexport async function calculateTransactionId(encodedTransaction: string): Promise<string> {\n  await sodium.ready;\n  const encodedTransactionBuffer = Uint8Array.from(Buffer.from(encodedTransaction, 'hex'));\n  const operationHashPayload = sodium.crypto_generichash(32, encodedTransactionBuffer);\n  return base58encode(hashTypes.o.prefix, Buffer.from(operationHashPayload));\n}\n\n/**\n * Calculate the address of a new originated account.\n *\n * @param {string} transactionId The transaction id\n * @param {number} index The index of the origination operation inside the transaction (starts at 0)\n * @returns {Promise<string>} An originated address with the KT prefix\n */\nexport async function calculateOriginatedAddress(transactionId: string, index: number): Promise<string> {\n  // From https://github.com/TezTech/eztz/blob/cfdc4fcfc891f4f4f077c3056f414476dde3610b/src/main.js#L768\n  const ob = base58check.decode(transactionId).slice(hashTypes.o.prefix.length);\n\n  let tt: number[] = [];\n  for (let i = 0; i < ob.length; i++) {\n    tt.push(ob[i]);\n  }\n\n  tt = tt.concat([\n    (index & 0xff000000) >> 24,\n    (index & 0x00ff0000) >> 16,\n    (index & 0x0000ff00) >> 8,\n    index & 0x000000ff,\n  ]);\n\n  await sodium.ready;\n  const payload = sodium.crypto_generichash(20, new Uint8Array(tt));\n  return base58encode(hashTypes.KT.prefix, Buffer.from(payload));\n}\n\n/**\n * Generic data signing using Tezos library.\n *\n * @param {KeyPair} keyPair A Key Pair with a private key set\n * @param {string} data The data in hexadecimal to sign\n * @param {Uint8Array} watermark Magic byte: 1 for block, 2 for endorsement, 3 for generic\n * @returns {Promise<SignResponse>}\n */\nexport async function sign(\n  keyPair: KeyPair,\n  data: string,\n  watermark: Uint8Array = DEFAULT_WATERMARK\n): Promise<SignResponse> {\n  if (!keyPair.getKeys().prv) {\n    throw new SigningError('Missing private key');\n  }\n  const signer = new InMemorySigner(keyPair.getKeys().prv!);\n  return signer.sign(data, watermark);\n}\n\n/**\n * Verifies the signature produced for a given message belongs to a secp256k1 public key.\n *\n * @param {string} message Message in hex format to verify\n * @param {string} publicKey secp256k1 public key with \"sppk\" prefix to verify the signature with\n * @param {string} signature Tezos signature with \"sig\" prefix\n * @param {Uint8Array} watermark Optional watermark used to generate the signature\n * @returns {Promise<boolean>}\n */\nexport async function verifySignature(\n  message: string,\n  publicKey: string,\n  signature: string,\n  watermark: Uint8Array = DEFAULT_WATERMARK\n): Promise<boolean> {\n  const rawPublicKey = decodeKey(publicKey, hashTypes.sppk).toString('hex');\n  const key = secp256k1.ProjectivePoint.fromHex(rawPublicKey);\n\n  const messageBuffer = Uint8Array.from(Buffer.from(message, 'hex'));\n  // Tezos signatures always have a watermark\n  const messageWithWatermark = new Uint8Array(watermark.length + messageBuffer.length);\n  messageWithWatermark.set(watermark);\n  messageWithWatermark.set(messageBuffer, watermark.length);\n\n  await sodium.ready;\n  const bytesHash = Buffer.from(sodium.crypto_generichash(32, messageWithWatermark));\n\n  const rawSignature = decodeSignature(signature, hashTypes.sig);\n  return secp256k1.verify(rawSignature, bytesHash, key.toHex());\n}\n\n/**\n * Useful wrapper to create the generic multisig contract data to sign when moving funds.\n *\n * @param {string} contractAddress The wallet contract address with the funds to withdraw\n * @param {string} destinationAddress The address to transfer the funds to\n * @param {number} amount Number mutez to transfer\n * @param {string} contractCounter Wallet counter to use in the transaction\n * @returns {any} A JSON representation of the Michelson script to sign and approve a transfer\n */\nexport function generateDataToSign(\n  contractAddress: string,\n  destinationAddress: string,\n  amount: string,\n  contractCounter: string\n): any {\n  if (!isValidOriginatedAddress(contractAddress)) {\n    throw new Error('Invalid contract address ' + contractAddress + '. An originated account address was expected');\n  }\n  if (!isValidAddress(destinationAddress)) {\n    throw new Error('Invalid destination address ' + destinationAddress);\n  }\n  return genericMultisigDataToSign(contractAddress, destinationAddress, amount, contractCounter);\n}\n\n/**\n * Returns whether or not the string is a valid Tezos hash of the given type\n *\n * @param {string} hash - the string to validate\n * @param {HashType} hashType - the type of the provided hash\n * @returns {boolean}\n */\nexport function isValidHash(hash: string, hashType: HashType): boolean {\n  // Validate encoding\n  let decodedHash;\n  try {\n    decodedHash = base58check.decode(hash);\n  } catch (e) {\n    return false;\n  }\n  const hashPrefix = decodedHash.slice(0, hashType.prefix.length);\n\n  // Check prefix\n  if (!hashPrefix.equals(Buffer.from(hashType.prefix))) {\n    return false;\n  }\n\n  // Check length\n  const hashLength = decodedHash.length - hashPrefix.length;\n  return hashLength === hashType.byteLength;\n}\n\n/**\n * Returns whether or not the string is a valid Tezos address\n *\n * @param {string} hash - the address to validate\n * @returns {boolean}\n */\nexport function isValidAddress(hash: string): boolean {\n  return isValidImplicitAddress(hash) || isValidHash(hash, hashTypes.KT);\n}\n\n/**\n * Returns whether or not the string is a valid Tezos implicit account address\n *\n * @param {string} hash - the address to validate\n * @returns {boolean}\n */\nexport function isValidImplicitAddress(hash: string): boolean {\n  return isValidHash(hash, hashTypes.tz1) || isValidHash(hash, hashTypes.tz2) || isValidHash(hash, hashTypes.tz3);\n}\n\n/**\n * Returns whether or not the string is a valid Tezos originated account address\n *\n * @param {string} hash - the address to validate\n * @returns {boolean}\n */\nexport function isValidOriginatedAddress(hash: string): boolean {\n  return isValidHash(hash, hashTypes.KT);\n}\n\n/**\n * Returns whether or not the string is a valid Tezos signature\n *\n * @param {string} hash - the signature to validate\n * @returns {boolean}\n */\nexport function isValidSignature(hash: string): boolean {\n  return (\n    isValidHash(hash, hashTypes.edsig) ||\n    isValidHash(hash, hashTypes.spsig1) ||\n    isValidHash(hash, hashTypes.p2sig) ||\n    isValidHash(hash, hashTypes.sig)\n  );\n}\n\n/**\n * Returns whether or not the string is a valid Tezos public key\n *\n * @param {string} publicKey The public key to validate\n * @returns {boolean}\n */\nexport function isValidPublicKey(publicKey: string): boolean {\n  return (\n    isValidHash(publicKey, hashTypes.sppk) ||\n    isValidHash(publicKey, hashTypes.p2pk) ||\n    isValidHash(publicKey, hashTypes.edpk) ||\n    isValidXpub(publicKey) // xpubs are valid too.\n  );\n}\n\n/**\n * Returns whether or not the string is a valid Tezos private key\n *\n * @param {string} privateKey The private key to validate\n * @returns {boolean}\n */\nexport function isValidPrivateKey(privateKey: string): boolean {\n  return (\n    isValidHash(privateKey, hashTypes.edesk) ||\n    isValidHash(privateKey, hashTypes.edsk) ||\n    isValidHash(privateKey, hashTypes.spsk) ||\n    isValidHash(privateKey, hashTypes.p2sk)\n  );\n}\n\n/**\n * Returns whether or not the string is a valid Tezos block hash\n *\n * @param {string} hash - the address to validate\n * @returns {boolean}\n */\nexport function isValidBlockHash(hash: string): boolean {\n  return isValidHash(hash, hashTypes.b);\n}\n\n/**\n * Returns whether or not the string is a valid Tezos transaction hash\n *\n * @param {string} hash - the address to validate\n * @returns {boolean}\n */\nexport function isValidTransactionHash(hash: string): boolean {\n  return isValidHash(hash, hashTypes.o);\n}\n\n/**\n * Returns whether or not the string is a valid Tezos key given a prefix\n *\n * @param {string} hash - the key to validate\n * @param {HashType} hashType - the type of the provided hash\n * @returns {boolean}\n */\nexport function isValidKey(hash: string, hashType: HashType): boolean {\n  return isValidHash(hash, hashType);\n}\n\n/**\n * Get the original key form the text without the given prefix.\n *\n * @param {string} hash - base58 encoded key with a Tezos prefix\n * @param {HashType} hashType - the type of the provided hash\n * @returns {Buffer} the original decoded key\n */\nexport function decodeKey(hash: string, hashType: HashType): Buffer {\n  if (!isValidKey(hash, hashType)) {\n    throw new Error('Unsupported private key');\n  }\n  const decodedPrv = base58check.decode(hash);\n  return Buffer.from(decodedPrv.slice(hashType.prefix.length, decodedPrv.length));\n}\n\n/**\n * Get the raw signature from a Tezos encoded one.\n *\n * @param {string} signature Tezos signatures prefixed with sig, edsig, p2sig or spsig\n * @param {HashType} hashType The prefix of remove\n * @returns {Buffer} The decoded signature without prefix\n */\nexport function decodeSignature(signature: string, hashType: HashType): Buffer {\n  if (!isValidSignature(signature)) {\n    throw new Error('Unsupported signature');\n  }\n  const decodedPrv = base58check.decode(signature);\n  return Buffer.from(decodedPrv.slice(hashType.prefix.length, decodedPrv.length));\n}\n\n// Base58Check is used for encoding\n// hashedTypes is used to validate hashes by type, by checking their prefix and\n// the length of the Buffer obtained by decoding the hash (excluding the prefix)\nexport const hashTypes = {\n  /* 20 bytes long */\n  // ed25519 public key hash\n  tz1: {\n    prefix: Buffer.from([6, 161, 159]),\n    byteLength: 20,\n  },\n  // secp256k1 public key hash\n  tz2: {\n    prefix: Buffer.from([6, 161, 161]),\n    byteLength: 20,\n  },\n  // p256 public key hash\n  tz3: {\n    prefix: Buffer.from([6, 161, 164]),\n    byteLength: 20,\n  },\n  KT: {\n    prefix: Buffer.from([2, 90, 121]),\n    byteLength: 20,\n  },\n  /* 32 bytes long */\n  // ed25519 public key\n  edpk: {\n    prefix: Buffer.from([13, 15, 37, 217]),\n    byteLength: 32,\n  },\n  // ed25519 secret key\n  edsk2: {\n    prefix: Buffer.from([13, 15, 58, 7]),\n    byteLength: 32,\n  },\n  // secp256k1 secret key\n  spsk: {\n    prefix: Buffer.from([17, 162, 224, 201]),\n    byteLength: 32,\n  },\n  // p256 secret key\n  p2sk: {\n    prefix: Buffer.from([16, 81, 238, 189]),\n    byteLength: 32,\n  },\n  // block hash\n  b: {\n    prefix: Buffer.from([1, 52]),\n    byteLength: 32,\n  },\n  // operation hash\n  o: {\n    prefix: Buffer.from([5, 116]),\n    byteLength: 32,\n  },\n  // operation list hash\n  Lo: {\n    prefix: Buffer.from([133, 233]),\n    byteLength: 32,\n  },\n  // operation list list hash\n  LLo: {\n    prefix: Buffer.from([29, 159, 109]),\n    byteLength: 32,\n  },\n  // protocol hash\n  P: {\n    prefix: Buffer.from([2, 170]),\n    byteLength: 32,\n  },\n  // context hash\n  Co: {\n    prefix: Buffer.from([79, 179]),\n    byteLength: 32,\n  },\n  /* 33 bytes long */\n  // secp256k1 public key\n  sppk: {\n    prefix: Buffer.from([3, 254, 226, 86]),\n    byteLength: 33,\n  },\n  // p256 public key\n  p2pk: {\n    prefix: Buffer.from([3, 178, 139, 127]),\n    byteLength: 33,\n  },\n  /* 56 bytes long */\n  // ed25519 encrypted seed\n  edesk: {\n    prefix: Buffer.from([7, 90, 60, 179, 41]),\n    byteLength: 56,\n  },\n  /* 63 bytes long */\n  // ed25519 secret key\n  edsk: {\n    prefix: Buffer.from([43, 246, 78, 7]),\n    byteLength: 64,\n  },\n  // ed25519 signature\n  edsig: {\n    prefix: Buffer.from([9, 245, 205, 134, 18]),\n    byteLength: 64,\n  },\n  // secp256k1 signature\n  spsig1: {\n    prefix: Buffer.from([13, 115, 101, 19, 63]),\n    byteLength: 64,\n  },\n  // p256_signature\n  p2sig: {\n    prefix: Buffer.from([54, 240, 44, 52]),\n    byteLength: 64,\n  },\n  // generic signature\n  sig: {\n    prefix: Buffer.from([4, 130, 43]),\n    byteLength: 64,\n  },\n  /* 15 bytes long */\n  // network hash\n  Net: {\n    prefix: Buffer.from([87, 82, 0]),\n    byteLength: 15,\n  },\n  // nonce hash\n  nce: {\n    prefix: Buffer.from([69, 220, 169]),\n    byteLength: 15,\n  },\n  /* 4 bytes long */\n  // chain id\n  id: {\n    prefix: Buffer.from([153, 103]),\n    byteLength: 4,\n  },\n};\n\n// From https://github.com/ecadlabs/taquito/blob/master/packages/taquito/src/constants.ts\n\nexport enum DEFAULT_GAS_LIMIT {\n  DELEGATION = 10600,\n  ORIGINATION = 10600,\n  TRANSFER = 10600,\n  REVEAL = 10600,\n}\n\nexport enum DEFAULT_FEE {\n  DELEGATION = 1257,\n  ORIGINATION = 10000,\n  TRANSFER = 10000,\n  REVEAL = 1420,\n}\n\nexport enum DEFAULT_STORAGE_LIMIT {\n  DELEGATION = 0,\n  ORIGINATION = 257,\n  TRANSFER = 257,\n  REVEAL = 0,\n}\n"]}
473
+ var TRANSACTION_FEE;
474
+ (function (TRANSACTION_FEE) {
475
+ TRANSACTION_FEE[TRANSACTION_FEE["ORIGINATION"] = 47640] = "ORIGINATION";
476
+ TRANSACTION_FEE[TRANSACTION_FEE["TRANSFER"] = 47640] = "TRANSFER";
477
+ TRANSACTION_FEE[TRANSACTION_FEE["REVEAL"] = 1420] = "REVEAL";
478
+ })(TRANSACTION_FEE || (exports.TRANSACTION_FEE = TRANSACTION_FEE = {}));
479
+ var TRANSACTION_STORAGE_LIMIT;
480
+ (function (TRANSACTION_STORAGE_LIMIT) {
481
+ TRANSACTION_STORAGE_LIMIT[TRANSACTION_STORAGE_LIMIT["ORIGINATION"] = 3000] = "ORIGINATION";
482
+ TRANSACTION_STORAGE_LIMIT[TRANSACTION_STORAGE_LIMIT["TRANSFER"] = 300] = "TRANSFER";
483
+ TRANSACTION_STORAGE_LIMIT[TRANSACTION_STORAGE_LIMIT["REVEAL"] = 5] = "REVEAL";
484
+ })(TRANSACTION_STORAGE_LIMIT || (exports.TRANSACTION_STORAGE_LIMIT = TRANSACTION_STORAGE_LIMIT = {}));
485
+ var TRANSACTION_GAS_LIMIT;
486
+ (function (TRANSACTION_GAS_LIMIT) {
487
+ TRANSACTION_GAS_LIMIT[TRANSACTION_GAS_LIMIT["ORIGINATION"] = 4600] = "ORIGINATION";
488
+ TRANSACTION_GAS_LIMIT[TRANSACTION_GAS_LIMIT["TRANSFER"] = 6000] = "TRANSFER";
489
+ TRANSACTION_GAS_LIMIT[TRANSACTION_GAS_LIMIT["CONTRACT_TRANSFER"] = 20000] = "CONTRACT_TRANSFER";
490
+ TRANSACTION_GAS_LIMIT[TRANSACTION_GAS_LIMIT["REVEAL"] = 1500] = "REVEAL";
491
+ })(TRANSACTION_GAS_LIMIT || (exports.TRANSACTION_GAS_LIMIT = TRANSACTION_GAS_LIMIT = {}));
492
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/lib/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { isValidXpub, SigningError } from '@bitgo/sdk-core';\nimport { InMemorySigner } from '@taquito/signer';\nimport * as base58check from 'bs58check';\nimport { secp256k1 } from '@noble/curves/secp256k1';\nimport sodium from 'libsodium-wrappers';\nimport { HashType, SignResponse } from './iface';\nimport { KeyPair } from './keyPair';\nimport { genericMultisigDataToSign } from './multisigUtils';\n\n// By default, use the transactions prefix\nexport const DEFAULT_WATERMARK = new Uint8Array([3]);\n\n/**\n * Encode the payload to base58 with a specific Tezos prefix.\n *\n * @param {Buffer} prefix to add to the encoded payload\n * @param {Buffer} payload to encode\n * @returns {any} base58 payload with a Tezos prefix\n */\nexport function base58encode(prefix: Buffer, payload: Buffer): string {\n  const n = Buffer.alloc(prefix.length + payload.length);\n  n.set(prefix);\n  n.set(payload, prefix.length);\n\n  return base58check.encode(n);\n}\n\n/**\n * Calculate the transaction id for a for a signed transaction.\n *\n * @param {string} encodedTransaction Signed transaction in hexadecimal\n * @returns {Promise<string>} The transaction id\n */\nexport async function calculateTransactionId(encodedTransaction: string): Promise<string> {\n  await sodium.ready;\n  const encodedTransactionBuffer = Uint8Array.from(Buffer.from(encodedTransaction, 'hex'));\n  const operationHashPayload = sodium.crypto_generichash(32, encodedTransactionBuffer);\n  return base58encode(hashTypes.o.prefix, Buffer.from(operationHashPayload));\n}\n\n/**\n * Calculate the address of a new originated account.\n *\n * @param {string} transactionId The transaction id\n * @param {number} index The index of the origination operation inside the transaction (starts at 0)\n * @returns {Promise<string>} An originated address with the KT prefix\n */\nexport async function calculateOriginatedAddress(transactionId: string, index: number): Promise<string> {\n  // From https://github.com/TezTech/eztz/blob/cfdc4fcfc891f4f4f077c3056f414476dde3610b/src/main.js#L768\n  const ob = base58check.decode(transactionId).slice(hashTypes.o.prefix.length);\n\n  let tt: number[] = [];\n  for (let i = 0; i < ob.length; i++) {\n    tt.push(ob[i]);\n  }\n\n  tt = tt.concat([\n    (index & 0xff000000) >> 24,\n    (index & 0x00ff0000) >> 16,\n    (index & 0x0000ff00) >> 8,\n    index & 0x000000ff,\n  ]);\n\n  await sodium.ready;\n  const payload = sodium.crypto_generichash(20, new Uint8Array(tt));\n  return base58encode(hashTypes.KT.prefix, Buffer.from(payload));\n}\n\n/**\n * Generic data signing using Tezos library.\n *\n * @param {KeyPair} keyPair A Key Pair with a private key set\n * @param {string} data The data in hexadecimal to sign\n * @param {Uint8Array} watermark Magic byte: 1 for block, 2 for endorsement, 3 for generic\n * @returns {Promise<SignResponse>}\n */\nexport async function sign(\n  keyPair: KeyPair,\n  data: string,\n  watermark: Uint8Array = DEFAULT_WATERMARK\n): Promise<SignResponse> {\n  if (!keyPair.getKeys().prv) {\n    throw new SigningError('Missing private key');\n  }\n  const signer = new InMemorySigner(keyPair.getKeys().prv!);\n  return signer.sign(data, watermark);\n}\n\n/**\n * Verifies the signature produced for a given message belongs to a secp256k1 public key.\n *\n * @param {string} message Message in hex format to verify\n * @param {string} publicKey secp256k1 public key with \"sppk\" prefix to verify the signature with\n * @param {string} signature Tezos signature with \"sig\" prefix\n * @param {Uint8Array} watermark Optional watermark used to generate the signature\n * @returns {Promise<boolean>}\n */\nexport async function verifySignature(\n  message: string,\n  publicKey: string,\n  signature: string,\n  watermark: Uint8Array = DEFAULT_WATERMARK\n): Promise<boolean> {\n  const rawPublicKey = decodeKey(publicKey, hashTypes.sppk).toString('hex');\n  const key = secp256k1.ProjectivePoint.fromHex(rawPublicKey);\n\n  const messageBuffer = Uint8Array.from(Buffer.from(message, 'hex'));\n  // Tezos signatures always have a watermark\n  const messageWithWatermark = new Uint8Array(watermark.length + messageBuffer.length);\n  messageWithWatermark.set(watermark);\n  messageWithWatermark.set(messageBuffer, watermark.length);\n\n  await sodium.ready;\n  const bytesHash = Buffer.from(sodium.crypto_generichash(32, messageWithWatermark));\n\n  const rawSignature = decodeSignature(signature, hashTypes.sig);\n  return secp256k1.verify(rawSignature, bytesHash, key.toHex());\n}\n\n/**\n * Useful wrapper to create the generic multisig contract data to sign when moving funds.\n *\n * @param {string} contractAddress The wallet contract address with the funds to withdraw\n * @param {string} destinationAddress The address to transfer the funds to\n * @param {number} amount Number mutez to transfer\n * @param {string} contractCounter Wallet counter to use in the transaction\n * @returns {any} A JSON representation of the Michelson script to sign and approve a transfer\n */\nexport function generateDataToSign(\n  contractAddress: string,\n  destinationAddress: string,\n  amount: string,\n  contractCounter: string\n): any {\n  if (!isValidOriginatedAddress(contractAddress)) {\n    throw new Error('Invalid contract address ' + contractAddress + '. An originated account address was expected');\n  }\n  if (!isValidAddress(destinationAddress)) {\n    throw new Error('Invalid destination address ' + destinationAddress);\n  }\n  return genericMultisigDataToSign(contractAddress, destinationAddress, amount, contractCounter);\n}\n\n/**\n * Returns whether or not the string is a valid Tezos hash of the given type\n *\n * @param {string} hash - the string to validate\n * @param {HashType} hashType - the type of the provided hash\n * @returns {boolean}\n */\nexport function isValidHash(hash: string, hashType: HashType): boolean {\n  // Validate encoding\n  let decodedHash;\n  try {\n    decodedHash = base58check.decode(hash);\n  } catch (e) {\n    return false;\n  }\n  const hashPrefix = decodedHash.slice(0, hashType.prefix.length);\n\n  // Check prefix\n  if (!hashPrefix.equals(Buffer.from(hashType.prefix))) {\n    return false;\n  }\n\n  // Check length\n  const hashLength = decodedHash.length - hashPrefix.length;\n  return hashLength === hashType.byteLength;\n}\n\n/**\n * Returns whether or not the string is a valid Tezos address\n *\n * @param {string} hash - the address to validate\n * @returns {boolean}\n */\nexport function isValidAddress(hash: string): boolean {\n  return isValidImplicitAddress(hash) || isValidHash(hash, hashTypes.KT);\n}\n\n/**\n * Returns whether or not the string is a valid Tezos implicit account address\n *\n * @param {string} hash - the address to validate\n * @returns {boolean}\n */\nexport function isValidImplicitAddress(hash: string): boolean {\n  return isValidHash(hash, hashTypes.tz1) || isValidHash(hash, hashTypes.tz2) || isValidHash(hash, hashTypes.tz3);\n}\n\n/**\n * Returns whether or not the string is a valid Tezos originated account address\n *\n * @param {string} hash - the address to validate\n * @returns {boolean}\n */\nexport function isValidOriginatedAddress(hash: string): boolean {\n  return isValidHash(hash, hashTypes.KT);\n}\n\n/**\n * Returns whether or not the string is a valid Tezos signature\n *\n * @param {string} hash - the signature to validate\n * @returns {boolean}\n */\nexport function isValidSignature(hash: string): boolean {\n  return (\n    isValidHash(hash, hashTypes.edsig) ||\n    isValidHash(hash, hashTypes.spsig1) ||\n    isValidHash(hash, hashTypes.p2sig) ||\n    isValidHash(hash, hashTypes.sig)\n  );\n}\n\n/**\n * Returns whether or not the string is a valid Tezos public key\n *\n * @param {string} publicKey The public key to validate\n * @returns {boolean}\n */\nexport function isValidPublicKey(publicKey: string): boolean {\n  return (\n    isValidHash(publicKey, hashTypes.sppk) ||\n    isValidHash(publicKey, hashTypes.p2pk) ||\n    isValidHash(publicKey, hashTypes.edpk) ||\n    isValidXpub(publicKey) // xpubs are valid too.\n  );\n}\n\n/**\n * Returns whether or not the string is a valid Tezos private key\n *\n * @param {string} privateKey The private key to validate\n * @returns {boolean}\n */\nexport function isValidPrivateKey(privateKey: string): boolean {\n  return (\n    isValidHash(privateKey, hashTypes.edesk) ||\n    isValidHash(privateKey, hashTypes.edsk) ||\n    isValidHash(privateKey, hashTypes.spsk) ||\n    isValidHash(privateKey, hashTypes.p2sk)\n  );\n}\n\n/**\n * Returns whether or not the string is a valid Tezos block hash\n *\n * @param {string} hash - the address to validate\n * @returns {boolean}\n */\nexport function isValidBlockHash(hash: string): boolean {\n  return isValidHash(hash, hashTypes.b);\n}\n\n/**\n * Returns whether or not the string is a valid Tezos transaction hash\n *\n * @param {string} hash - the address to validate\n * @returns {boolean}\n */\nexport function isValidTransactionHash(hash: string): boolean {\n  return isValidHash(hash, hashTypes.o);\n}\n\n/**\n * Returns whether or not the string is a valid Tezos key given a prefix\n *\n * @param {string} hash - the key to validate\n * @param {HashType} hashType - the type of the provided hash\n * @returns {boolean}\n */\nexport function isValidKey(hash: string, hashType: HashType): boolean {\n  return isValidHash(hash, hashType);\n}\n\n/**\n * Get the original key form the text without the given prefix.\n *\n * @param {string} hash - base58 encoded key with a Tezos prefix\n * @param {HashType} hashType - the type of the provided hash\n * @returns {Buffer} the original decoded key\n */\nexport function decodeKey(hash: string, hashType: HashType): Buffer {\n  if (!isValidKey(hash, hashType)) {\n    throw new Error('Unsupported private key');\n  }\n  const decodedPrv = base58check.decode(hash);\n  return Buffer.from(decodedPrv.slice(hashType.prefix.length, decodedPrv.length));\n}\n\n/**\n * Get the raw signature from a Tezos encoded one.\n *\n * @param {string} signature Tezos signatures prefixed with sig, edsig, p2sig or spsig\n * @param {HashType} hashType The prefix of remove\n * @returns {Buffer} The decoded signature without prefix\n */\nexport function decodeSignature(signature: string, hashType: HashType): Buffer {\n  if (!isValidSignature(signature)) {\n    throw new Error('Unsupported signature');\n  }\n  const decodedPrv = base58check.decode(signature);\n  return Buffer.from(decodedPrv.slice(hashType.prefix.length, decodedPrv.length));\n}\n\n// Base58Check is used for encoding\n// hashedTypes is used to validate hashes by type, by checking their prefix and\n// the length of the Buffer obtained by decoding the hash (excluding the prefix)\nexport const hashTypes = {\n  /* 20 bytes long */\n  // ed25519 public key hash\n  tz1: {\n    prefix: Buffer.from([6, 161, 159]),\n    byteLength: 20,\n  },\n  // secp256k1 public key hash\n  tz2: {\n    prefix: Buffer.from([6, 161, 161]),\n    byteLength: 20,\n  },\n  // p256 public key hash\n  tz3: {\n    prefix: Buffer.from([6, 161, 164]),\n    byteLength: 20,\n  },\n  KT: {\n    prefix: Buffer.from([2, 90, 121]),\n    byteLength: 20,\n  },\n  /* 32 bytes long */\n  // ed25519 public key\n  edpk: {\n    prefix: Buffer.from([13, 15, 37, 217]),\n    byteLength: 32,\n  },\n  // ed25519 secret key\n  edsk2: {\n    prefix: Buffer.from([13, 15, 58, 7]),\n    byteLength: 32,\n  },\n  // secp256k1 secret key\n  spsk: {\n    prefix: Buffer.from([17, 162, 224, 201]),\n    byteLength: 32,\n  },\n  // p256 secret key\n  p2sk: {\n    prefix: Buffer.from([16, 81, 238, 189]),\n    byteLength: 32,\n  },\n  // block hash\n  b: {\n    prefix: Buffer.from([1, 52]),\n    byteLength: 32,\n  },\n  // operation hash\n  o: {\n    prefix: Buffer.from([5, 116]),\n    byteLength: 32,\n  },\n  // operation list hash\n  Lo: {\n    prefix: Buffer.from([133, 233]),\n    byteLength: 32,\n  },\n  // operation list list hash\n  LLo: {\n    prefix: Buffer.from([29, 159, 109]),\n    byteLength: 32,\n  },\n  // protocol hash\n  P: {\n    prefix: Buffer.from([2, 170]),\n    byteLength: 32,\n  },\n  // context hash\n  Co: {\n    prefix: Buffer.from([79, 179]),\n    byteLength: 32,\n  },\n  /* 33 bytes long */\n  // secp256k1 public key\n  sppk: {\n    prefix: Buffer.from([3, 254, 226, 86]),\n    byteLength: 33,\n  },\n  // p256 public key\n  p2pk: {\n    prefix: Buffer.from([3, 178, 139, 127]),\n    byteLength: 33,\n  },\n  /* 56 bytes long */\n  // ed25519 encrypted seed\n  edesk: {\n    prefix: Buffer.from([7, 90, 60, 179, 41]),\n    byteLength: 56,\n  },\n  /* 63 bytes long */\n  // ed25519 secret key\n  edsk: {\n    prefix: Buffer.from([43, 246, 78, 7]),\n    byteLength: 64,\n  },\n  // ed25519 signature\n  edsig: {\n    prefix: Buffer.from([9, 245, 205, 134, 18]),\n    byteLength: 64,\n  },\n  // secp256k1 signature\n  spsig1: {\n    prefix: Buffer.from([13, 115, 101, 19, 63]),\n    byteLength: 64,\n  },\n  // p256_signature\n  p2sig: {\n    prefix: Buffer.from([54, 240, 44, 52]),\n    byteLength: 64,\n  },\n  // generic signature\n  sig: {\n    prefix: Buffer.from([4, 130, 43]),\n    byteLength: 64,\n  },\n  /* 15 bytes long */\n  // network hash\n  Net: {\n    prefix: Buffer.from([87, 82, 0]),\n    byteLength: 15,\n  },\n  // nonce hash\n  nce: {\n    prefix: Buffer.from([69, 220, 169]),\n    byteLength: 15,\n  },\n  /* 4 bytes long */\n  // chain id\n  id: {\n    prefix: Buffer.from([153, 103]),\n    byteLength: 4,\n  },\n};\n\n// From https://github.com/ecadlabs/taquito/blob/master/packages/taquito/src/constants.ts\n\nexport enum DEFAULT_GAS_LIMIT {\n  DELEGATION = 10600,\n  ORIGINATION = 10600,\n  TRANSFER = 10600,\n  REVEAL = 10600,\n}\n\nexport enum DEFAULT_FEE {\n  DELEGATION = 1257,\n  ORIGINATION = 10000,\n  TRANSFER = 10000,\n  REVEAL = 1420,\n}\n\nexport enum DEFAULT_STORAGE_LIMIT {\n  DELEGATION = 0,\n  ORIGINATION = 257,\n  TRANSFER = 257,\n  REVEAL = 0,\n}\n\nexport enum TRANSACTION_FEE {\n  ORIGINATION = 47640,\n  TRANSFER = 47640,\n  REVEAL = 1420,\n}\n\nexport enum TRANSACTION_STORAGE_LIMIT {\n  ORIGINATION = 3000,\n  TRANSFER = 300,\n  REVEAL = 5,\n}\n\nexport enum TRANSACTION_GAS_LIMIT {\n  ORIGINATION = 4600,\n  TRANSFER = 6000,\n  CONTRACT_TRANSFER = 20000,\n  REVEAL = 1500,\n}\n"]}
package/dist/src/xtz.d.ts CHANGED
@@ -1,6 +1,7 @@
1
1
  import { BaseCoin, BitGoBase, ParsedTransaction, ParseTransactionOptions, KeyPair as SdkCoreKeyPair, SignedTransaction, TransactionExplanation, VerifyAddressOptions, VerifyTransactionOptions, MultisigType, AuditDecryptedKeyParams } from '@bitgo/sdk-core';
2
2
  import { CoinFamily, BaseCoin as StaticsBaseCoin } from '@bitgo/statics';
3
3
  import { Interface } from './lib';
4
+ import { RecoverOptions } from './lib/iface';
4
5
  export declare class Xtz extends BaseCoin {
5
6
  protected readonly _staticsCoin: Readonly<StaticsBaseCoin>;
6
7
  constructor(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>);
@@ -61,6 +62,48 @@ export declare class Xtz extends BaseCoin {
61
62
  * @param message
62
63
  */
63
64
  signMessage(key: SdkCoreKeyPair, message: string | Buffer): Promise<Buffer>;
65
+ /**
66
+ * Method to validate recovery params
67
+ * @param {RecoverOptions} params
68
+ * @returns {void}
69
+ */
70
+ validateRecoveryParams(params: RecoverOptions): void;
71
+ /**
72
+ * Make a query to blockchain explorer for information such as balance, token balance, solidity calls
73
+ * @param query {Object} key-value pairs of parameters to append after /api
74
+ * @param apiKey {string} optional API key to use instead of the one from the environment
75
+ * @returns {Object} response from the blockchain explorer
76
+ */
77
+ recoveryBlockchainExplorerQuery(params: {
78
+ actionPath: string;
79
+ address?: string;
80
+ action?: string;
81
+ }, apiKey?: string): Promise<unknown>;
82
+ /**
83
+ * Queries public block explorer to get the next XTZ address details
84
+ * @param {string} address
85
+ * @param {string} apiKey - optional API key to use instead of the one from the environment
86
+ * @returns {Promise<any>}
87
+ */
88
+ getAddressDetails(address: string, apiKey?: string): Promise<any>;
89
+ /**
90
+ * Query explorer for the balance of an address
91
+ * @param {String} address - the XTZ base/receive address
92
+ * @param {String} apiKey - optional API key to use instead of the one from the environment
93
+ * @returns {BigNumber} address balance
94
+ */
95
+ queryAddressBalance(address: string, apiKey?: string): Promise<any>;
96
+ /**
97
+ * Generate and pack the data to sign for each transfer.
98
+ *
99
+ * @param {String} contractAddress Wallet address to withdraw funds from
100
+ * @param {String} contractCounter Wallet internal counter
101
+ * @param {String} destination Tezos address to send the funds to
102
+ * @param {String} amount Number of mutez to move
103
+ * @param {IMSClient} imsClient Existing IMS client connection to reuse
104
+ * @return {String} data to sign in hex format
105
+ */
106
+ packDataToSign(contractAddress: any, contractCounter: any, destination: any, amount: any): Promise<any>;
64
107
  /**
65
108
  * Builds a funds recovery transaction without BitGo.
66
109
  * We need to do three queries during this:
@@ -69,7 +112,7 @@ export declare class Xtz extends BaseCoin {
69
112
  * 3) Send signed build - send our signed build to a public node
70
113
  * @param params
71
114
  */
72
- recover(params: any): Promise<any>;
115
+ recover(params: RecoverOptions): Promise<unknown>;
73
116
  /**
74
117
  * Explain a Tezos transaction from txHex
75
118
  * @param params
@@ -1 +1 @@
1
- {"version":3,"file":"xtz.d.ts","sourceRoot":"","sources":["../../src/xtz.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,QAAQ,EAER,SAAS,EAET,iBAAiB,EACjB,uBAAuB,EACvB,OAAO,IAAI,cAAc,EACzB,iBAAiB,EACjB,sBAAsB,EACtB,oBAAoB,EACpB,wBAAwB,EACxB,YAAY,EAEZ,uBAAuB,EACxB,MAAM,iBAAiB,CAAC;AAEzB,OAAO,EAAE,UAAU,EAAS,QAAQ,IAAI,eAAe,EAAE,MAAM,gBAAgB,CAAC;AAEhF,OAAO,EAAE,SAAS,EAAsC,MAAM,OAAO,CAAC;AAEtE,qBAAa,GAAI,SAAQ,QAAQ;IAC/B,SAAS,CAAC,QAAQ,CAAC,YAAY,EAAE,QAAQ,CAAC,eAAe,CAAC,CAAC;gBAE/C,KAAK,EAAE,SAAS,EAAE,WAAW,CAAC,EAAE,QAAQ,CAAC,eAAe,CAAC;IAUrE,MAAM,CAAC,cAAc,CAAC,KAAK,EAAE,SAAS,EAAE,WAAW,CAAC,EAAE,QAAQ,CAAC,eAAe,CAAC,GAAG,QAAQ;IAI1F,QAAQ,IAAI,MAAM;IAIlB,SAAS,IAAI,UAAU;IAIvB,WAAW,IAAI,MAAM;IAIrB,aAAa;IAIb,oBAAoB;IACpB,sBAAsB,IAAI,YAAY;IAItC;;;OAGG;IACH,wBAAwB,IAAI,OAAO;IAInC;;OAEG;IACH,2BAA2B,IAAI,OAAO;IAItC;;;OAGG;IACH,cAAc,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO;IAOxC;;;;;OAKG;IACH,eAAe,CAAC,IAAI,CAAC,EAAE,MAAM,GAAG,cAAc;IAcxC,gBAAgB,CAAC,MAAM,EAAE,uBAAuB,GAAG,OAAO,CAAC,iBAAiB,CAAC;IAI7E,eAAe,CAAC,MAAM,EAAE,oBAAoB,GAAG,OAAO,CAAC,OAAO,CAAC;IAI/D,iBAAiB,CAAC,MAAM,EAAE,wBAAwB,GAAG,OAAO,CAAC,OAAO,CAAC;IAU3E;;;;;OAKG;IACH,iBAAiB,CAAC,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE;QAAE,GAAG,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,GAAG,MAAM;IAMvE;;;;;;;OAOG;IACG,eAAe,CAAC,MAAM,EAAE,SAAS,CAAC,yBAAyB,GAAG,OAAO,CAAC,iBAAiB,CAAC;IA6B9F;;;;;OAKG;IACG,WAAW,CAAC,GAAG,EAAE,cAAc,EAAE,OAAO,EAAE,MAAM,GAAG,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAQjF;;;;;;;OAOG;IACG,OAAO,CAAC,MAAM,EAAE,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC;IAIxC;;;OAGG;IACG,kBAAkB,CAAC,MAAM,EAAE,SAAS,CAAC,yBAAyB,GAAG,OAAO,CAAC,sBAAsB,CAAC;IA4BtG,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;IAIhC,kBAAkB;IAClB,iBAAiB,CAAC,MAAM,EAAE,uBAAuB;CAGlD"}
1
+ {"version":3,"file":"xtz.d.ts","sourceRoot":"","sources":["../../src/xtz.ts"],"names":[],"mappings":"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"}
package/dist/src/xtz.js CHANGED
@@ -9,6 +9,8 @@ const secp256k1_1 = require("@bitgo/secp256k1");
9
9
  const statics_1 = require("@bitgo/statics");
10
10
  const bignumber_js_1 = __importDefault(require("bignumber.js"));
11
11
  const lib_1 = require("./lib");
12
+ const utils_1 = require("./lib/utils");
13
+ const superagent_1 = __importDefault(require("superagent"));
12
14
  class Xtz extends sdk_core_1.BaseCoin {
13
15
  constructor(bitgo, staticsCoin) {
14
16
  super(bitgo);
@@ -148,6 +150,102 @@ class Xtz extends sdk_core_1.BaseCoin {
148
150
  const signatureData = await lib_1.Utils.sign(keyPair, messageHex);
149
151
  return Buffer.from(signatureData.sig);
150
152
  }
153
+ /**
154
+ * Method to validate recovery params
155
+ * @param {RecoverOptions} params
156
+ * @returns {void}
157
+ */
158
+ validateRecoveryParams(params) {
159
+ if (params.userKey === undefined) {
160
+ throw new Error('missing userKey');
161
+ }
162
+ if (params.backupKey === undefined) {
163
+ throw new Error('missing backupKey');
164
+ }
165
+ if (!params.isUnsignedSweep && params.walletPassphrase === undefined && !params.userKey.startsWith('xpub')) {
166
+ throw new Error('missing wallet passphrase');
167
+ }
168
+ if (params.walletContractAddress === undefined || !this.isValidAddress(params.walletContractAddress)) {
169
+ throw new Error('invalid walletContractAddress');
170
+ }
171
+ if (params.recoveryDestination === undefined || !this.isValidAddress(params.recoveryDestination)) {
172
+ throw new Error('invalid recoveryDestination');
173
+ }
174
+ }
175
+ /**
176
+ * Make a query to blockchain explorer for information such as balance, token balance, solidity calls
177
+ * @param query {Object} key-value pairs of parameters to append after /api
178
+ * @param apiKey {string} optional API key to use instead of the one from the environment
179
+ * @returns {Object} response from the blockchain explorer
180
+ */
181
+ async recoveryBlockchainExplorerQuery(params, apiKey) {
182
+ const response = await superagent_1.default.get(`${sdk_core_1.common.Environments[this.bitgo.getEnv()].xtzExplorerBaseUrl}/v1/${params.actionPath}${params.address ? '/' + params.address : ''}${params.action ? '/' + params.action : ''}${apiKey ? `?apikey=${apiKey}` : ''}`);
183
+ if (!response.ok) {
184
+ throw new Error('could not reach TZKT');
185
+ }
186
+ if (response.status === 429) {
187
+ throw new Error('TZKT rate limit reached');
188
+ }
189
+ return response.body;
190
+ }
191
+ /**
192
+ * Queries public block explorer to get the next XTZ address details
193
+ * @param {string} address
194
+ * @param {string} apiKey - optional API key to use instead of the one from the environment
195
+ * @returns {Promise<any>}
196
+ */
197
+ async getAddressDetails(address, apiKey) {
198
+ const result = await this.recoveryBlockchainExplorerQuery({
199
+ actionPath: 'accounts',
200
+ address,
201
+ }, apiKey);
202
+ if (!result) {
203
+ throw new Error(`Unable to find details for ${address}`);
204
+ }
205
+ return result;
206
+ }
207
+ /**
208
+ * Query explorer for the balance of an address
209
+ * @param {String} address - the XTZ base/receive address
210
+ * @param {String} apiKey - optional API key to use instead of the one from the environment
211
+ * @returns {BigNumber} address balance
212
+ */
213
+ async queryAddressBalance(address, apiKey) {
214
+ const result = await this.recoveryBlockchainExplorerQuery({
215
+ actionPath: (0, utils_1.isValidOriginatedAddress)(address) ? 'contracts' : 'accounts',
216
+ address,
217
+ }, apiKey);
218
+ // throw if the result does not exist or the result is not a valid number
219
+ if (!result || !result.balance) {
220
+ throw new Error(`Could not obtain address balance for ${address} from the explorer`);
221
+ }
222
+ return new bignumber_js_1.default(result.balance, 10);
223
+ }
224
+ /**
225
+ * Generate and pack the data to sign for each transfer.
226
+ *
227
+ * @param {String} contractAddress Wallet address to withdraw funds from
228
+ * @param {String} contractCounter Wallet internal counter
229
+ * @param {String} destination Tezos address to send the funds to
230
+ * @param {String} amount Number of mutez to move
231
+ * @param {IMSClient} imsClient Existing IMS client connection to reuse
232
+ * @return {String} data to sign in hex format
233
+ */
234
+ async packDataToSign(contractAddress, contractCounter, destination, amount) {
235
+ const dataToSign = (0, utils_1.generateDataToSign)(contractAddress, destination, amount, contractCounter);
236
+ const xtzRpcUrl = `${sdk_core_1.common.Environments[this.bitgo.getEnv()].xtzRpcUrl}/chains/main/blocks/head/helpers/scripts/pack_data`;
237
+ if (!xtzRpcUrl) {
238
+ throw new Error('XTZ RPC url not found');
239
+ }
240
+ const response = await superagent_1.default.post(xtzRpcUrl).send(dataToSign);
241
+ if (response.status === 404) {
242
+ throw new Error(`unable to pack data to sign ${response.status}: ${response.body.error.message}`);
243
+ }
244
+ else if (response.status !== 200) {
245
+ throw new Error(`unexpected IMS response status ${response.status}: ${response.body.error.message}`);
246
+ }
247
+ return response.body.packed;
248
+ }
151
249
  /**
152
250
  * Builds a funds recovery transaction without BitGo.
153
251
  * We need to do three queries during this:
@@ -157,7 +255,97 @@ class Xtz extends sdk_core_1.BaseCoin {
157
255
  * @param params
158
256
  */
159
257
  async recover(params) {
160
- throw new sdk_core_1.MethodNotImplementedError();
258
+ this.validateRecoveryParams(params);
259
+ // Clean up whitespace from entered values
260
+ const backupKey = params.backupKey.replace(/\s/g, '');
261
+ const userAddressDetails = await this.getAddressDetails(params.walletContractAddress, params.apiKey);
262
+ if (!userAddressDetails) {
263
+ throw new Error('Unable to fetch user address details');
264
+ }
265
+ // Decrypt backup private key and get address
266
+ let backupPrv;
267
+ try {
268
+ backupPrv = this.bitgo.decrypt({
269
+ input: backupKey,
270
+ password: params.walletPassphrase,
271
+ });
272
+ }
273
+ catch (e) {
274
+ throw new Error(`Error decrypting backup keychain: ${e.message}`);
275
+ }
276
+ const keyPair = new lib_1.KeyPair({ prv: backupPrv });
277
+ const backupSigningKey = keyPair.getKeys().prv;
278
+ if (!backupSigningKey) {
279
+ throw new Error('no private key');
280
+ }
281
+ const backupKeyAddress = keyPair.getAddress();
282
+ const backupAddressDetails = await this.getAddressDetails(backupKeyAddress, params.apiKey || '');
283
+ if (!backupAddressDetails.counter || !backupAddressDetails.balance) {
284
+ throw new Error(`Missing required detail(s): counter, balance`);
285
+ }
286
+ const backupKeyNonce = new bignumber_js_1.default(backupAddressDetails.counter + 1, 10);
287
+ // get balance of backupKey to ensure funds are available to pay fees
288
+ const backupKeyBalance = new bignumber_js_1.default(backupAddressDetails.balance, 10);
289
+ const gasLimit = (0, utils_1.isValidOriginatedAddress)(params.recoveryDestination)
290
+ ? utils_1.TRANSACTION_GAS_LIMIT.CONTRACT_TRANSFER
291
+ : utils_1.TRANSACTION_GAS_LIMIT.TRANSFER;
292
+ const gasPrice = utils_1.TRANSACTION_FEE.TRANSFER;
293
+ // Checking whether back up key address has sufficient funds for transaction
294
+ if (backupKeyBalance.lt(gasPrice)) {
295
+ const weiToGwei = 10 ** 6;
296
+ throw new Error(`Backup key address ${backupKeyAddress} has balance ${(backupKeyBalance.toNumber() / weiToGwei).toString()} Gwei.` +
297
+ `This address must have a balance of at least ${(gasPrice / weiToGwei).toString()}` +
298
+ ` Gwei to perform recoveries. Try sending some funds to this address then retry.`);
299
+ }
300
+ // get balance of sender address
301
+ if (!userAddressDetails.balance || userAddressDetails.balance === 0) {
302
+ throw new Error('No funds to recover from source address');
303
+ }
304
+ const txAmount = userAddressDetails.balance;
305
+ if (new bignumber_js_1.default(txAmount).isLessThanOrEqualTo(0)) {
306
+ throw new Error('Wallet does not have enough funds to recover');
307
+ }
308
+ const feeInfo = {
309
+ fee: new bignumber_js_1.default(utils_1.TRANSACTION_FEE.TRANSFER),
310
+ gasLimit: new bignumber_js_1.default(gasLimit),
311
+ storageLimit: new bignumber_js_1.default(utils_1.TRANSACTION_STORAGE_LIMIT.TRANSFER),
312
+ };
313
+ const txBuilder = new lib_1.TransactionBuilder(statics_1.coins.get(this.getChain()));
314
+ txBuilder.type(sdk_core_1.TransactionType.Send);
315
+ txBuilder.source(backupKeyAddress);
316
+ // Used to set the branch for the transaction
317
+ const chainHead = await this.recoveryBlockchainExplorerQuery({
318
+ actionPath: 'head',
319
+ });
320
+ if (!chainHead || !chainHead.hash) {
321
+ throw new Error('Unable to fetch chain head');
322
+ }
323
+ txBuilder.branch(chainHead.hash);
324
+ if (!backupAddressDetails.revealed) {
325
+ feeInfo.fee = feeInfo.fee.plus(utils_1.TRANSACTION_FEE.REVEAL);
326
+ feeInfo.gasLimit = feeInfo.gasLimit.plus(utils_1.TRANSACTION_GAS_LIMIT.REVEAL);
327
+ feeInfo.storageLimit = feeInfo.storageLimit.plus(utils_1.TRANSACTION_STORAGE_LIMIT.REVEAL);
328
+ backupKeyNonce.plus(1);
329
+ const publicKeyToReveal = keyPair.getKeys();
330
+ txBuilder.publicKeyToReveal(publicKeyToReveal.pub);
331
+ }
332
+ txBuilder.counter(backupKeyNonce.toString());
333
+ const packedDataToSign = await this.packDataToSign(params.walletContractAddress, backupKeyNonce.toString(), params.recoveryDestination, txAmount?.toString());
334
+ txBuilder
335
+ .transfer(txAmount?.toString())
336
+ .from(params.walletContractAddress)
337
+ .to(params.recoveryDestination)
338
+ .counter(backupKeyNonce.toString())
339
+ .fee(utils_1.TRANSACTION_FEE.TRANSFER.toString())
340
+ .storageLimit(utils_1.TRANSACTION_STORAGE_LIMIT.TRANSFER.toString())
341
+ .gasLimit(gasLimit.toString())
342
+ .dataToSign(packedDataToSign);
343
+ txBuilder.sign({ key: backupSigningKey });
344
+ const signedTx = await txBuilder.build();
345
+ return {
346
+ id: signedTx.id,
347
+ tx: signedTx.toBroadcastFormat(),
348
+ };
161
349
  }
162
350
  /**
163
351
  * Explain a Tezos transaction from txHex
@@ -197,4 +385,4 @@ class Xtz extends sdk_core_1.BaseCoin {
197
385
  }
198
386
  }
199
387
  exports.Xtz = Xtz;
200
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"xtz.js","sourceRoot":"","sources":["../../src/xtz.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  BaseCoin,\n  BaseTransactionBuilder,\n  BitGoBase,\n  MethodNotImplementedError,\n  ParsedTransaction,\n  ParseTransactionOptions,\n  KeyPair as SdkCoreKeyPair,\n  SignedTransaction,\n  TransactionExplanation,\n  VerifyAddressOptions,\n  VerifyTransactionOptions,\n  MultisigType,\n  multisigTypes,\n  AuditDecryptedKeyParams,\n} from '@bitgo/sdk-core';\nimport { bip32 } from '@bitgo/secp256k1';\nimport { CoinFamily, coins, BaseCoin as StaticsBaseCoin } from '@bitgo/statics';\nimport BigNumber from 'bignumber.js';\nimport { Interface, KeyPair, TransactionBuilder, Utils } from './lib';\n\nexport class Xtz extends BaseCoin {\n  protected readonly _staticsCoin: Readonly<StaticsBaseCoin>;\n\n  constructor(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>) {\n    super(bitgo);\n\n    if (!staticsCoin) {\n      throw new Error('missing required constructor parameter staticsCoin');\n    }\n\n    this._staticsCoin = staticsCoin;\n  }\n\n  static createInstance(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>): BaseCoin {\n    return new Xtz(bitgo, staticsCoin);\n  }\n\n  getChain(): string {\n    return this._staticsCoin.name;\n  }\n\n  getFamily(): CoinFamily {\n    return this._staticsCoin.family;\n  }\n\n  getFullName(): string {\n    return this._staticsCoin.fullName;\n  }\n\n  getBaseFactor() {\n    return Math.pow(10, this._staticsCoin.decimalPlaces);\n  }\n\n  /** inherited doc */\n  getDefaultMultisigType(): MultisigType {\n    return multisigTypes.onchain;\n  }\n\n  /**\n   * Flag for sending value of 0\n   * @returns {boolean} True if okay to send 0 value, false otherwise\n   */\n  valuelessTransferAllowed(): boolean {\n    return true;\n  }\n\n  /**\n   * Xtz supports transfers to consolidate balance from receive address to the wallet contract\n   */\n  allowsAccountConsolidations(): boolean {\n    return true;\n  }\n\n  /**\n   * Checks if this is a valid base58 or hex address\n   * @param address\n   */\n  isValidAddress(address: string): boolean {\n    if (!address) {\n      return false;\n    }\n    return Utils.isValidAddress(address);\n  }\n\n  /**\n   * Generate Tezos key pair - BitGo xpub format\n   *\n   * @param seed\n   * @returns {Object} object with generated xpub, xprv\n   */\n  generateKeyPair(seed?: Buffer): SdkCoreKeyPair {\n    const keyPair = seed ? new KeyPair({ seed }) : new KeyPair();\n    const keys = keyPair.getExtendedKeys();\n\n    if (!keys.xprv) {\n      throw new Error('Missing xprv in key generation.');\n    }\n\n    return {\n      pub: keys.xpub,\n      prv: keys.xprv,\n    };\n  }\n\n  async parseTransaction(params: ParseTransactionOptions): Promise<ParsedTransaction> {\n    return {};\n  }\n\n  async isWalletAddress(params: VerifyAddressOptions): Promise<boolean> {\n    throw new MethodNotImplementedError();\n  }\n\n  async verifyTransaction(params: VerifyTransactionOptions): Promise<boolean> {\n    const { txParams } = params;\n    if (Array.isArray(txParams.recipients) && txParams.recipients.length > 1) {\n      throw new Error(\n        `${this.getChain()} doesn't support sending to more than 1 destination address within a single transaction. Try again, using only a single recipient.`\n      );\n    }\n    return true;\n  }\n\n  /**\n   * Derive a user key using the chain path of the address\n   * @param key\n   * @param path\n   * @returns {string} derived private key\n   */\n  deriveKeyWithPath({ key, path }: { key: string; path: string }): string {\n    const keychain = bip32.fromBase58(key);\n    const derivedKeyNode = keychain.derivePath(path);\n    return derivedKeyNode.toBase58();\n  }\n\n  /**\n   * Assemble keychain and half-sign prebuilt transaction\n   *\n   * @param params\n   * @param params.txPrebuild {Object} prebuild object returned by platform\n   * @param params.prv {String} user prv\n   * @returns Bluebird<SignedTransaction>\n   */\n  async signTransaction(params: Interface.XtzSignTransactionOptions): Promise<SignedTransaction> {\n    const txBuilder = new TransactionBuilder(coins.get(this.getChain()));\n    txBuilder.from(params.txPrebuild.txHex);\n    txBuilder.source(params.txPrebuild.source);\n    if (params.txPrebuild.dataToSign) {\n      txBuilder.overrideDataToSign({ dataToSign: params.txPrebuild.dataToSign });\n    }\n    // The path /0/0/0/0 is used by the wallet base address\n    // Derive the user key only if the transaction is sent from a receive address\n    let key;\n    const { chain, index } = params.txPrebuild.addressInfo;\n    if (chain === 0 && index === 0) {\n      key = params.prv;\n    } else {\n      const derivationPath = `0/0/${chain}/${index}`;\n      key = this.deriveKeyWithPath({ key: params.prv, path: derivationPath });\n    }\n    txBuilder.sign({ key });\n\n    const transaction = await txBuilder.build();\n    if (!transaction) {\n      throw new Error('Invalid messaged passed to signMessage');\n    }\n    const response = {\n      txHex: transaction.toBroadcastFormat(),\n    };\n    return transaction.signature.length >= 2 ? response : { halfSigned: response };\n  }\n\n  /**\n   * Sign message with private key\n   *\n   * @param key\n   * @param message\n   */\n  async signMessage(key: SdkCoreKeyPair, message: string | Buffer): Promise<Buffer> {\n    const keyPair = new KeyPair({ prv: key.prv });\n    const messageHex =\n      message instanceof Buffer ? message.toString('hex') : Buffer.from(message as string, 'utf-8').toString('hex');\n    const signatureData = await Utils.sign(keyPair, messageHex);\n    return Buffer.from(signatureData.sig);\n  }\n\n  /**\n   * Builds a funds recovery transaction without BitGo.\n   * We need to do three queries during this:\n   * 1) Node query - how much money is in the account\n   * 2) Build transaction - build our transaction for the amount\n   * 3) Send signed build - send our signed build to a public node\n   * @param params\n   */\n  async recover(params: any): Promise<any> {\n    throw new MethodNotImplementedError();\n  }\n\n  /**\n   * Explain a Tezos transaction from txHex\n   * @param params\n   */\n  async explainTransaction(params: Interface.ExplainTransactionOptions): Promise<TransactionExplanation> {\n    const txHex = params.txHex || (params.halfSigned && params.halfSigned.txHex);\n    if (!txHex || !params.feeInfo) {\n      throw new Error('missing explain tx parameters');\n    }\n    const txBuilder = new TransactionBuilder(coins.get(this.getChain()));\n    // Newer coins can return BaseTransactionBuilderFactory instead of BaseTransactionBuilder\n    if (!(txBuilder instanceof BaseTransactionBuilder)) {\n      throw new Error('getBuilder() did not return an BaseTransactionBuilder object. Has it been updated?');\n    }\n    txBuilder.from(txHex);\n    const tx = await txBuilder.build();\n\n    const displayOrder = ['id', 'outputAmount', 'changeAmount', 'outputs', 'changeOutputs', 'fee'];\n\n    return {\n      displayOrder,\n      id: tx.id,\n      outputs: tx.outputs,\n      outputAmount: tx.outputs\n        .reduce((accumulator, output) => accumulator.plus(output.value), new BigNumber('0'))\n        .toFixed(0),\n      changeOutputs: [], // account based does not use change outputs\n      changeAmount: '0', // account base does not make change\n      fee: params.feeInfo,\n    } as any;\n  }\n\n  isValidPub(pub: string): boolean {\n    return Utils.isValidPublicKey(pub);\n  }\n\n  /** @inheritDoc */\n  auditDecryptedKey(params: AuditDecryptedKeyParams) {\n    throw new MethodNotImplementedError();\n  }\n}\n"]}
388
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"xtz.js","sourceRoot":"","sources":["../../src/xtz.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  BaseCoin,\n  BaseTransactionBuilder,\n  BitGoBase,\n  MethodNotImplementedError,\n  ParsedTransaction,\n  ParseTransactionOptions,\n  KeyPair as SdkCoreKeyPair,\n  SignedTransaction,\n  TransactionExplanation,\n  VerifyAddressOptions,\n  VerifyTransactionOptions,\n  MultisigType,\n  multisigTypes,\n  AuditDecryptedKeyParams,\n  common,\n  TransactionType,\n} from '@bitgo/sdk-core';\nimport { bip32 } from '@bitgo/secp256k1';\nimport { CoinFamily, coins, BaseCoin as StaticsBaseCoin } from '@bitgo/statics';\nimport BigNumber from 'bignumber.js';\nimport { Interface, KeyPair, TransactionBuilder, Utils } from './lib';\nimport { RecoverOptions } from './lib/iface';\nimport {\n  generateDataToSign,\n  isValidOriginatedAddress,\n  TRANSACTION_FEE,\n  TRANSACTION_GAS_LIMIT,\n  TRANSACTION_STORAGE_LIMIT,\n} from './lib/utils';\nimport request from 'superagent';\nexport class Xtz extends BaseCoin {\n  protected readonly _staticsCoin: Readonly<StaticsBaseCoin>;\n\n  constructor(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>) {\n    super(bitgo);\n\n    if (!staticsCoin) {\n      throw new Error('missing required constructor parameter staticsCoin');\n    }\n\n    this._staticsCoin = staticsCoin;\n  }\n\n  static createInstance(bitgo: BitGoBase, staticsCoin?: Readonly<StaticsBaseCoin>): BaseCoin {\n    return new Xtz(bitgo, staticsCoin);\n  }\n\n  getChain(): string {\n    return this._staticsCoin.name;\n  }\n\n  getFamily(): CoinFamily {\n    return this._staticsCoin.family;\n  }\n\n  getFullName(): string {\n    return this._staticsCoin.fullName;\n  }\n\n  getBaseFactor() {\n    return Math.pow(10, this._staticsCoin.decimalPlaces);\n  }\n\n  /** inherited doc */\n  getDefaultMultisigType(): MultisigType {\n    return multisigTypes.onchain;\n  }\n\n  /**\n   * Flag for sending value of 0\n   * @returns {boolean} True if okay to send 0 value, false otherwise\n   */\n  valuelessTransferAllowed(): boolean {\n    return true;\n  }\n\n  /**\n   * Xtz supports transfers to consolidate balance from receive address to the wallet contract\n   */\n  allowsAccountConsolidations(): boolean {\n    return true;\n  }\n\n  /**\n   * Checks if this is a valid base58 or hex address\n   * @param address\n   */\n  isValidAddress(address: string): boolean {\n    if (!address) {\n      return false;\n    }\n    return Utils.isValidAddress(address);\n  }\n\n  /**\n   * Generate Tezos key pair - BitGo xpub format\n   *\n   * @param seed\n   * @returns {Object} object with generated xpub, xprv\n   */\n  generateKeyPair(seed?: Buffer): SdkCoreKeyPair {\n    const keyPair = seed ? new KeyPair({ seed }) : new KeyPair();\n    const keys = keyPair.getExtendedKeys();\n\n    if (!keys.xprv) {\n      throw new Error('Missing xprv in key generation.');\n    }\n\n    return {\n      pub: keys.xpub,\n      prv: keys.xprv,\n    };\n  }\n\n  async parseTransaction(params: ParseTransactionOptions): Promise<ParsedTransaction> {\n    return {};\n  }\n\n  async isWalletAddress(params: VerifyAddressOptions): Promise<boolean> {\n    throw new MethodNotImplementedError();\n  }\n\n  async verifyTransaction(params: VerifyTransactionOptions): Promise<boolean> {\n    const { txParams } = params;\n    if (Array.isArray(txParams.recipients) && txParams.recipients.length > 1) {\n      throw new Error(\n        `${this.getChain()} doesn't support sending to more than 1 destination address within a single transaction. Try again, using only a single recipient.`\n      );\n    }\n    return true;\n  }\n\n  /**\n   * Derive a user key using the chain path of the address\n   * @param key\n   * @param path\n   * @returns {string} derived private key\n   */\n  deriveKeyWithPath({ key, path }: { key: string; path: string }): string {\n    const keychain = bip32.fromBase58(key);\n    const derivedKeyNode = keychain.derivePath(path);\n    return derivedKeyNode.toBase58();\n  }\n\n  /**\n   * Assemble keychain and half-sign prebuilt transaction\n   *\n   * @param params\n   * @param params.txPrebuild {Object} prebuild object returned by platform\n   * @param params.prv {String} user prv\n   * @returns Bluebird<SignedTransaction>\n   */\n  async signTransaction(params: Interface.XtzSignTransactionOptions): Promise<SignedTransaction> {\n    const txBuilder = new TransactionBuilder(coins.get(this.getChain()));\n    txBuilder.from(params.txPrebuild.txHex);\n    txBuilder.source(params.txPrebuild.source);\n    if (params.txPrebuild.dataToSign) {\n      txBuilder.overrideDataToSign({ dataToSign: params.txPrebuild.dataToSign });\n    }\n    // The path /0/0/0/0 is used by the wallet base address\n    // Derive the user key only if the transaction is sent from a receive address\n    let key;\n    const { chain, index } = params.txPrebuild.addressInfo;\n    if (chain === 0 && index === 0) {\n      key = params.prv;\n    } else {\n      const derivationPath = `0/0/${chain}/${index}`;\n      key = this.deriveKeyWithPath({ key: params.prv, path: derivationPath });\n    }\n    txBuilder.sign({ key });\n\n    const transaction = await txBuilder.build();\n    if (!transaction) {\n      throw new Error('Invalid messaged passed to signMessage');\n    }\n    const response = {\n      txHex: transaction.toBroadcastFormat(),\n    };\n    return transaction.signature.length >= 2 ? response : { halfSigned: response };\n  }\n\n  /**\n   * Sign message with private key\n   *\n   * @param key\n   * @param message\n   */\n  async signMessage(key: SdkCoreKeyPair, message: string | Buffer): Promise<Buffer> {\n    const keyPair = new KeyPair({ prv: key.prv });\n    const messageHex =\n      message instanceof Buffer ? message.toString('hex') : Buffer.from(message as string, 'utf-8').toString('hex');\n    const signatureData = await Utils.sign(keyPair, messageHex);\n    return Buffer.from(signatureData.sig);\n  }\n  /**\n   * Method to validate recovery params\n   * @param {RecoverOptions} params\n   * @returns {void}\n   */\n  validateRecoveryParams(params: RecoverOptions): void {\n    if (params.userKey === undefined) {\n      throw new Error('missing userKey');\n    }\n\n    if (params.backupKey === undefined) {\n      throw new Error('missing backupKey');\n    }\n\n    if (!params.isUnsignedSweep && params.walletPassphrase === undefined && !params.userKey.startsWith('xpub')) {\n      throw new Error('missing wallet passphrase');\n    }\n\n    if (params.walletContractAddress === undefined || !this.isValidAddress(params.walletContractAddress)) {\n      throw new Error('invalid walletContractAddress');\n    }\n\n    if (params.recoveryDestination === undefined || !this.isValidAddress(params.recoveryDestination)) {\n      throw new Error('invalid recoveryDestination');\n    }\n  }\n\n  /**\n   * Make a query to blockchain explorer for information such as balance, token balance, solidity calls\n   * @param query {Object} key-value pairs of parameters to append after /api\n   * @param apiKey {string} optional API key to use instead of the one from the environment\n   * @returns {Object} response from the blockchain explorer\n   */\n  async recoveryBlockchainExplorerQuery(\n    params: {\n      actionPath: string;\n      address?: string;\n      action?: string;\n    },\n    apiKey?: string\n  ): Promise<unknown> {\n    const response = await request.get(\n      `${common.Environments[this.bitgo.getEnv()].xtzExplorerBaseUrl}/v1/${params.actionPath}${\n        params.address ? '/' + params.address : ''\n      }${params.action ? '/' + params.action : ''}${apiKey ? `?apikey=${apiKey}` : ''}`\n    );\n\n    if (!response.ok) {\n      throw new Error('could not reach TZKT');\n    }\n\n    if (response.status === 429) {\n      throw new Error('TZKT rate limit reached');\n    }\n    return response.body;\n  }\n\n  /**\n   * Queries public block explorer to get the next XTZ address details\n   * @param {string} address\n   * @param {string} apiKey - optional API key to use instead of the one from the environment\n   * @returns {Promise<any>}\n   */\n  async getAddressDetails(address: string, apiKey?: string): Promise<any> {\n    const result = await this.recoveryBlockchainExplorerQuery(\n      {\n        actionPath: 'accounts',\n        address,\n      },\n      apiKey\n    );\n\n    if (!result) {\n      throw new Error(`Unable to find details for ${address}`);\n    }\n    return result;\n  }\n\n  /**\n   * Query explorer for the balance of an address\n   * @param {String} address - the XTZ base/receive address\n   * @param {String} apiKey - optional API key to use instead of the one from the environment\n   * @returns {BigNumber} address balance\n   */\n  async queryAddressBalance(address: string, apiKey?: string): Promise<any> {\n    const result: any = await this.recoveryBlockchainExplorerQuery(\n      {\n        actionPath: isValidOriginatedAddress(address) ? 'contracts' : 'accounts',\n        address,\n      },\n      apiKey\n    );\n    // throw if the result does not exist or the result is not a valid number\n    if (!result || !result.balance) {\n      throw new Error(`Could not obtain address balance for ${address} from the explorer`);\n    }\n    return new BigNumber(result.balance, 10);\n  }\n\n  /**\n   * Generate and pack the data to sign for each transfer.\n   *\n   * @param {String} contractAddress Wallet address to withdraw funds from\n   * @param {String} contractCounter Wallet internal counter\n   * @param {String} destination Tezos address to send the funds to\n   * @param {String} amount Number of mutez to move\n   * @param {IMSClient} imsClient Existing IMS client connection to reuse\n   * @return {String} data to sign in hex format\n   */\n  async packDataToSign(contractAddress, contractCounter, destination, amount) {\n    const dataToSign = generateDataToSign(contractAddress, destination, amount, contractCounter);\n    const xtzRpcUrl = `${\n      common.Environments[this.bitgo.getEnv()].xtzRpcUrl\n    }/chains/main/blocks/head/helpers/scripts/pack_data`;\n\n    if (!xtzRpcUrl) {\n      throw new Error('XTZ RPC url not found');\n    }\n\n    const response = await request.post(xtzRpcUrl).send(dataToSign);\n    if (response.status === 404) {\n      throw new Error(`unable to pack data to sign ${response.status}: ${response.body.error.message}`);\n    } else if (response.status !== 200) {\n      throw new Error(`unexpected IMS response status ${response.status}: ${response.body.error.message}`);\n    }\n    return response.body.packed;\n  }\n\n  /**\n   * Builds a funds recovery transaction without BitGo.\n   * We need to do three queries during this:\n   * 1) Node query - how much money is in the account\n   * 2) Build transaction - build our transaction for the amount\n   * 3) Send signed build - send our signed build to a public node\n   * @param params\n   */\n  async recover(params: RecoverOptions): Promise<unknown> {\n    this.validateRecoveryParams(params);\n\n    // Clean up whitespace from entered values\n\n    const backupKey = params.backupKey.replace(/\\s/g, '');\n\n    const userAddressDetails = await this.getAddressDetails(params.walletContractAddress, params.apiKey);\n\n    if (!userAddressDetails) {\n      throw new Error('Unable to fetch user address details');\n    }\n\n    // Decrypt backup private key and get address\n    let backupPrv;\n\n    try {\n      backupPrv = this.bitgo.decrypt({\n        input: backupKey,\n        password: params.walletPassphrase,\n      });\n    } catch (e) {\n      throw new Error(`Error decrypting backup keychain: ${e.message}`);\n    }\n    const keyPair = new KeyPair({ prv: backupPrv });\n    const backupSigningKey = keyPair.getKeys().prv;\n    if (!backupSigningKey) {\n      throw new Error('no private key');\n    }\n    const backupKeyAddress = keyPair.getAddress();\n\n    const backupAddressDetails = await this.getAddressDetails(backupKeyAddress, params.apiKey || '');\n\n    if (!backupAddressDetails.counter || !backupAddressDetails.balance) {\n      throw new Error(`Missing required detail(s): counter, balance`);\n    }\n    const backupKeyNonce = new BigNumber(backupAddressDetails.counter + 1, 10);\n\n    // get balance of backupKey to ensure funds are available to pay fees\n    const backupKeyBalance = new BigNumber(backupAddressDetails.balance, 10);\n\n    const gasLimit = isValidOriginatedAddress(params.recoveryDestination)\n      ? TRANSACTION_GAS_LIMIT.CONTRACT_TRANSFER\n      : TRANSACTION_GAS_LIMIT.TRANSFER;\n    const gasPrice = TRANSACTION_FEE.TRANSFER;\n\n    // Checking whether back up key address has sufficient funds for transaction\n    if (backupKeyBalance.lt(gasPrice)) {\n      const weiToGwei = 10 ** 6;\n      throw new Error(\n        `Backup key address ${backupKeyAddress} has balance ${(\n          backupKeyBalance.toNumber() / weiToGwei\n        ).toString()} Gwei.` +\n          `This address must have a balance of at least ${(gasPrice / weiToGwei).toString()}` +\n          ` Gwei to perform recoveries. Try sending some funds to this address then retry.`\n      );\n    }\n\n    // get balance of sender address\n    if (!userAddressDetails.balance || userAddressDetails.balance === 0) {\n      throw new Error('No funds to recover from source address');\n    }\n    const txAmount = userAddressDetails.balance;\n    if (new BigNumber(txAmount).isLessThanOrEqualTo(0)) {\n      throw new Error('Wallet does not have enough funds to recover');\n    }\n\n    const feeInfo = {\n      fee: new BigNumber(TRANSACTION_FEE.TRANSFER),\n      gasLimit: new BigNumber(gasLimit),\n      storageLimit: new BigNumber(TRANSACTION_STORAGE_LIMIT.TRANSFER),\n    };\n\n    const txBuilder = new TransactionBuilder(coins.get(this.getChain()));\n\n    txBuilder.type(TransactionType.Send);\n    txBuilder.source(backupKeyAddress);\n\n    // Used to set the branch for the transaction\n    const chainHead: any = await this.recoveryBlockchainExplorerQuery({\n      actionPath: 'head',\n    });\n\n    if (!chainHead || !chainHead.hash) {\n      throw new Error('Unable to fetch chain head');\n    }\n    txBuilder.branch(chainHead.hash);\n\n    if (!backupAddressDetails.revealed) {\n      feeInfo.fee = feeInfo.fee.plus(TRANSACTION_FEE.REVEAL);\n      feeInfo.gasLimit = feeInfo.gasLimit.plus(TRANSACTION_GAS_LIMIT.REVEAL);\n      feeInfo.storageLimit = feeInfo.storageLimit.plus(TRANSACTION_STORAGE_LIMIT.REVEAL);\n      backupKeyNonce.plus(1);\n      const publicKeyToReveal = keyPair.getKeys();\n      txBuilder.publicKeyToReveal(publicKeyToReveal.pub);\n    }\n\n    txBuilder.counter(backupKeyNonce.toString());\n\n    const packedDataToSign = await this.packDataToSign(\n      params.walletContractAddress,\n      backupKeyNonce.toString(),\n      params.recoveryDestination,\n      txAmount?.toString()\n    );\n\n    txBuilder\n      .transfer(txAmount?.toString())\n      .from(params.walletContractAddress)\n      .to(params.recoveryDestination)\n      .counter(backupKeyNonce.toString())\n      .fee(TRANSACTION_FEE.TRANSFER.toString())\n      .storageLimit(TRANSACTION_STORAGE_LIMIT.TRANSFER.toString())\n      .gasLimit(gasLimit.toString())\n      .dataToSign(packedDataToSign);\n\n    txBuilder.sign({ key: backupSigningKey });\n    const signedTx = await txBuilder.build();\n\n    return {\n      id: signedTx.id,\n      tx: signedTx.toBroadcastFormat(),\n    };\n  }\n\n  /**\n   * Explain a Tezos transaction from txHex\n   * @param params\n   */\n  async explainTransaction(params: Interface.ExplainTransactionOptions): Promise<TransactionExplanation> {\n    const txHex = params.txHex || (params.halfSigned && params.halfSigned.txHex);\n    if (!txHex || !params.feeInfo) {\n      throw new Error('missing explain tx parameters');\n    }\n    const txBuilder = new TransactionBuilder(coins.get(this.getChain()));\n    // Newer coins can return BaseTransactionBuilderFactory instead of BaseTransactionBuilder\n    if (!(txBuilder instanceof BaseTransactionBuilder)) {\n      throw new Error('getBuilder() did not return an BaseTransactionBuilder object. Has it been updated?');\n    }\n    txBuilder.from(txHex);\n    const tx = await txBuilder.build();\n\n    const displayOrder = ['id', 'outputAmount', 'changeAmount', 'outputs', 'changeOutputs', 'fee'];\n\n    return {\n      displayOrder,\n      id: tx.id,\n      outputs: tx.outputs,\n      outputAmount: tx.outputs\n        .reduce((accumulator, output) => accumulator.plus(output.value), new BigNumber('0'))\n        .toFixed(0),\n      changeOutputs: [], // account based does not use change outputs\n      changeAmount: '0', // account base does not make change\n      fee: params.feeInfo,\n    } as any;\n  }\n\n  isValidPub(pub: string): boolean {\n    return Utils.isValidPublicKey(pub);\n  }\n\n  /** @inheritDoc */\n  auditDecryptedKey(params: AuditDecryptedKeyParams) {\n    throw new MethodNotImplementedError();\n  }\n}\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@bitgo/sdk-coin-xtz",
3
- "version": "2.4.12",
3
+ "version": "2.5.0",
4
4
  "description": "BitGo SDK coin library for Tezos",
5
5
  "main": "./dist/src/index.js",
6
6
  "types": "./dist/src/index.d.ts",
@@ -41,20 +41,21 @@
41
41
  },
42
42
  "dependencies": {
43
43
  "@bitgo/blake2b": "^3.2.4",
44
- "@bitgo/sdk-core": "^36.1.0",
44
+ "@bitgo/sdk-core": "^36.3.0",
45
45
  "@bitgo/secp256k1": "^1.4.0",
46
- "@bitgo/statics": "^57.1.0",
46
+ "@bitgo/statics": "^57.3.0",
47
47
  "@noble/curves": "1.8.1",
48
48
  "@taquito/local-forging": "6.3.5-beta.0",
49
49
  "@taquito/signer": "6.3.5-beta.0",
50
50
  "bignumber.js": "^9.0.0",
51
51
  "bs58check": "^2.1.2",
52
52
  "libsodium-wrappers": "^0.7.6",
53
- "lodash": "^4.17.15"
53
+ "lodash": "^4.17.15",
54
+ "superagent": "^9.0.1"
54
55
  },
55
56
  "devDependencies": {
56
- "@bitgo/sdk-api": "^1.66.0",
57
- "@bitgo/sdk-test": "^9.0.1"
57
+ "@bitgo/sdk-api": "^1.66.2",
58
+ "@bitgo/sdk-test": "^9.0.3"
58
59
  },
59
- "gitHead": "cf55aa27fda96d4ea04983955142df157409addf"
60
+ "gitHead": "e059224e9ae21d6e1adf5ddb06721fe9954f71ee"
60
61
  }