ox 0.9.16 → 0.10.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 +27 -0
- package/README.md +4 -4
- package/TxEnvelope/package.json +6 -0
- package/TxEnvelopeEip1559/package.json +6 -0
- package/TxEnvelopeEip2930/package.json +6 -0
- package/TxEnvelopeEip4844/package.json +6 -0
- package/TxEnvelopeEip7702/package.json +6 -0
- package/TxEnvelopeLegacy/package.json +6 -0
- package/_cjs/core/{TransactionEnvelope.js → TxEnvelope.js} +1 -1
- package/_cjs/core/TxEnvelope.js.map +1 -0
- package/_cjs/core/{TransactionEnvelopeEip1559.js → TxEnvelopeEip1559.js} +2 -2
- package/_cjs/core/TxEnvelopeEip1559.js.map +1 -0
- package/_cjs/core/{TransactionEnvelopeEip2930.js → TxEnvelopeEip2930.js} +2 -2
- package/_cjs/core/TxEnvelopeEip2930.js.map +1 -0
- package/_cjs/core/{TransactionEnvelopeEip4844.js → TxEnvelopeEip4844.js} +4 -4
- package/_cjs/core/TxEnvelopeEip4844.js.map +1 -0
- package/_cjs/core/{TransactionEnvelopeEip7702.js → TxEnvelopeEip7702.js} +4 -4
- package/_cjs/core/TxEnvelopeEip7702.js.map +1 -0
- package/_cjs/core/{TransactionEnvelopeLegacy.js → TxEnvelopeLegacy.js} +2 -2
- package/_cjs/core/TxEnvelopeLegacy.js.map +1 -0
- package/_cjs/core/WebAuthnP256.js +1 -1
- package/_cjs/core/WebAuthnP256.js.map +1 -1
- package/_cjs/erc8021/Attribution.js +36 -6
- package/_cjs/erc8021/Attribution.js.map +1 -1
- package/_cjs/index.docs.js +1 -0
- package/_cjs/index.docs.js.map +1 -1
- package/_cjs/index.js +7 -7
- package/_cjs/index.js.map +1 -1
- package/_cjs/tempo/AuthorizationTempo.js +101 -0
- package/_cjs/tempo/AuthorizationTempo.js.map +1 -0
- package/_cjs/tempo/KeyAuthorization.js +123 -0
- package/_cjs/tempo/KeyAuthorization.js.map +1 -0
- package/_cjs/tempo/PoolId.js +10 -0
- package/_cjs/tempo/PoolId.js.map +1 -0
- package/_cjs/tempo/SignatureEnvelope.js +394 -0
- package/_cjs/tempo/SignatureEnvelope.js.map +1 -0
- package/_cjs/tempo/Tick.js +77 -0
- package/_cjs/tempo/Tick.js.map +1 -0
- package/_cjs/tempo/TokenId.js +28 -0
- package/_cjs/tempo/TokenId.js.map +1 -0
- package/_cjs/tempo/TokenRole.js +26 -0
- package/_cjs/tempo/TokenRole.js.map +1 -0
- package/_cjs/tempo/Transaction.js +80 -0
- package/_cjs/tempo/Transaction.js.map +1 -0
- package/_cjs/tempo/TransactionReceipt.js +26 -0
- package/_cjs/tempo/TransactionReceipt.js.map +1 -0
- package/_cjs/tempo/TransactionRequest.js +53 -0
- package/_cjs/tempo/TransactionRequest.js.map +1 -0
- package/_cjs/tempo/TxEnvelopeTempo.js +267 -0
- package/_cjs/tempo/TxEnvelopeTempo.js.map +1 -0
- package/_cjs/tempo/index.js +15 -0
- package/_cjs/tempo/index.js.map +1 -0
- package/_cjs/version.js +1 -1
- package/_esm/core/Blobs.js +8 -8
- package/_esm/core/{TransactionEnvelope.js → TxEnvelope.js} +11 -11
- package/_esm/core/TxEnvelope.js.map +1 -0
- package/_esm/core/{TransactionEnvelopeEip1559.js → TxEnvelopeEip1559.js} +42 -42
- package/_esm/core/TxEnvelopeEip1559.js.map +1 -0
- package/_esm/core/{TransactionEnvelopeEip2930.js → TxEnvelopeEip2930.js} +43 -43
- package/_esm/core/TxEnvelopeEip2930.js.map +1 -0
- package/_esm/core/{TransactionEnvelopeEip4844.js → TxEnvelopeEip4844.js} +42 -42
- package/_esm/core/TxEnvelopeEip4844.js.map +1 -0
- package/_esm/core/{TransactionEnvelopeEip7702.js → TxEnvelopeEip7702.js} +40 -40
- package/_esm/core/TxEnvelopeEip7702.js.map +1 -0
- package/_esm/core/{TransactionEnvelopeLegacy.js → TxEnvelopeLegacy.js} +42 -42
- package/_esm/core/TxEnvelopeLegacy.js.map +1 -0
- package/_esm/core/WebAuthnP256.js +1 -1
- package/_esm/core/WebAuthnP256.js.map +1 -1
- package/_esm/erc8021/Attribution.js +58 -13
- package/_esm/erc8021/Attribution.js.map +1 -1
- package/_esm/index.docs.js +1 -0
- package/_esm/index.docs.js.map +1 -1
- package/_esm/index.js +192 -192
- package/_esm/index.js.map +1 -1
- package/_esm/tempo/AuthorizationTempo.js +664 -0
- package/_esm/tempo/AuthorizationTempo.js.map +1 -0
- package/_esm/tempo/KeyAuthorization.js +426 -0
- package/_esm/tempo/KeyAuthorization.js.map +1 -0
- package/_esm/tempo/PoolId.js +28 -0
- package/_esm/tempo/PoolId.js.map +1 -0
- package/_esm/tempo/SignatureEnvelope.js +660 -0
- package/_esm/tempo/SignatureEnvelope.js.map +1 -0
- package/_esm/tempo/Tick.js +147 -0
- package/_esm/tempo/Tick.js.map +1 -0
- package/_esm/tempo/TokenId.js +71 -0
- package/_esm/tempo/TokenId.js.map +1 -0
- package/_esm/tempo/TokenRole.js +40 -0
- package/_esm/tempo/TokenRole.js.map +1 -0
- package/_esm/tempo/Transaction.js +167 -0
- package/_esm/tempo/Transaction.js.map +1 -0
- package/_esm/tempo/TransactionReceipt.js +138 -0
- package/_esm/tempo/TransactionReceipt.js.map +1 -0
- package/_esm/tempo/TransactionRequest.js +99 -0
- package/_esm/tempo/TransactionRequest.js.map +1 -0
- package/_esm/tempo/TxEnvelopeTempo.js +607 -0
- package/_esm/tempo/TxEnvelopeTempo.js.map +1 -0
- package/_esm/tempo/index.js +298 -0
- package/_esm/tempo/index.js.map +1 -0
- package/_esm/version.js +1 -1
- package/_types/core/Blobs.d.ts +8 -8
- package/_types/core/{TransactionEnvelope.d.ts → TxEnvelope.d.ts} +11 -11
- package/_types/core/TxEnvelope.d.ts.map +1 -0
- package/_types/core/{TransactionEnvelopeEip1559.d.ts → TxEnvelopeEip1559.d.ts} +54 -54
- package/_types/core/TxEnvelopeEip1559.d.ts.map +1 -0
- package/_types/core/{TransactionEnvelopeEip2930.d.ts → TxEnvelopeEip2930.d.ts} +55 -55
- package/_types/core/TxEnvelopeEip2930.d.ts.map +1 -0
- package/_types/core/{TransactionEnvelopeEip4844.d.ts → TxEnvelopeEip4844.d.ts} +54 -54
- package/_types/core/TxEnvelopeEip4844.d.ts.map +1 -0
- package/_types/core/{TransactionEnvelopeEip7702.d.ts → TxEnvelopeEip7702.d.ts} +49 -49
- package/_types/core/TxEnvelopeEip7702.d.ts.map +1 -0
- package/_types/core/{TransactionEnvelopeLegacy.d.ts → TxEnvelopeLegacy.d.ts} +54 -54
- package/_types/core/TxEnvelopeLegacy.d.ts.map +1 -0
- package/_types/core/WebAuthnP256.d.ts +1 -1
- package/_types/core/WebAuthnP256.d.ts.map +1 -1
- package/_types/erc8021/Attribution.d.ts +20 -6
- package/_types/erc8021/Attribution.d.ts.map +1 -1
- package/_types/index.d.ts +192 -192
- package/_types/index.d.ts.map +1 -1
- package/_types/index.docs.d.ts +1 -0
- package/_types/index.docs.d.ts.map +1 -1
- package/_types/tempo/AuthorizationTempo.d.ts +688 -0
- package/_types/tempo/AuthorizationTempo.d.ts.map +1 -0
- package/_types/tempo/KeyAuthorization.d.ts +437 -0
- package/_types/tempo/KeyAuthorization.d.ts.map +1 -0
- package/_types/tempo/PoolId.d.ts +33 -0
- package/_types/tempo/PoolId.d.ts.map +1 -0
- package/_types/tempo/SignatureEnvelope.d.ts +438 -0
- package/_types/tempo/SignatureEnvelope.d.ts.map +1 -0
- package/_types/tempo/Tick.d.ts +120 -0
- package/_types/tempo/Tick.d.ts.map +1 -0
- package/_types/tempo/TokenId.d.ts +55 -0
- package/_types/tempo/TokenId.d.ts.map +1 -0
- package/_types/tempo/TokenRole.d.ts +29 -0
- package/_types/tempo/TokenRole.d.ts.map +1 -0
- package/_types/tempo/Transaction.d.ts +208 -0
- package/_types/tempo/Transaction.d.ts.map +1 -0
- package/_types/tempo/TransactionReceipt.d.ts +165 -0
- package/_types/tempo/TransactionReceipt.d.ts.map +1 -0
- package/_types/tempo/TransactionRequest.d.ts +89 -0
- package/_types/tempo/TransactionRequest.d.ts.map +1 -0
- package/_types/tempo/TxEnvelopeTempo.d.ts +551 -0
- package/_types/tempo/TxEnvelopeTempo.d.ts.map +1 -0
- package/_types/tempo/index.d.ts +300 -0
- package/_types/tempo/index.d.ts.map +1 -0
- package/_types/version.d.ts +1 -1
- package/core/Blobs.ts +8 -8
- package/core/{TransactionEnvelope.ts → TxEnvelope.ts} +10 -10
- package/core/{TransactionEnvelopeEip1559.ts → TxEnvelopeEip1559.ts} +60 -69
- package/core/{TransactionEnvelopeEip2930.ts → TxEnvelopeEip2930.ts} +61 -72
- package/core/{TransactionEnvelopeEip4844.ts → TxEnvelopeEip4844.ts} +62 -71
- package/core/{TransactionEnvelopeEip7702.ts → TxEnvelopeEip7702.ts} +58 -67
- package/core/{TransactionEnvelopeLegacy.ts → TxEnvelopeLegacy.ts} +59 -68
- package/core/WebAuthnP256.ts +3 -1
- package/erc8021/Attribution.ts +77 -15
- package/index.docs.ts +1 -0
- package/index.ts +192 -195
- package/package.json +91 -31
- package/tempo/AuthorizationTempo/package.json +6 -0
- package/tempo/AuthorizationTempo.test.ts +1293 -0
- package/tempo/AuthorizationTempo.ts +884 -0
- package/tempo/KeyAuthorization/package.json +6 -0
- package/tempo/KeyAuthorization.test.ts +1373 -0
- package/tempo/KeyAuthorization.ts +622 -0
- package/tempo/PoolId/package.json +6 -0
- package/tempo/PoolId.test.ts +33 -0
- package/tempo/PoolId.ts +42 -0
- package/tempo/SignatureEnvelope/package.json +6 -0
- package/tempo/SignatureEnvelope.test.ts +1877 -0
- package/tempo/SignatureEnvelope.ts +973 -0
- package/tempo/Tick/package.json +6 -0
- package/tempo/Tick.test.ts +281 -0
- package/tempo/Tick.ts +186 -0
- package/tempo/TokenId/package.json +6 -0
- package/tempo/TokenId.test.ts +40 -0
- package/tempo/TokenId.ts +80 -0
- package/tempo/TokenRole/package.json +6 -0
- package/tempo/TokenRole.test.ts +16 -0
- package/tempo/TokenRole.ts +45 -0
- package/tempo/Transaction/package.json +6 -0
- package/tempo/Transaction.test.ts +523 -0
- package/tempo/Transaction.ts +339 -0
- package/tempo/TransactionReceipt/package.json +6 -0
- package/tempo/TransactionReceipt.ts +200 -0
- package/tempo/TransactionRequest/package.json +6 -0
- package/tempo/TransactionRequest.ts +160 -0
- package/tempo/TxEnvelopeTempo/package.json +6 -0
- package/tempo/TxEnvelopeTempo.test.ts +1371 -0
- package/tempo/TxEnvelopeTempo.ts +972 -0
- package/tempo/e2e.test.ts +1387 -0
- package/tempo/index.ts +308 -0
- package/tempo/package.json +6 -0
- package/version.ts +1 -1
- package/TransactionEnvelope/package.json +0 -6
- package/TransactionEnvelopeEip1559/package.json +0 -6
- package/TransactionEnvelopeEip2930/package.json +0 -6
- package/TransactionEnvelopeEip4844/package.json +0 -6
- package/TransactionEnvelopeEip7702/package.json +0 -6
- package/TransactionEnvelopeLegacy/package.json +0 -6
- package/_cjs/core/TransactionEnvelope.js.map +0 -1
- package/_cjs/core/TransactionEnvelopeEip1559.js.map +0 -1
- package/_cjs/core/TransactionEnvelopeEip2930.js.map +0 -1
- package/_cjs/core/TransactionEnvelopeEip4844.js.map +0 -1
- package/_cjs/core/TransactionEnvelopeEip7702.js.map +0 -1
- package/_cjs/core/TransactionEnvelopeLegacy.js.map +0 -1
- package/_esm/core/TransactionEnvelope.js.map +0 -1
- package/_esm/core/TransactionEnvelopeEip1559.js.map +0 -1
- package/_esm/core/TransactionEnvelopeEip2930.js.map +0 -1
- package/_esm/core/TransactionEnvelopeEip4844.js.map +0 -1
- package/_esm/core/TransactionEnvelopeEip7702.js.map +0 -1
- package/_esm/core/TransactionEnvelopeLegacy.js.map +0 -1
- package/_types/core/TransactionEnvelope.d.ts.map +0 -1
- package/_types/core/TransactionEnvelopeEip1559.d.ts.map +0 -1
- package/_types/core/TransactionEnvelopeEip2930.d.ts.map +0 -1
- package/_types/core/TransactionEnvelopeEip4844.d.ts.map +0 -1
- package/_types/core/TransactionEnvelopeEip7702.d.ts.map +0 -1
- package/_types/core/TransactionEnvelopeLegacy.d.ts.map +0 -1
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.from = from;
|
|
4
|
+
exports.fromRpc = fromRpc;
|
|
5
|
+
exports.fromTuple = fromTuple;
|
|
6
|
+
exports.getSignPayload = getSignPayload;
|
|
7
|
+
exports.hash = hash;
|
|
8
|
+
exports.toRpc = toRpc;
|
|
9
|
+
exports.toTuple = toTuple;
|
|
10
|
+
const Hash = require("../core/Hash.js");
|
|
11
|
+
const Hex = require("../core/Hex.js");
|
|
12
|
+
const Rlp = require("../core/Rlp.js");
|
|
13
|
+
const SignatureEnvelope = require("./SignatureEnvelope.js");
|
|
14
|
+
function from(authorization, options = {}) {
|
|
15
|
+
if (typeof authorization.expiry === 'string')
|
|
16
|
+
return fromRpc(authorization);
|
|
17
|
+
if (options.signature)
|
|
18
|
+
return {
|
|
19
|
+
...authorization,
|
|
20
|
+
signature: SignatureEnvelope.from(options.signature),
|
|
21
|
+
};
|
|
22
|
+
return authorization;
|
|
23
|
+
}
|
|
24
|
+
function fromRpc(authorization) {
|
|
25
|
+
const { chainId = '0x0', keyId, expiry = 0, limits, keyType } = authorization;
|
|
26
|
+
const signature = SignatureEnvelope.fromRpc(authorization.signature);
|
|
27
|
+
return {
|
|
28
|
+
address: keyId,
|
|
29
|
+
chainId: chainId === '0x' ? 0n : Hex.toBigInt(chainId),
|
|
30
|
+
expiry: Number(expiry),
|
|
31
|
+
limits: limits?.map((limit) => ({
|
|
32
|
+
token: limit.token,
|
|
33
|
+
limit: BigInt(limit.limit),
|
|
34
|
+
})),
|
|
35
|
+
signature,
|
|
36
|
+
type: keyType,
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
function fromTuple(tuple) {
|
|
40
|
+
const [authorization, signatureSerialized] = tuple;
|
|
41
|
+
const [chainId, keyType_hex, keyId, expiry, limits] = authorization;
|
|
42
|
+
const keyType = (() => {
|
|
43
|
+
switch (keyType_hex) {
|
|
44
|
+
case '0x':
|
|
45
|
+
case '0x00':
|
|
46
|
+
return 'secp256k1';
|
|
47
|
+
case '0x01':
|
|
48
|
+
return 'p256';
|
|
49
|
+
case '0x02':
|
|
50
|
+
return 'webAuthn';
|
|
51
|
+
default:
|
|
52
|
+
throw new Error(`Invalid key type: ${keyType_hex}`);
|
|
53
|
+
}
|
|
54
|
+
})();
|
|
55
|
+
const args = {
|
|
56
|
+
address: keyId,
|
|
57
|
+
expiry: typeof expiry !== 'undefined' ? Hex.toNumber(expiry) : undefined,
|
|
58
|
+
type: keyType,
|
|
59
|
+
...(chainId !== '0x' ? { chainId: Hex.toBigInt(chainId) } : {}),
|
|
60
|
+
...(typeof expiry !== 'undefined' ? { expiry: Hex.toNumber(expiry) } : {}),
|
|
61
|
+
...(typeof limits !== 'undefined'
|
|
62
|
+
? {
|
|
63
|
+
limits: limits.map(([token, limit]) => ({
|
|
64
|
+
token,
|
|
65
|
+
limit: BigInt(limit),
|
|
66
|
+
})),
|
|
67
|
+
}
|
|
68
|
+
: {}),
|
|
69
|
+
};
|
|
70
|
+
if (signatureSerialized)
|
|
71
|
+
args.signature = SignatureEnvelope.deserialize(signatureSerialized);
|
|
72
|
+
return from(args);
|
|
73
|
+
}
|
|
74
|
+
function getSignPayload(authorization) {
|
|
75
|
+
return hash(authorization);
|
|
76
|
+
}
|
|
77
|
+
function hash(authorization) {
|
|
78
|
+
const [authorizationTuple] = toTuple(authorization);
|
|
79
|
+
const serialized = Rlp.fromHex(authorizationTuple);
|
|
80
|
+
return Hash.keccak256(serialized);
|
|
81
|
+
}
|
|
82
|
+
function toRpc(authorization) {
|
|
83
|
+
const { address, chainId = 0n, expiry, limits, type, signature, } = authorization;
|
|
84
|
+
return {
|
|
85
|
+
chainId: chainId === 0n ? '0x' : Hex.fromNumber(chainId),
|
|
86
|
+
expiry: typeof expiry === 'number' ? Hex.fromNumber(expiry) : undefined,
|
|
87
|
+
limits: limits?.map(({ token, limit }) => ({
|
|
88
|
+
token,
|
|
89
|
+
limit: Hex.fromNumber(limit),
|
|
90
|
+
})),
|
|
91
|
+
keyId: address,
|
|
92
|
+
signature: SignatureEnvelope.toRpc(signature),
|
|
93
|
+
keyType: type,
|
|
94
|
+
};
|
|
95
|
+
}
|
|
96
|
+
function toTuple(authorization) {
|
|
97
|
+
const { address, chainId = 0n, expiry, limits } = authorization;
|
|
98
|
+
const signature = authorization.signature
|
|
99
|
+
? SignatureEnvelope.serialize(authorization.signature)
|
|
100
|
+
: undefined;
|
|
101
|
+
const type = (() => {
|
|
102
|
+
switch (authorization.type) {
|
|
103
|
+
case 'secp256k1':
|
|
104
|
+
return '0x';
|
|
105
|
+
case 'p256':
|
|
106
|
+
return '0x01';
|
|
107
|
+
case 'webAuthn':
|
|
108
|
+
return '0x02';
|
|
109
|
+
default:
|
|
110
|
+
throw new Error(`Invalid key type: ${authorization.type}`);
|
|
111
|
+
}
|
|
112
|
+
})();
|
|
113
|
+
const authorizationTuple = [
|
|
114
|
+
chainId === 0n ? '0x' : Hex.fromNumber(chainId),
|
|
115
|
+
type,
|
|
116
|
+
address,
|
|
117
|
+
typeof expiry === 'number' ? Hex.fromNumber(expiry) : undefined,
|
|
118
|
+
limits?.map((limit) => [limit.token, Hex.fromNumber(limit.limit)]) ??
|
|
119
|
+
undefined,
|
|
120
|
+
].filter(Boolean);
|
|
121
|
+
return [authorizationTuple, ...(signature ? [signature] : [])];
|
|
122
|
+
}
|
|
123
|
+
//# sourceMappingURL=KeyAuthorization.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"KeyAuthorization.js","sourceRoot":"","sources":["../../tempo/KeyAuthorization.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.from = from;
|
|
4
|
+
const Hash = require("../core/Hash.js");
|
|
5
|
+
const Hex = require("../core/Hex.js");
|
|
6
|
+
const TokenId = require("./TokenId.js");
|
|
7
|
+
function from(value) {
|
|
8
|
+
return Hash.keccak256(Hex.concat(Hex.padLeft(TokenId.toAddress(value.userToken), 32), Hex.padLeft(TokenId.toAddress(value.validatorToken), 32)));
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=PoolId.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PoolId.js","sourceRoot":"","sources":["../../tempo/PoolId.ts"],"names":[],"mappings":";;AAyBA,oBAOC;AAhCD,wCAAuC;AACvC,sCAAqC;AACrC,wCAAuC;AAuBvC,SAAgB,IAAI,CAAC,KAAiB;IACpC,OAAO,IAAI,CAAC,SAAS,CACnB,GAAG,CAAC,MAAM,CACR,GAAG,CAAC,OAAO,CAAC,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,SAAS,CAAC,EAAE,EAAE,CAAC,EACnD,GAAG,CAAC,OAAO,CAAC,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,cAAc,CAAC,EAAE,EAAE,CAAC,CACzD,CACF,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,394 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.InvalidSerializedError = exports.MissingPropertiesError = exports.CoercionError = exports.types = void 0;
|
|
4
|
+
exports.assert = assert;
|
|
5
|
+
exports.deserialize = deserialize;
|
|
6
|
+
exports.from = from;
|
|
7
|
+
exports.fromRpc = fromRpc;
|
|
8
|
+
exports.getType = getType;
|
|
9
|
+
exports.serialize = serialize;
|
|
10
|
+
exports.toRpc = toRpc;
|
|
11
|
+
exports.validate = validate;
|
|
12
|
+
const Errors = require("../core/Errors.js");
|
|
13
|
+
const Hex = require("../core/Hex.js");
|
|
14
|
+
const Json = require("../core/Json.js");
|
|
15
|
+
const Signature = require("../core/Signature.js");
|
|
16
|
+
const serializedP256Type = '0x01';
|
|
17
|
+
const serializedWebAuthnType = '0x02';
|
|
18
|
+
const serializedKeychainType = '0x03';
|
|
19
|
+
exports.types = ['secp256k1', 'p256', 'webAuthn'];
|
|
20
|
+
function assert(envelope) {
|
|
21
|
+
const type = getType(envelope);
|
|
22
|
+
if (type === 'secp256k1') {
|
|
23
|
+
const secp256k1 = envelope;
|
|
24
|
+
Signature.assert(secp256k1.signature);
|
|
25
|
+
return;
|
|
26
|
+
}
|
|
27
|
+
if (type === 'p256') {
|
|
28
|
+
const p256 = envelope;
|
|
29
|
+
const missing = [];
|
|
30
|
+
if (typeof p256.signature?.r !== 'bigint')
|
|
31
|
+
missing.push('signature.r');
|
|
32
|
+
if (typeof p256.signature?.s !== 'bigint')
|
|
33
|
+
missing.push('signature.s');
|
|
34
|
+
if (typeof p256.prehash !== 'boolean')
|
|
35
|
+
missing.push('prehash');
|
|
36
|
+
if (!p256.publicKey)
|
|
37
|
+
missing.push('publicKey');
|
|
38
|
+
else {
|
|
39
|
+
if (typeof p256.publicKey.x !== 'bigint')
|
|
40
|
+
missing.push('publicKey.x');
|
|
41
|
+
if (typeof p256.publicKey.y !== 'bigint')
|
|
42
|
+
missing.push('publicKey.y');
|
|
43
|
+
}
|
|
44
|
+
if (missing.length > 0)
|
|
45
|
+
throw new MissingPropertiesError({ envelope, missing, type: 'p256' });
|
|
46
|
+
return;
|
|
47
|
+
}
|
|
48
|
+
if (type === 'webAuthn') {
|
|
49
|
+
const webauthn = envelope;
|
|
50
|
+
const missing = [];
|
|
51
|
+
if (typeof webauthn.signature?.r !== 'bigint')
|
|
52
|
+
missing.push('signature.r');
|
|
53
|
+
if (typeof webauthn.signature?.s !== 'bigint')
|
|
54
|
+
missing.push('signature.s');
|
|
55
|
+
if (!webauthn.metadata)
|
|
56
|
+
missing.push('metadata');
|
|
57
|
+
else {
|
|
58
|
+
if (!webauthn.metadata.authenticatorData)
|
|
59
|
+
missing.push('metadata.authenticatorData');
|
|
60
|
+
if (!webauthn.metadata.clientDataJSON)
|
|
61
|
+
missing.push('metadata.clientDataJSON');
|
|
62
|
+
}
|
|
63
|
+
if (!webauthn.publicKey)
|
|
64
|
+
missing.push('publicKey');
|
|
65
|
+
else {
|
|
66
|
+
if (typeof webauthn.publicKey.x !== 'bigint')
|
|
67
|
+
missing.push('publicKey.x');
|
|
68
|
+
if (typeof webauthn.publicKey.y !== 'bigint')
|
|
69
|
+
missing.push('publicKey.y');
|
|
70
|
+
}
|
|
71
|
+
if (missing.length > 0)
|
|
72
|
+
throw new MissingPropertiesError({ envelope, missing, type: 'webAuthn' });
|
|
73
|
+
return;
|
|
74
|
+
}
|
|
75
|
+
if (type === 'keychain') {
|
|
76
|
+
const keychain = envelope;
|
|
77
|
+
assert(keychain.inner);
|
|
78
|
+
return;
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
function deserialize(serialized) {
|
|
82
|
+
const size = Hex.size(serialized);
|
|
83
|
+
if (size === 65) {
|
|
84
|
+
const signature = Signature.fromHex(serialized);
|
|
85
|
+
Signature.assert(signature);
|
|
86
|
+
return { signature, type: 'secp256k1' };
|
|
87
|
+
}
|
|
88
|
+
const typeId = Hex.slice(serialized, 0, 1);
|
|
89
|
+
const data = Hex.slice(serialized, 1);
|
|
90
|
+
const dataSize = Hex.size(data);
|
|
91
|
+
if (typeId === serializedP256Type) {
|
|
92
|
+
if (dataSize !== 129)
|
|
93
|
+
throw new InvalidSerializedError({
|
|
94
|
+
reason: `Invalid P256 signature envelope size: expected 129 bytes, got ${dataSize} bytes`,
|
|
95
|
+
serialized,
|
|
96
|
+
});
|
|
97
|
+
return {
|
|
98
|
+
publicKey: {
|
|
99
|
+
prefix: 4,
|
|
100
|
+
x: Hex.toBigInt(Hex.slice(data, 64, 96)),
|
|
101
|
+
y: Hex.toBigInt(Hex.slice(data, 96, 128)),
|
|
102
|
+
},
|
|
103
|
+
prehash: Hex.toNumber(Hex.slice(data, 128, 129)) !== 0,
|
|
104
|
+
signature: {
|
|
105
|
+
r: Hex.toBigInt(Hex.slice(data, 0, 32)),
|
|
106
|
+
s: Hex.toBigInt(Hex.slice(data, 32, 64)),
|
|
107
|
+
},
|
|
108
|
+
type: 'p256',
|
|
109
|
+
};
|
|
110
|
+
}
|
|
111
|
+
if (typeId === serializedWebAuthnType) {
|
|
112
|
+
if (dataSize < 128)
|
|
113
|
+
throw new InvalidSerializedError({
|
|
114
|
+
reason: `Invalid WebAuthn signature envelope size: expected at least 128 bytes, got ${dataSize} bytes`,
|
|
115
|
+
serialized,
|
|
116
|
+
});
|
|
117
|
+
const webauthnDataSize = dataSize - 128;
|
|
118
|
+
const webauthnData = Hex.slice(data, 0, webauthnDataSize);
|
|
119
|
+
let authenticatorData;
|
|
120
|
+
let clientDataJSON;
|
|
121
|
+
for (let split = 37; split < webauthnDataSize; split++) {
|
|
122
|
+
const potentialJson = Hex.toString(Hex.slice(webauthnData, split));
|
|
123
|
+
if (potentialJson.startsWith('{') && potentialJson.endsWith('}')) {
|
|
124
|
+
try {
|
|
125
|
+
JSON.parse(potentialJson);
|
|
126
|
+
authenticatorData = Hex.slice(webauthnData, 0, split);
|
|
127
|
+
clientDataJSON = potentialJson;
|
|
128
|
+
break;
|
|
129
|
+
}
|
|
130
|
+
catch { }
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
if (!authenticatorData || !clientDataJSON)
|
|
134
|
+
throw new InvalidSerializedError({
|
|
135
|
+
reason: 'Unable to parse WebAuthn metadata: could not extract valid authenticatorData and clientDataJSON',
|
|
136
|
+
serialized,
|
|
137
|
+
});
|
|
138
|
+
return {
|
|
139
|
+
publicKey: {
|
|
140
|
+
prefix: 4,
|
|
141
|
+
x: Hex.toBigInt(Hex.slice(data, webauthnDataSize + 64, webauthnDataSize + 96)),
|
|
142
|
+
y: Hex.toBigInt(Hex.slice(data, webauthnDataSize + 96, webauthnDataSize + 128)),
|
|
143
|
+
},
|
|
144
|
+
metadata: {
|
|
145
|
+
authenticatorData,
|
|
146
|
+
clientDataJSON,
|
|
147
|
+
},
|
|
148
|
+
signature: {
|
|
149
|
+
r: Hex.toBigInt(Hex.slice(data, webauthnDataSize, webauthnDataSize + 32)),
|
|
150
|
+
s: Hex.toBigInt(Hex.slice(data, webauthnDataSize + 32, webauthnDataSize + 64)),
|
|
151
|
+
},
|
|
152
|
+
type: 'webAuthn',
|
|
153
|
+
};
|
|
154
|
+
}
|
|
155
|
+
if (typeId === serializedKeychainType) {
|
|
156
|
+
const userAddress = Hex.slice(data, 0, 20);
|
|
157
|
+
const inner = deserialize(Hex.slice(data, 20));
|
|
158
|
+
return {
|
|
159
|
+
userAddress,
|
|
160
|
+
inner,
|
|
161
|
+
type: 'keychain',
|
|
162
|
+
};
|
|
163
|
+
}
|
|
164
|
+
throw new InvalidSerializedError({
|
|
165
|
+
reason: `Unknown signature type identifier: ${typeId}. Expected ${serializedP256Type} (P256) or ${serializedWebAuthnType} (WebAuthn)`,
|
|
166
|
+
serialized,
|
|
167
|
+
});
|
|
168
|
+
}
|
|
169
|
+
function from(value) {
|
|
170
|
+
if (typeof value === 'string')
|
|
171
|
+
return deserialize(value);
|
|
172
|
+
if (typeof value === 'object' &&
|
|
173
|
+
value !== null &&
|
|
174
|
+
'r' in value &&
|
|
175
|
+
's' in value &&
|
|
176
|
+
'yParity' in value)
|
|
177
|
+
return { signature: value, type: 'secp256k1' };
|
|
178
|
+
const type = getType(value);
|
|
179
|
+
return {
|
|
180
|
+
...value,
|
|
181
|
+
...(type === 'p256' ? { prehash: value.prehash } : {}),
|
|
182
|
+
type,
|
|
183
|
+
};
|
|
184
|
+
}
|
|
185
|
+
function fromRpc(envelope) {
|
|
186
|
+
if (envelope.type === 'secp256k1')
|
|
187
|
+
return {
|
|
188
|
+
signature: Signature.fromRpc(envelope),
|
|
189
|
+
type: 'secp256k1',
|
|
190
|
+
};
|
|
191
|
+
if (envelope.type === 'p256') {
|
|
192
|
+
return {
|
|
193
|
+
prehash: envelope.prehash,
|
|
194
|
+
publicKey: {
|
|
195
|
+
prefix: 4,
|
|
196
|
+
x: Hex.toBigInt(envelope.pubKeyX),
|
|
197
|
+
y: Hex.toBigInt(envelope.pubKeyY),
|
|
198
|
+
},
|
|
199
|
+
signature: {
|
|
200
|
+
r: Hex.toBigInt(envelope.r),
|
|
201
|
+
s: Hex.toBigInt(envelope.s),
|
|
202
|
+
},
|
|
203
|
+
type: 'p256',
|
|
204
|
+
};
|
|
205
|
+
}
|
|
206
|
+
if (envelope.type === 'webAuthn') {
|
|
207
|
+
const webauthnData = envelope.webauthnData;
|
|
208
|
+
const webauthnDataSize = Hex.size(webauthnData);
|
|
209
|
+
let authenticatorData;
|
|
210
|
+
let clientDataJSON;
|
|
211
|
+
for (let split = 37; split < webauthnDataSize; split++) {
|
|
212
|
+
const potentialJson = Hex.toString(Hex.slice(webauthnData, split));
|
|
213
|
+
if (potentialJson.startsWith('{') && potentialJson.endsWith('}')) {
|
|
214
|
+
try {
|
|
215
|
+
JSON.parse(potentialJson);
|
|
216
|
+
authenticatorData = Hex.slice(webauthnData, 0, split);
|
|
217
|
+
clientDataJSON = potentialJson;
|
|
218
|
+
break;
|
|
219
|
+
}
|
|
220
|
+
catch { }
|
|
221
|
+
}
|
|
222
|
+
}
|
|
223
|
+
if (!authenticatorData || !clientDataJSON)
|
|
224
|
+
throw new InvalidSerializedError({
|
|
225
|
+
reason: 'Unable to parse WebAuthn metadata: could not extract valid authenticatorData and clientDataJSON',
|
|
226
|
+
serialized: webauthnData,
|
|
227
|
+
});
|
|
228
|
+
return {
|
|
229
|
+
metadata: {
|
|
230
|
+
authenticatorData,
|
|
231
|
+
clientDataJSON,
|
|
232
|
+
},
|
|
233
|
+
publicKey: {
|
|
234
|
+
prefix: 4,
|
|
235
|
+
x: Hex.toBigInt(envelope.pubKeyX),
|
|
236
|
+
y: Hex.toBigInt(envelope.pubKeyY),
|
|
237
|
+
},
|
|
238
|
+
signature: {
|
|
239
|
+
r: Hex.toBigInt(envelope.r),
|
|
240
|
+
s: Hex.toBigInt(envelope.s),
|
|
241
|
+
},
|
|
242
|
+
type: 'webAuthn',
|
|
243
|
+
};
|
|
244
|
+
}
|
|
245
|
+
if (envelope.type === 'keychain' ||
|
|
246
|
+
('userAddress' in envelope && 'signature' in envelope))
|
|
247
|
+
return {
|
|
248
|
+
type: 'keychain',
|
|
249
|
+
userAddress: envelope.userAddress,
|
|
250
|
+
inner: fromRpc(envelope.signature),
|
|
251
|
+
};
|
|
252
|
+
throw new CoercionError({ envelope });
|
|
253
|
+
}
|
|
254
|
+
function getType(envelope) {
|
|
255
|
+
if (typeof envelope !== 'object' || envelope === null)
|
|
256
|
+
throw new CoercionError({ envelope });
|
|
257
|
+
if ('type' in envelope && envelope.type)
|
|
258
|
+
return envelope.type;
|
|
259
|
+
if ('signature' in envelope &&
|
|
260
|
+
!('publicKey' in envelope) &&
|
|
261
|
+
typeof envelope.signature === 'object' &&
|
|
262
|
+
envelope.signature !== null &&
|
|
263
|
+
'r' in envelope.signature &&
|
|
264
|
+
's' in envelope.signature &&
|
|
265
|
+
'yParity' in envelope.signature)
|
|
266
|
+
return 'secp256k1';
|
|
267
|
+
if ('r' in envelope && 's' in envelope && 'yParity' in envelope)
|
|
268
|
+
return 'secp256k1';
|
|
269
|
+
if ('signature' in envelope &&
|
|
270
|
+
'prehash' in envelope &&
|
|
271
|
+
'publicKey' in envelope &&
|
|
272
|
+
typeof envelope.prehash === 'boolean')
|
|
273
|
+
return 'p256';
|
|
274
|
+
if ('signature' in envelope &&
|
|
275
|
+
'metadata' in envelope &&
|
|
276
|
+
'publicKey' in envelope)
|
|
277
|
+
return 'webAuthn';
|
|
278
|
+
if ('userAddress' in envelope && 'inner' in envelope)
|
|
279
|
+
return 'keychain';
|
|
280
|
+
throw new CoercionError({
|
|
281
|
+
envelope,
|
|
282
|
+
});
|
|
283
|
+
}
|
|
284
|
+
function serialize(envelope) {
|
|
285
|
+
const type = getType(envelope);
|
|
286
|
+
if (type === 'secp256k1') {
|
|
287
|
+
const secp256k1 = envelope;
|
|
288
|
+
return Signature.toHex(secp256k1.signature);
|
|
289
|
+
}
|
|
290
|
+
if (type === 'p256') {
|
|
291
|
+
const p256 = envelope;
|
|
292
|
+
return Hex.concat(serializedP256Type, Hex.fromNumber(p256.signature.r, { size: 32 }), Hex.fromNumber(p256.signature.s, { size: 32 }), Hex.fromNumber(p256.publicKey.x, { size: 32 }), Hex.fromNumber(p256.publicKey.y, { size: 32 }), Hex.fromNumber(p256.prehash ? 1 : 0, { size: 1 }));
|
|
293
|
+
}
|
|
294
|
+
if (type === 'webAuthn') {
|
|
295
|
+
const webauthn = envelope;
|
|
296
|
+
const webauthnData = Hex.concat(webauthn.metadata.authenticatorData, Hex.fromString(webauthn.metadata.clientDataJSON));
|
|
297
|
+
return Hex.concat(serializedWebAuthnType, webauthnData, Hex.fromNumber(webauthn.signature.r, { size: 32 }), Hex.fromNumber(webauthn.signature.s, { size: 32 }), Hex.fromNumber(webauthn.publicKey.x, { size: 32 }), Hex.fromNumber(webauthn.publicKey.y, { size: 32 }));
|
|
298
|
+
}
|
|
299
|
+
if (type === 'keychain') {
|
|
300
|
+
const keychain = envelope;
|
|
301
|
+
return Hex.concat(serializedKeychainType, keychain.userAddress, serialize(keychain.inner));
|
|
302
|
+
}
|
|
303
|
+
throw new CoercionError({ envelope });
|
|
304
|
+
}
|
|
305
|
+
function toRpc(envelope) {
|
|
306
|
+
const type = getType(envelope);
|
|
307
|
+
if (type === 'secp256k1') {
|
|
308
|
+
const secp256k1 = envelope;
|
|
309
|
+
return {
|
|
310
|
+
...Signature.toRpc(secp256k1.signature),
|
|
311
|
+
type: 'secp256k1',
|
|
312
|
+
};
|
|
313
|
+
}
|
|
314
|
+
if (type === 'p256') {
|
|
315
|
+
const p256 = envelope;
|
|
316
|
+
return {
|
|
317
|
+
prehash: p256.prehash,
|
|
318
|
+
pubKeyX: Hex.fromNumber(p256.publicKey.x, { size: 32 }),
|
|
319
|
+
pubKeyY: Hex.fromNumber(p256.publicKey.y, { size: 32 }),
|
|
320
|
+
r: Hex.fromNumber(p256.signature.r, { size: 32 }),
|
|
321
|
+
s: Hex.fromNumber(p256.signature.s, { size: 32 }),
|
|
322
|
+
type: 'p256',
|
|
323
|
+
};
|
|
324
|
+
}
|
|
325
|
+
if (type === 'webAuthn') {
|
|
326
|
+
const webauthn = envelope;
|
|
327
|
+
const webauthnData = Hex.concat(webauthn.metadata.authenticatorData, Hex.fromString(webauthn.metadata.clientDataJSON));
|
|
328
|
+
return {
|
|
329
|
+
pubKeyX: Hex.fromNumber(webauthn.publicKey.x, { size: 32 }),
|
|
330
|
+
pubKeyY: Hex.fromNumber(webauthn.publicKey.y, { size: 32 }),
|
|
331
|
+
r: Hex.fromNumber(webauthn.signature.r, { size: 32 }),
|
|
332
|
+
s: Hex.fromNumber(webauthn.signature.s, { size: 32 }),
|
|
333
|
+
type: 'webAuthn',
|
|
334
|
+
webauthnData,
|
|
335
|
+
};
|
|
336
|
+
}
|
|
337
|
+
if (type === 'keychain') {
|
|
338
|
+
const keychain = envelope;
|
|
339
|
+
return {
|
|
340
|
+
type: 'keychain',
|
|
341
|
+
userAddress: keychain.userAddress,
|
|
342
|
+
signature: toRpc(keychain.inner),
|
|
343
|
+
};
|
|
344
|
+
}
|
|
345
|
+
throw new CoercionError({ envelope });
|
|
346
|
+
}
|
|
347
|
+
function validate(envelope) {
|
|
348
|
+
try {
|
|
349
|
+
assert(envelope);
|
|
350
|
+
return true;
|
|
351
|
+
}
|
|
352
|
+
catch {
|
|
353
|
+
return false;
|
|
354
|
+
}
|
|
355
|
+
}
|
|
356
|
+
class CoercionError extends Errors.BaseError {
|
|
357
|
+
constructor({ envelope }) {
|
|
358
|
+
super(`Unable to coerce value (\`${Json.stringify(envelope)}\`) to a valid signature envelope.`);
|
|
359
|
+
Object.defineProperty(this, "name", {
|
|
360
|
+
enumerable: true,
|
|
361
|
+
configurable: true,
|
|
362
|
+
writable: true,
|
|
363
|
+
value: 'SignatureEnvelope.CoercionError'
|
|
364
|
+
});
|
|
365
|
+
}
|
|
366
|
+
}
|
|
367
|
+
exports.CoercionError = CoercionError;
|
|
368
|
+
class MissingPropertiesError extends Errors.BaseError {
|
|
369
|
+
constructor({ envelope, missing, type, }) {
|
|
370
|
+
super(`Signature envelope of type "${type}" is missing required properties: ${missing.map((m) => `\`${m}\``).join(', ')}.\n\nProvided: ${Json.stringify(envelope)}`);
|
|
371
|
+
Object.defineProperty(this, "name", {
|
|
372
|
+
enumerable: true,
|
|
373
|
+
configurable: true,
|
|
374
|
+
writable: true,
|
|
375
|
+
value: 'SignatureEnvelope.MissingPropertiesError'
|
|
376
|
+
});
|
|
377
|
+
}
|
|
378
|
+
}
|
|
379
|
+
exports.MissingPropertiesError = MissingPropertiesError;
|
|
380
|
+
class InvalidSerializedError extends Errors.BaseError {
|
|
381
|
+
constructor({ reason, serialized, }) {
|
|
382
|
+
super(`Unable to deserialize signature envelope: ${reason}`, {
|
|
383
|
+
metaMessages: [`Serialized: ${serialized}`],
|
|
384
|
+
});
|
|
385
|
+
Object.defineProperty(this, "name", {
|
|
386
|
+
enumerable: true,
|
|
387
|
+
configurable: true,
|
|
388
|
+
writable: true,
|
|
389
|
+
value: 'SignatureEnvelope.InvalidSerializedError'
|
|
390
|
+
});
|
|
391
|
+
}
|
|
392
|
+
}
|
|
393
|
+
exports.InvalidSerializedError = InvalidSerializedError;
|
|
394
|
+
//# sourceMappingURL=SignatureEnvelope.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SignatureEnvelope.js","sourceRoot":"","sources":["../../tempo/SignatureEnvelope.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.PriceOutOfBoundsError = exports.InvalidPriceFormatError = exports.TickOutOfBoundsError = exports.priceScale = exports.maxTick = exports.minTick = void 0;
|
|
4
|
+
exports.toPrice = toPrice;
|
|
5
|
+
exports.fromPrice = fromPrice;
|
|
6
|
+
const Errors = require("../core/Errors.js");
|
|
7
|
+
exports.minTick = -2000;
|
|
8
|
+
exports.maxTick = 2000;
|
|
9
|
+
exports.priceScale = 100_000;
|
|
10
|
+
function toPrice(tick) {
|
|
11
|
+
if (tick < exports.minTick || tick > exports.maxTick) {
|
|
12
|
+
throw new TickOutOfBoundsError({ tick });
|
|
13
|
+
}
|
|
14
|
+
const price = exports.priceScale + tick;
|
|
15
|
+
const whole = Math.floor(price / exports.priceScale);
|
|
16
|
+
let decimal = (price % exports.priceScale).toString().padStart(5, '0');
|
|
17
|
+
decimal = decimal.replace(/0+$/, '');
|
|
18
|
+
if (decimal.length === 0)
|
|
19
|
+
return whole.toString();
|
|
20
|
+
return `${whole}.${decimal}`;
|
|
21
|
+
}
|
|
22
|
+
function fromPrice(price) {
|
|
23
|
+
const priceStr = price.trim();
|
|
24
|
+
if (!/^-?\d+(\.\d+)?$/.test(priceStr))
|
|
25
|
+
throw new InvalidPriceFormatError({ price });
|
|
26
|
+
const [w, d = '0'] = priceStr.split('.');
|
|
27
|
+
const whole = BigInt(w);
|
|
28
|
+
const decimal = BigInt(d.padEnd(5, '0').slice(0, 5));
|
|
29
|
+
const priceInt = whole * BigInt(exports.priceScale) + decimal;
|
|
30
|
+
const tick = Number(priceInt - BigInt(exports.priceScale));
|
|
31
|
+
if (tick < exports.minTick || tick > exports.maxTick)
|
|
32
|
+
throw new PriceOutOfBoundsError({ price, tick });
|
|
33
|
+
return tick;
|
|
34
|
+
}
|
|
35
|
+
class TickOutOfBoundsError extends Errors.BaseError {
|
|
36
|
+
constructor(options) {
|
|
37
|
+
super(`Tick ${options.tick} is out of bounds.`, {
|
|
38
|
+
metaMessages: [`Tick must be between ${exports.minTick} and ${exports.maxTick}.`],
|
|
39
|
+
});
|
|
40
|
+
Object.defineProperty(this, "name", {
|
|
41
|
+
enumerable: true,
|
|
42
|
+
configurable: true,
|
|
43
|
+
writable: true,
|
|
44
|
+
value: 'Tick.TickOutOfBoundsError'
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
exports.TickOutOfBoundsError = TickOutOfBoundsError;
|
|
49
|
+
class InvalidPriceFormatError extends Errors.BaseError {
|
|
50
|
+
constructor(options) {
|
|
51
|
+
super(`Invalid price format: "${options.price}".`, {
|
|
52
|
+
metaMessages: ['Price must be a decimal number string (e.g., "1.001").'],
|
|
53
|
+
});
|
|
54
|
+
Object.defineProperty(this, "name", {
|
|
55
|
+
enumerable: true,
|
|
56
|
+
configurable: true,
|
|
57
|
+
writable: true,
|
|
58
|
+
value: 'Tick.InvalidPriceFormatError'
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
exports.InvalidPriceFormatError = InvalidPriceFormatError;
|
|
63
|
+
class PriceOutOfBoundsError extends Errors.BaseError {
|
|
64
|
+
constructor(options) {
|
|
65
|
+
super(`Price "${options.price}" results in tick ${options.tick} which is out of bounds.`, {
|
|
66
|
+
metaMessages: [`Tick must be between ${exports.minTick} and ${exports.maxTick}.`],
|
|
67
|
+
});
|
|
68
|
+
Object.defineProperty(this, "name", {
|
|
69
|
+
enumerable: true,
|
|
70
|
+
configurable: true,
|
|
71
|
+
writable: true,
|
|
72
|
+
value: 'Tick.PriceOutOfBoundsError'
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
exports.PriceOutOfBoundsError = PriceOutOfBoundsError;
|
|
77
|
+
//# sourceMappingURL=Tick.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Tick.js","sourceRoot":"","sources":["../../tempo/Tick.ts"],"names":[],"mappings":"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"}
|