@bitgo-beta/sdk-coin-xtz 1.4.3-alpha.42 → 1.4.3-alpha.421
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/src/index.js +23 -9
- package/dist/src/lib/iface.d.ts +36 -2
- package/dist/src/lib/iface.d.ts.map +1 -1
- package/dist/src/lib/iface.js +1 -1
- package/dist/src/lib/index.js +23 -9
- package/dist/src/lib/keyPair.js +41 -27
- package/dist/src/lib/multisigUtils.js +36 -23
- package/dist/src/lib/transaction.d.ts.map +1 -1
- package/dist/src/lib/transaction.js +41 -25
- package/dist/src/lib/transactionBuilder.d.ts +2 -1
- package/dist/src/lib/transactionBuilder.d.ts.map +1 -1
- package/dist/src/lib/transactionBuilder.js +17 -16
- package/dist/src/lib/transferBuilder.js +1 -1
- package/dist/src/lib/utils.d.ts +42 -27
- package/dist/src/lib/utils.d.ts.map +1 -1
- package/dist/src/lib/utils.js +70 -38
- package/dist/src/xtz.d.ts +50 -5
- package/dist/src/xtz.d.ts.map +1 -1
- package/dist/src/xtz.js +228 -8
- package/dist/test/fixtures.d.ts +571 -0
- package/dist/test/fixtures.d.ts.map +1 -0
- package/dist/test/fixtures.js +656 -0
- package/dist/test/resources.d.ts +451 -0
- package/dist/test/resources.d.ts.map +1 -0
- package/dist/test/resources.js +349 -0
- package/dist/test/unit/keyPair.d.ts +2 -0
- package/dist/test/unit/keyPair.d.ts.map +1 -0
- package/dist/test/unit/keyPair.js +142 -0
- package/dist/test/unit/offlineTransactionBuilder.d.ts +2 -0
- package/dist/test/unit/offlineTransactionBuilder.d.ts.map +1 -0
- package/dist/test/unit/offlineTransactionBuilder.js +291 -0
- package/dist/test/unit/transaction.d.ts +2 -0
- package/dist/test/unit/transaction.d.ts.map +1 -0
- package/dist/test/unit/transaction.js +101 -0
- package/dist/test/unit/transactionBuilder.d.ts +2 -0
- package/dist/test/unit/transactionBuilder.d.ts.map +1 -0
- package/dist/test/unit/transactionBuilder.js +656 -0
- package/dist/test/unit/transferBuilder.d.ts +2 -0
- package/dist/test/unit/transferBuilder.d.ts.map +1 -0
- package/dist/test/unit/transferBuilder.js +82 -0
- package/dist/test/unit/util.d.ts +2 -0
- package/dist/test/unit/util.d.ts.map +1 -0
- package/dist/test/unit/util.js +198 -0
- package/dist/test/unit/xtz.d.ts +2 -0
- package/dist/test/unit/xtz.d.ts.map +1 -0
- package/dist/test/unit/xtz.js +192 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/package.json +19 -14
- package/.eslintignore +0 -5
- package/.mocharc.yml +0 -8
- package/CHANGELOG.md +0 -106
|
@@ -61,4 +61,4 @@ class TransferBuilder {
|
|
|
61
61
|
}
|
|
62
62
|
}
|
|
63
63
|
exports.TransferBuilder = TransferBuilder;
|
|
64
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
64
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNmZXJCdWlsZGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2xpYi90cmFuc2ZlckJ1aWxkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsbURBQTZEO0FBRzdELDhCQUE4QjtBQUM5QixzQ0FBc0M7QUFDdEMsTUFBYSxlQUFlO0lBVzFCLE1BQU0sQ0FBQyxNQUFjO1FBQ25CLElBQUksQ0FBQyxPQUFPLEdBQUcsTUFBTSxDQUFDO1FBQ3RCLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVELElBQUksQ0FBQyxJQUFZO1FBQ2YsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUM7UUFDbEIsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRUQsSUFBSSxDQUFDLE9BQWU7UUFDbEIsSUFBSSxDQUFDLFlBQVksR0FBRyxPQUFPLENBQUM7UUFDNUIsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRUQsRUFBRSxDQUFDLE9BQWU7UUFDaEIsSUFBSSxDQUFDLFVBQVUsR0FBRyxPQUFPLENBQUM7UUFDMUIsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRUQsR0FBRyxDQUFDLEdBQVc7UUFDYixJQUFJLENBQUMsSUFBSSxHQUFHLEdBQUcsQ0FBQztRQUNoQixPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFFRCxRQUFRLENBQUMsUUFBZ0I7UUFDdkIsSUFBSSxDQUFDLFNBQVMsR0FBRyxRQUFRLENBQUM7UUFDMUIsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRUQsWUFBWSxDQUFDLFlBQW9CO1FBQy9CLElBQUksQ0FBQyxhQUFhLEdBQUcsWUFBWSxDQUFDO1FBQ2xDLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVELFVBQVUsQ0FBQyxVQUFrQjtRQUMzQixJQUFJLENBQUMsV0FBVyxHQUFHLFVBQVUsQ0FBQztRQUM5QixPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFFRCxPQUFPLENBQUMsT0FBZTtRQUNyQixJQUFJLENBQUMsUUFBUSxHQUFHLE9BQU8sQ0FBQztRQUN4QixPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFFRCxLQUFLO1FBQ0gsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsWUFBWSxJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztZQUMxRSxNQUFNLElBQUksZ0NBQXFCLENBQzdCLHlHQUF5RyxDQUMxRyxDQUFDO1FBQ0osQ0FBQztRQUNELE9BQU87WUFDTCxNQUFNLEVBQUUsSUFBSSxDQUFDLE9BQU87WUFDcEIsSUFBSSxFQUFFLElBQUksQ0FBQyxLQUFLO1lBQ2hCLElBQUksRUFBRSxJQUFJLENBQUMsWUFBWTtZQUN2QixFQUFFLEVBQUUsSUFBSSxDQUFDLFVBQVU7WUFDbkIsR0FBRyxFQUFFO2dCQUNILEdBQUcsRUFBRSxJQUFJLENBQUMsSUFBSTtnQkFDZCxRQUFRLEVBQUUsSUFBSSxDQUFDLFNBQVM7Z0JBQ3hCLFlBQVksRUFBRSxJQUFJLENBQUMsYUFBYTthQUNqQztZQUNELFVBQVUsRUFBRSxJQUFJLENBQUMsV0FBVztZQUM1QixPQUFPLEVBQUUsSUFBSSxDQUFDLFFBQVE7U0FDdkIsQ0FBQztJQUNKLENBQUM7Q0FDRjtBQTVFRCwwQ0E0RUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCdWlsZFRyYW5zYWN0aW9uRXJyb3IgfSBmcm9tICdAYml0Z28tYmV0YS9zZGstY29yZSc7XG5pbXBvcnQgeyBUcmFuc2ZlckRhdGEgfSBmcm9tICcuL2lmYWNlJztcblxuLyoqIFRlem9zIHRyYW5zZmVyIGJ1aWxkZXIuICovXG4vLyBUT0RPOiBpbXBsZW1lbnQgQmFzZVRyYW5zZmVyQnVpbGRlclxuZXhwb3J0IGNsYXNzIFRyYW5zZmVyQnVpbGRlciB7XG4gIHByaXZhdGUgX2Ftb3VudDogc3RyaW5nO1xuICBwcml2YXRlIF9jb2luOiBzdHJpbmc7XG4gIHByaXZhdGUgX3RvQWRkcmVzczogc3RyaW5nO1xuICBwcml2YXRlIF9mcm9tQWRkcmVzczogc3RyaW5nO1xuICBwcml2YXRlIF9mZWU6IHN0cmluZztcbiAgcHJpdmF0ZSBfZ2FzTGltaXQ6IHN0cmluZztcbiAgcHJpdmF0ZSBfc3RvcmFnZUxpbWl0OiBzdHJpbmc7XG4gIHByaXZhdGUgX2RhdGFUb1NpZ246IHN0cmluZztcbiAgcHJpdmF0ZSBfY291bnRlcjogc3RyaW5nO1xuXG4gIGFtb3VudChhbW91bnQ6IHN0cmluZyk6IFRyYW5zZmVyQnVpbGRlciB7XG4gICAgdGhpcy5fYW1vdW50ID0gYW1vdW50O1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgY29pbihjb2luOiBzdHJpbmcpOiBUcmFuc2ZlckJ1aWxkZXIge1xuICAgIHRoaXMuX2NvaW4gPSBjb2luO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgZnJvbShhZGRyZXNzOiBzdHJpbmcpOiBUcmFuc2ZlckJ1aWxkZXIge1xuICAgIHRoaXMuX2Zyb21BZGRyZXNzID0gYWRkcmVzcztcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIHRvKGFkZHJlc3M6IHN0cmluZyk6IFRyYW5zZmVyQnVpbGRlciB7XG4gICAgdGhpcy5fdG9BZGRyZXNzID0gYWRkcmVzcztcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIGZlZShmZWU6IHN0cmluZyk6IFRyYW5zZmVyQnVpbGRlciB7XG4gICAgdGhpcy5fZmVlID0gZmVlO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgZ2FzTGltaXQoZ2FzTGltaXQ6IHN0cmluZyk6IFRyYW5zZmVyQnVpbGRlciB7XG4gICAgdGhpcy5fZ2FzTGltaXQgPSBnYXNMaW1pdDtcbiAgICByZXR1cm4gdGhpcztcbiAgfVxuXG4gIHN0b3JhZ2VMaW1pdChzdG9yYWdlTGltaXQ6IHN0cmluZyk6IFRyYW5zZmVyQnVpbGRlciB7XG4gICAgdGhpcy5fc3RvcmFnZUxpbWl0ID0gc3RvcmFnZUxpbWl0O1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgZGF0YVRvU2lnbihkYXRhVG9TaWduOiBzdHJpbmcpOiBUcmFuc2ZlckJ1aWxkZXIge1xuICAgIHRoaXMuX2RhdGFUb1NpZ24gPSBkYXRhVG9TaWduO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgY291bnRlcihjb3VudGVyOiBzdHJpbmcpOiBUcmFuc2ZlckJ1aWxkZXIge1xuICAgIHRoaXMuX2NvdW50ZXIgPSBjb3VudGVyO1xuICAgIHJldHVybiB0aGlzO1xuICB9XG5cbiAgYnVpbGQoKTogVHJhbnNmZXJEYXRhIHtcbiAgICBpZiAoIXRoaXMuX2Ftb3VudCB8fCAhdGhpcy5fZnJvbUFkZHJlc3MgfHwgIXRoaXMuX3RvQWRkcmVzcyB8fCAhdGhpcy5fZmVlKSB7XG4gICAgICB0aHJvdyBuZXcgQnVpbGRUcmFuc2FjdGlvbkVycm9yKFxuICAgICAgICAnTWlzc2luZyB0cmFuc2ZlciBtYW5kYXRvcnkgZmllbGRzLiBBbW91bnQsIGZyb20gYWRkcmVzcywgZGVzdGluYXRpb24gKHRvKSBhZGRyZXNzIGFuZCBmZWUgYXJlIG1hbmRhdG9yeSdcbiAgICAgICk7XG4gICAgfVxuICAgIHJldHVybiB7XG4gICAgICBhbW91bnQ6IHRoaXMuX2Ftb3VudCxcbiAgICAgIGNvaW46IHRoaXMuX2NvaW4sXG4gICAgICBmcm9tOiB0aGlzLl9mcm9tQWRkcmVzcyxcbiAgICAgIHRvOiB0aGlzLl90b0FkZHJlc3MsXG4gICAgICBmZWU6IHtcbiAgICAgICAgZmVlOiB0aGlzLl9mZWUsXG4gICAgICAgIGdhc0xpbWl0OiB0aGlzLl9nYXNMaW1pdCxcbiAgICAgICAgc3RvcmFnZUxpbWl0OiB0aGlzLl9zdG9yYWdlTGltaXQsXG4gICAgICB9LFxuICAgICAgZGF0YVRvU2lnbjogdGhpcy5fZGF0YVRvU2lnbixcbiAgICAgIGNvdW50ZXI6IHRoaXMuX2NvdW50ZXIsXG4gICAgfTtcbiAgfVxufVxuIl19
|
package/dist/src/lib/utils.d.ts
CHANGED
|
@@ -1,7 +1,6 @@
|
|
|
1
|
-
/// <reference types="node" />
|
|
2
1
|
import { HashType, SignResponse } from './iface';
|
|
3
2
|
import { KeyPair } from './keyPair';
|
|
4
|
-
export declare const DEFAULT_WATERMARK: Uint8Array
|
|
3
|
+
export declare const DEFAULT_WATERMARK: Uint8Array<ArrayBuffer>;
|
|
5
4
|
/**
|
|
6
5
|
* Encode the payload to base58 with a specific Tezos prefix.
|
|
7
6
|
*
|
|
@@ -144,103 +143,103 @@ export declare function decodeKey(hash: string, hashType: HashType): Buffer;
|
|
|
144
143
|
export declare function decodeSignature(signature: string, hashType: HashType): Buffer;
|
|
145
144
|
export declare const hashTypes: {
|
|
146
145
|
tz1: {
|
|
147
|
-
prefix: Buffer
|
|
146
|
+
prefix: Buffer<ArrayBuffer>;
|
|
148
147
|
byteLength: number;
|
|
149
148
|
};
|
|
150
149
|
tz2: {
|
|
151
|
-
prefix: Buffer
|
|
150
|
+
prefix: Buffer<ArrayBuffer>;
|
|
152
151
|
byteLength: number;
|
|
153
152
|
};
|
|
154
153
|
tz3: {
|
|
155
|
-
prefix: Buffer
|
|
154
|
+
prefix: Buffer<ArrayBuffer>;
|
|
156
155
|
byteLength: number;
|
|
157
156
|
};
|
|
158
157
|
KT: {
|
|
159
|
-
prefix: Buffer
|
|
158
|
+
prefix: Buffer<ArrayBuffer>;
|
|
160
159
|
byteLength: number;
|
|
161
160
|
};
|
|
162
161
|
edpk: {
|
|
163
|
-
prefix: Buffer
|
|
162
|
+
prefix: Buffer<ArrayBuffer>;
|
|
164
163
|
byteLength: number;
|
|
165
164
|
};
|
|
166
165
|
edsk2: {
|
|
167
|
-
prefix: Buffer
|
|
166
|
+
prefix: Buffer<ArrayBuffer>;
|
|
168
167
|
byteLength: number;
|
|
169
168
|
};
|
|
170
169
|
spsk: {
|
|
171
|
-
prefix: Buffer
|
|
170
|
+
prefix: Buffer<ArrayBuffer>;
|
|
172
171
|
byteLength: number;
|
|
173
172
|
};
|
|
174
173
|
p2sk: {
|
|
175
|
-
prefix: Buffer
|
|
174
|
+
prefix: Buffer<ArrayBuffer>;
|
|
176
175
|
byteLength: number;
|
|
177
176
|
};
|
|
178
177
|
b: {
|
|
179
|
-
prefix: Buffer
|
|
178
|
+
prefix: Buffer<ArrayBuffer>;
|
|
180
179
|
byteLength: number;
|
|
181
180
|
};
|
|
182
181
|
o: {
|
|
183
|
-
prefix: Buffer
|
|
182
|
+
prefix: Buffer<ArrayBuffer>;
|
|
184
183
|
byteLength: number;
|
|
185
184
|
};
|
|
186
185
|
Lo: {
|
|
187
|
-
prefix: Buffer
|
|
186
|
+
prefix: Buffer<ArrayBuffer>;
|
|
188
187
|
byteLength: number;
|
|
189
188
|
};
|
|
190
189
|
LLo: {
|
|
191
|
-
prefix: Buffer
|
|
190
|
+
prefix: Buffer<ArrayBuffer>;
|
|
192
191
|
byteLength: number;
|
|
193
192
|
};
|
|
194
193
|
P: {
|
|
195
|
-
prefix: Buffer
|
|
194
|
+
prefix: Buffer<ArrayBuffer>;
|
|
196
195
|
byteLength: number;
|
|
197
196
|
};
|
|
198
197
|
Co: {
|
|
199
|
-
prefix: Buffer
|
|
198
|
+
prefix: Buffer<ArrayBuffer>;
|
|
200
199
|
byteLength: number;
|
|
201
200
|
};
|
|
202
201
|
sppk: {
|
|
203
|
-
prefix: Buffer
|
|
202
|
+
prefix: Buffer<ArrayBuffer>;
|
|
204
203
|
byteLength: number;
|
|
205
204
|
};
|
|
206
205
|
p2pk: {
|
|
207
|
-
prefix: Buffer
|
|
206
|
+
prefix: Buffer<ArrayBuffer>;
|
|
208
207
|
byteLength: number;
|
|
209
208
|
};
|
|
210
209
|
edesk: {
|
|
211
|
-
prefix: Buffer
|
|
210
|
+
prefix: Buffer<ArrayBuffer>;
|
|
212
211
|
byteLength: number;
|
|
213
212
|
};
|
|
214
213
|
edsk: {
|
|
215
|
-
prefix: Buffer
|
|
214
|
+
prefix: Buffer<ArrayBuffer>;
|
|
216
215
|
byteLength: number;
|
|
217
216
|
};
|
|
218
217
|
edsig: {
|
|
219
|
-
prefix: Buffer
|
|
218
|
+
prefix: Buffer<ArrayBuffer>;
|
|
220
219
|
byteLength: number;
|
|
221
220
|
};
|
|
222
221
|
spsig1: {
|
|
223
|
-
prefix: Buffer
|
|
222
|
+
prefix: Buffer<ArrayBuffer>;
|
|
224
223
|
byteLength: number;
|
|
225
224
|
};
|
|
226
225
|
p2sig: {
|
|
227
|
-
prefix: Buffer
|
|
226
|
+
prefix: Buffer<ArrayBuffer>;
|
|
228
227
|
byteLength: number;
|
|
229
228
|
};
|
|
230
229
|
sig: {
|
|
231
|
-
prefix: Buffer
|
|
230
|
+
prefix: Buffer<ArrayBuffer>;
|
|
232
231
|
byteLength: number;
|
|
233
232
|
};
|
|
234
233
|
Net: {
|
|
235
|
-
prefix: Buffer
|
|
234
|
+
prefix: Buffer<ArrayBuffer>;
|
|
236
235
|
byteLength: number;
|
|
237
236
|
};
|
|
238
237
|
nce: {
|
|
239
|
-
prefix: Buffer
|
|
238
|
+
prefix: Buffer<ArrayBuffer>;
|
|
240
239
|
byteLength: number;
|
|
241
240
|
};
|
|
242
241
|
id: {
|
|
243
|
-
prefix: Buffer
|
|
242
|
+
prefix: Buffer<ArrayBuffer>;
|
|
244
243
|
byteLength: number;
|
|
245
244
|
};
|
|
246
245
|
};
|
|
@@ -262,4 +261,20 @@ export declare enum DEFAULT_STORAGE_LIMIT {
|
|
|
262
261
|
TRANSFER = 257,
|
|
263
262
|
REVEAL = 0
|
|
264
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
|
+
}
|
|
265
280
|
//# sourceMappingURL=utils.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/lib/utils.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/lib/utils.ts"],"names":[],"mappings":"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"}
|
package/dist/src/lib/utils.js
CHANGED
|
@@ -1,7 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
3
|
if (k2 === undefined) k2 = k;
|
|
4
|
-
Object.
|
|
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);
|
|
5
9
|
}) : (function(o, m, k, k2) {
|
|
6
10
|
if (k2 === undefined) k2 = k;
|
|
7
11
|
o[k2] = m[k];
|
|
@@ -11,22 +15,50 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (
|
|
|
11
15
|
}) : function(o, v) {
|
|
12
16
|
o["default"] = v;
|
|
13
17
|
});
|
|
14
|
-
var __importStar = (this && this.__importStar) || function (
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
};
|
|
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
|
+
})();
|
|
21
35
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
22
36
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
23
37
|
};
|
|
24
38
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
25
|
-
exports.
|
|
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
|
+
exports.base58encode = base58encode;
|
|
41
|
+
exports.calculateTransactionId = calculateTransactionId;
|
|
42
|
+
exports.calculateOriginatedAddress = calculateOriginatedAddress;
|
|
43
|
+
exports.sign = sign;
|
|
44
|
+
exports.verifySignature = verifySignature;
|
|
45
|
+
exports.generateDataToSign = generateDataToSign;
|
|
46
|
+
exports.isValidHash = isValidHash;
|
|
47
|
+
exports.isValidAddress = isValidAddress;
|
|
48
|
+
exports.isValidImplicitAddress = isValidImplicitAddress;
|
|
49
|
+
exports.isValidOriginatedAddress = isValidOriginatedAddress;
|
|
50
|
+
exports.isValidSignature = isValidSignature;
|
|
51
|
+
exports.isValidPublicKey = isValidPublicKey;
|
|
52
|
+
exports.isValidPrivateKey = isValidPrivateKey;
|
|
53
|
+
exports.isValidBlockHash = isValidBlockHash;
|
|
54
|
+
exports.isValidTransactionHash = isValidTransactionHash;
|
|
55
|
+
exports.isValidKey = isValidKey;
|
|
56
|
+
exports.decodeKey = decodeKey;
|
|
57
|
+
exports.decodeSignature = decodeSignature;
|
|
26
58
|
const sdk_core_1 = require("@bitgo-beta/sdk-core");
|
|
27
59
|
const signer_1 = require("@taquito/signer");
|
|
28
60
|
const base58check = __importStar(require("bs58check"));
|
|
29
|
-
const
|
|
61
|
+
const secp256k1_1 = require("@noble/curves/secp256k1");
|
|
30
62
|
const libsodium_wrappers_1 = __importDefault(require("libsodium-wrappers"));
|
|
31
63
|
const multisigUtils_1 = require("./multisigUtils");
|
|
32
64
|
// By default, use the transactions prefix
|
|
@@ -44,7 +76,6 @@ function base58encode(prefix, payload) {
|
|
|
44
76
|
n.set(payload, prefix.length);
|
|
45
77
|
return base58check.encode(n);
|
|
46
78
|
}
|
|
47
|
-
exports.base58encode = base58encode;
|
|
48
79
|
/**
|
|
49
80
|
* Calculate the transaction id for a for a signed transaction.
|
|
50
81
|
*
|
|
@@ -57,7 +88,6 @@ async function calculateTransactionId(encodedTransaction) {
|
|
|
57
88
|
const operationHashPayload = libsodium_wrappers_1.default.crypto_generichash(32, encodedTransactionBuffer);
|
|
58
89
|
return base58encode(exports.hashTypes.o.prefix, Buffer.from(operationHashPayload));
|
|
59
90
|
}
|
|
60
|
-
exports.calculateTransactionId = calculateTransactionId;
|
|
61
91
|
/**
|
|
62
92
|
* Calculate the address of a new originated account.
|
|
63
93
|
*
|
|
@@ -82,7 +112,6 @@ async function calculateOriginatedAddress(transactionId, index) {
|
|
|
82
112
|
const payload = libsodium_wrappers_1.default.crypto_generichash(20, new Uint8Array(tt));
|
|
83
113
|
return base58encode(exports.hashTypes.KT.prefix, Buffer.from(payload));
|
|
84
114
|
}
|
|
85
|
-
exports.calculateOriginatedAddress = calculateOriginatedAddress;
|
|
86
115
|
/**
|
|
87
116
|
* Generic data signing using Tezos library.
|
|
88
117
|
*
|
|
@@ -98,7 +127,6 @@ async function sign(keyPair, data, watermark = exports.DEFAULT_WATERMARK) {
|
|
|
98
127
|
const signer = new signer_1.InMemorySigner(keyPair.getKeys().prv);
|
|
99
128
|
return signer.sign(data, watermark);
|
|
100
129
|
}
|
|
101
|
-
exports.sign = sign;
|
|
102
130
|
/**
|
|
103
131
|
* Verifies the signature produced for a given message belongs to a secp256k1 public key.
|
|
104
132
|
*
|
|
@@ -109,9 +137,8 @@ exports.sign = sign;
|
|
|
109
137
|
* @returns {Promise<boolean>}
|
|
110
138
|
*/
|
|
111
139
|
async function verifySignature(message, publicKey, signature, watermark = exports.DEFAULT_WATERMARK) {
|
|
112
|
-
const rawPublicKey = decodeKey(publicKey, exports.hashTypes.sppk);
|
|
113
|
-
const
|
|
114
|
-
const key = ec.keyFromPublic(rawPublicKey);
|
|
140
|
+
const rawPublicKey = decodeKey(publicKey, exports.hashTypes.sppk).toString('hex');
|
|
141
|
+
const key = secp256k1_1.secp256k1.ProjectivePoint.fromHex(rawPublicKey);
|
|
115
142
|
const messageBuffer = Uint8Array.from(Buffer.from(message, 'hex'));
|
|
116
143
|
// Tezos signatures always have a watermark
|
|
117
144
|
const messageWithWatermark = new Uint8Array(watermark.length + messageBuffer.length);
|
|
@@ -120,9 +147,8 @@ async function verifySignature(message, publicKey, signature, watermark = export
|
|
|
120
147
|
await libsodium_wrappers_1.default.ready;
|
|
121
148
|
const bytesHash = Buffer.from(libsodium_wrappers_1.default.crypto_generichash(32, messageWithWatermark));
|
|
122
149
|
const rawSignature = decodeSignature(signature, exports.hashTypes.sig);
|
|
123
|
-
return
|
|
150
|
+
return secp256k1_1.secp256k1.verify(rawSignature, bytesHash, key.toHex());
|
|
124
151
|
}
|
|
125
|
-
exports.verifySignature = verifySignature;
|
|
126
152
|
/**
|
|
127
153
|
* Useful wrapper to create the generic multisig contract data to sign when moving funds.
|
|
128
154
|
*
|
|
@@ -139,9 +165,8 @@ function generateDataToSign(contractAddress, destinationAddress, amount, contrac
|
|
|
139
165
|
if (!isValidAddress(destinationAddress)) {
|
|
140
166
|
throw new Error('Invalid destination address ' + destinationAddress);
|
|
141
167
|
}
|
|
142
|
-
return multisigUtils_1.genericMultisigDataToSign(contractAddress, destinationAddress, amount, contractCounter);
|
|
168
|
+
return (0, multisigUtils_1.genericMultisigDataToSign)(contractAddress, destinationAddress, amount, contractCounter);
|
|
143
169
|
}
|
|
144
|
-
exports.generateDataToSign = generateDataToSign;
|
|
145
170
|
/**
|
|
146
171
|
* Returns whether or not the string is a valid Tezos hash of the given type
|
|
147
172
|
*
|
|
@@ -167,7 +192,6 @@ function isValidHash(hash, hashType) {
|
|
|
167
192
|
const hashLength = decodedHash.length - hashPrefix.length;
|
|
168
193
|
return hashLength === hashType.byteLength;
|
|
169
194
|
}
|
|
170
|
-
exports.isValidHash = isValidHash;
|
|
171
195
|
/**
|
|
172
196
|
* Returns whether or not the string is a valid Tezos address
|
|
173
197
|
*
|
|
@@ -177,7 +201,6 @@ exports.isValidHash = isValidHash;
|
|
|
177
201
|
function isValidAddress(hash) {
|
|
178
202
|
return isValidImplicitAddress(hash) || isValidHash(hash, exports.hashTypes.KT);
|
|
179
203
|
}
|
|
180
|
-
exports.isValidAddress = isValidAddress;
|
|
181
204
|
/**
|
|
182
205
|
* Returns whether or not the string is a valid Tezos implicit account address
|
|
183
206
|
*
|
|
@@ -187,7 +210,6 @@ exports.isValidAddress = isValidAddress;
|
|
|
187
210
|
function isValidImplicitAddress(hash) {
|
|
188
211
|
return isValidHash(hash, exports.hashTypes.tz1) || isValidHash(hash, exports.hashTypes.tz2) || isValidHash(hash, exports.hashTypes.tz3);
|
|
189
212
|
}
|
|
190
|
-
exports.isValidImplicitAddress = isValidImplicitAddress;
|
|
191
213
|
/**
|
|
192
214
|
* Returns whether or not the string is a valid Tezos originated account address
|
|
193
215
|
*
|
|
@@ -197,7 +219,6 @@ exports.isValidImplicitAddress = isValidImplicitAddress;
|
|
|
197
219
|
function isValidOriginatedAddress(hash) {
|
|
198
220
|
return isValidHash(hash, exports.hashTypes.KT);
|
|
199
221
|
}
|
|
200
|
-
exports.isValidOriginatedAddress = isValidOriginatedAddress;
|
|
201
222
|
/**
|
|
202
223
|
* Returns whether or not the string is a valid Tezos signature
|
|
203
224
|
*
|
|
@@ -210,7 +231,6 @@ function isValidSignature(hash) {
|
|
|
210
231
|
isValidHash(hash, exports.hashTypes.p2sig) ||
|
|
211
232
|
isValidHash(hash, exports.hashTypes.sig));
|
|
212
233
|
}
|
|
213
|
-
exports.isValidSignature = isValidSignature;
|
|
214
234
|
/**
|
|
215
235
|
* Returns whether or not the string is a valid Tezos public key
|
|
216
236
|
*
|
|
@@ -221,10 +241,9 @@ function isValidPublicKey(publicKey) {
|
|
|
221
241
|
return (isValidHash(publicKey, exports.hashTypes.sppk) ||
|
|
222
242
|
isValidHash(publicKey, exports.hashTypes.p2pk) ||
|
|
223
243
|
isValidHash(publicKey, exports.hashTypes.edpk) ||
|
|
224
|
-
sdk_core_1.isValidXpub(publicKey) // xpubs are valid too.
|
|
244
|
+
(0, sdk_core_1.isValidXpub)(publicKey) // xpubs are valid too.
|
|
225
245
|
);
|
|
226
246
|
}
|
|
227
|
-
exports.isValidPublicKey = isValidPublicKey;
|
|
228
247
|
/**
|
|
229
248
|
* Returns whether or not the string is a valid Tezos private key
|
|
230
249
|
*
|
|
@@ -237,7 +256,6 @@ function isValidPrivateKey(privateKey) {
|
|
|
237
256
|
isValidHash(privateKey, exports.hashTypes.spsk) ||
|
|
238
257
|
isValidHash(privateKey, exports.hashTypes.p2sk));
|
|
239
258
|
}
|
|
240
|
-
exports.isValidPrivateKey = isValidPrivateKey;
|
|
241
259
|
/**
|
|
242
260
|
* Returns whether or not the string is a valid Tezos block hash
|
|
243
261
|
*
|
|
@@ -247,7 +265,6 @@ exports.isValidPrivateKey = isValidPrivateKey;
|
|
|
247
265
|
function isValidBlockHash(hash) {
|
|
248
266
|
return isValidHash(hash, exports.hashTypes.b);
|
|
249
267
|
}
|
|
250
|
-
exports.isValidBlockHash = isValidBlockHash;
|
|
251
268
|
/**
|
|
252
269
|
* Returns whether or not the string is a valid Tezos transaction hash
|
|
253
270
|
*
|
|
@@ -257,7 +274,6 @@ exports.isValidBlockHash = isValidBlockHash;
|
|
|
257
274
|
function isValidTransactionHash(hash) {
|
|
258
275
|
return isValidHash(hash, exports.hashTypes.o);
|
|
259
276
|
}
|
|
260
|
-
exports.isValidTransactionHash = isValidTransactionHash;
|
|
261
277
|
/**
|
|
262
278
|
* Returns whether or not the string is a valid Tezos key given a prefix
|
|
263
279
|
*
|
|
@@ -268,7 +284,6 @@ exports.isValidTransactionHash = isValidTransactionHash;
|
|
|
268
284
|
function isValidKey(hash, hashType) {
|
|
269
285
|
return isValidHash(hash, hashType);
|
|
270
286
|
}
|
|
271
|
-
exports.isValidKey = isValidKey;
|
|
272
287
|
/**
|
|
273
288
|
* Get the original key form the text without the given prefix.
|
|
274
289
|
*
|
|
@@ -283,7 +298,6 @@ function decodeKey(hash, hashType) {
|
|
|
283
298
|
const decodedPrv = base58check.decode(hash);
|
|
284
299
|
return Buffer.from(decodedPrv.slice(hashType.prefix.length, decodedPrv.length));
|
|
285
300
|
}
|
|
286
|
-
exports.decodeKey = decodeKey;
|
|
287
301
|
/**
|
|
288
302
|
* Get the raw signature from a Tezos encoded one.
|
|
289
303
|
*
|
|
@@ -298,7 +312,6 @@ function decodeSignature(signature, hashType) {
|
|
|
298
312
|
const decodedPrv = base58check.decode(signature);
|
|
299
313
|
return Buffer.from(decodedPrv.slice(hashType.prefix.length, decodedPrv.length));
|
|
300
314
|
}
|
|
301
|
-
exports.decodeSignature = decodeSignature;
|
|
302
315
|
// Base58Check is used for encoding
|
|
303
316
|
// hashedTypes is used to validate hashes by type, by checking their prefix and
|
|
304
317
|
// the length of the Buffer obtained by decoding the hash (excluding the prefix)
|
|
@@ -442,19 +455,38 @@ var DEFAULT_GAS_LIMIT;
|
|
|
442
455
|
DEFAULT_GAS_LIMIT[DEFAULT_GAS_LIMIT["ORIGINATION"] = 10600] = "ORIGINATION";
|
|
443
456
|
DEFAULT_GAS_LIMIT[DEFAULT_GAS_LIMIT["TRANSFER"] = 10600] = "TRANSFER";
|
|
444
457
|
DEFAULT_GAS_LIMIT[DEFAULT_GAS_LIMIT["REVEAL"] = 10600] = "REVEAL";
|
|
445
|
-
})(DEFAULT_GAS_LIMIT
|
|
458
|
+
})(DEFAULT_GAS_LIMIT || (exports.DEFAULT_GAS_LIMIT = DEFAULT_GAS_LIMIT = {}));
|
|
446
459
|
var DEFAULT_FEE;
|
|
447
460
|
(function (DEFAULT_FEE) {
|
|
448
461
|
DEFAULT_FEE[DEFAULT_FEE["DELEGATION"] = 1257] = "DELEGATION";
|
|
449
462
|
DEFAULT_FEE[DEFAULT_FEE["ORIGINATION"] = 10000] = "ORIGINATION";
|
|
450
463
|
DEFAULT_FEE[DEFAULT_FEE["TRANSFER"] = 10000] = "TRANSFER";
|
|
451
464
|
DEFAULT_FEE[DEFAULT_FEE["REVEAL"] = 1420] = "REVEAL";
|
|
452
|
-
})(DEFAULT_FEE
|
|
465
|
+
})(DEFAULT_FEE || (exports.DEFAULT_FEE = DEFAULT_FEE = {}));
|
|
453
466
|
var DEFAULT_STORAGE_LIMIT;
|
|
454
467
|
(function (DEFAULT_STORAGE_LIMIT) {
|
|
455
468
|
DEFAULT_STORAGE_LIMIT[DEFAULT_STORAGE_LIMIT["DELEGATION"] = 0] = "DELEGATION";
|
|
456
469
|
DEFAULT_STORAGE_LIMIT[DEFAULT_STORAGE_LIMIT["ORIGINATION"] = 257] = "ORIGINATION";
|
|
457
470
|
DEFAULT_STORAGE_LIMIT[DEFAULT_STORAGE_LIMIT["TRANSFER"] = 257] = "TRANSFER";
|
|
458
471
|
DEFAULT_STORAGE_LIMIT[DEFAULT_STORAGE_LIMIT["REVEAL"] = 0] = "REVEAL";
|
|
459
|
-
})(DEFAULT_STORAGE_LIMIT
|
|
460
|
-
//# 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-beta/sdk-core';\nimport { InMemorySigner } from '@taquito/signer';\nimport * as base58check from 'bs58check';\nimport { ec as EC } from 'elliptic';\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);\n  const ec = new EC('secp256k1');\n  const key = ec.keyFromPublic(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 key.verify(bytesHash, { r: rawSignature.slice(0, 32), s: rawSignature.slice(32, 64) });\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"]}
|
|
472
|
+
})(DEFAULT_STORAGE_LIMIT || (exports.DEFAULT_STORAGE_LIMIT = DEFAULT_STORAGE_LIMIT = {}));
|
|
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-beta/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"]}
|