@0xsequence/wallet-primitives 0.0.0-20250520201059
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/.turbo/turbo-build.log +5 -0
- package/CHANGELOG.md +7 -0
- package/LICENSE +202 -0
- package/dist/address.d.ts +5 -0
- package/dist/address.d.ts.map +1 -0
- package/dist/address.js +7 -0
- package/dist/address.js.map +1 -0
- package/dist/attestation.d.ts +24 -0
- package/dist/attestation.d.ts.map +1 -0
- package/dist/attestation.js +77 -0
- package/dist/attestation.js.map +1 -0
- package/dist/config.d.ts +85 -0
- package/dist/config.d.ts.map +1 -0
- package/dist/config.js +381 -0
- package/dist/config.js.map +1 -0
- package/dist/constants.d.ts +173 -0
- package/dist/constants.d.ts.map +1 -0
- package/dist/constants.js +31 -0
- package/dist/constants.js.map +1 -0
- package/dist/context.d.ts +9 -0
- package/dist/context.d.ts.map +1 -0
- package/dist/context.js +8 -0
- package/dist/context.js.map +1 -0
- package/dist/erc-6492.d.ts +19 -0
- package/dist/erc-6492.d.ts.map +1 -0
- package/dist/erc-6492.js +64 -0
- package/dist/erc-6492.js.map +1 -0
- package/dist/extensions/index.d.ts +9 -0
- package/dist/extensions/index.d.ts.map +1 -0
- package/dist/extensions/index.js +7 -0
- package/dist/extensions/index.js.map +1 -0
- package/dist/extensions/passkeys.d.ts +31 -0
- package/dist/extensions/passkeys.d.ts.map +1 -0
- package/dist/extensions/passkeys.js +224 -0
- package/dist/extensions/passkeys.js.map +1 -0
- package/dist/extensions/recovery.d.ts +310 -0
- package/dist/extensions/recovery.d.ts.map +1 -0
- package/dist/extensions/recovery.js +444 -0
- package/dist/extensions/recovery.js.map +1 -0
- package/dist/generic-tree.d.ts +14 -0
- package/dist/generic-tree.d.ts.map +1 -0
- package/dist/generic-tree.js +34 -0
- package/dist/generic-tree.js.map +1 -0
- package/dist/index.d.ts +16 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +16 -0
- package/dist/index.js.map +1 -0
- package/dist/network.d.ts +15 -0
- package/dist/network.d.ts.map +1 -0
- package/dist/network.js +24 -0
- package/dist/network.js.map +1 -0
- package/dist/payload.d.ts +108 -0
- package/dist/payload.d.ts.map +1 -0
- package/dist/payload.js +627 -0
- package/dist/payload.js.map +1 -0
- package/dist/permission.d.ts +73 -0
- package/dist/permission.d.ts.map +1 -0
- package/dist/permission.js +188 -0
- package/dist/permission.js.map +1 -0
- package/dist/session-config.d.ts +113 -0
- package/dist/session-config.d.ts.map +1 -0
- package/dist/session-config.js +554 -0
- package/dist/session-config.js.map +1 -0
- package/dist/session-signature.d.ts +24 -0
- package/dist/session-signature.d.ts.map +1 -0
- package/dist/session-signature.js +141 -0
- package/dist/session-signature.js.map +1 -0
- package/dist/signature.d.ts +108 -0
- package/dist/signature.d.ts.map +1 -0
- package/dist/signature.js +1079 -0
- package/dist/signature.js.map +1 -0
- package/dist/utils.d.ts +45 -0
- package/dist/utils.d.ts.map +1 -0
- package/dist/utils.js +100 -0
- package/dist/utils.js.map +1 -0
- package/eslint.config.mjs +4 -0
- package/package.json +27 -0
- package/src/address.ts +19 -0
- package/src/attestation.ts +114 -0
- package/src/config.ts +521 -0
- package/src/constants.ts +39 -0
- package/src/context.ts +16 -0
- package/src/erc-6492.ts +97 -0
- package/src/extensions/index.ts +14 -0
- package/src/extensions/passkeys.ts +283 -0
- package/src/extensions/recovery.ts +542 -0
- package/src/generic-tree.ts +55 -0
- package/src/index.ts +15 -0
- package/src/network.ts +37 -0
- package/src/payload.ts +825 -0
- package/src/permission.ts +252 -0
- package/src/session-config.ts +681 -0
- package/src/session-signature.ts +197 -0
- package/src/signature.ts +1398 -0
- package/src/utils.ts +114 -0
- package/tsconfig.json +10 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"erc-6492.d.ts","sourceRoot":"","sources":["../src/erc-6492.ts"],"names":[],"mappings":"AAAA,OAAO,EAA8B,OAAO,EAAE,KAAK,EAAE,GAAG,EAAE,QAAQ,EAAE,MAAM,IAAI,CAAA;AAG9E,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAA;AAKtC,wBAAgB,MAAM,CAAC,CAAC,SAAS,KAAK,CAAC,KAAK,GAAG,GAAG,CAAC,GAAG,EACpD,UAAU,EAAE,CAAC,EACb,OAAO,EAAE,OAAO,GACf;IAAE,EAAE,EAAE,OAAO,CAAC,OAAO,CAAC;IAAC,IAAI,EAAE,CAAC,CAAA;CAAE,CASlC;AAED,wBAAgB,IAAI,CAAC,CAAC,SAAS,KAAK,CAAC,KAAK,GAAG,GAAG,CAAC,GAAG,EAClD,SAAS,EAAE,CAAC,EACZ,EAAE,EAAE,EAAE,IAAI,EAAE,EAAE;IAAE,EAAE,EAAE,OAAO,CAAC,OAAO,CAAC;IAAC,IAAI,EAAE,KAAK,CAAC,KAAK,GAAG,GAAG,CAAC,GAAG,CAAA;CAAE,GACjE,CAAC,CAeH;AAED,wBAAgB,MAAM,CAAC,CAAC,SAAS,KAAK,CAAC,KAAK,GAAG,GAAG,CAAC,GAAG,EACpD,SAAS,EAAE,CAAC,GACX;IAAE,SAAS,EAAE,CAAC,CAAC;IAAC,OAAO,CAAC,EAAE;QAAE,EAAE,EAAE,OAAO,CAAC,OAAO,CAAC;QAAC,IAAI,EAAE,CAAC,CAAA;KAAE,CAAA;CAAE,CA+B9D;AAED,wBAAgB,OAAO,CACrB,OAAO,EAAE,OAAO,CAAC,OAAO,EACxB,WAAW,EAAE,KAAK,CAAC,KAAK,GAAG,GAAG,CAAC,GAAG,EAClC,gBAAgB,EAAE,KAAK,CAAC,KAAK,GAAG,GAAG,CAAC,GAAG,EACvC,QAAQ,EAAE,QAAQ,CAAC,QAAQ,GAC1B,OAAO,CAAC,OAAO,CAAC,CAclB"}
|
package/dist/erc-6492.js
ADDED
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import { AbiFunction, AbiParameters, Bytes, Hex } from 'ox';
|
|
2
|
+
import { WrappedSignature } from 'ox/erc6492';
|
|
3
|
+
import { DEPLOY } from './constants.js';
|
|
4
|
+
const EIP_6492_OFFCHAIN_DEPLOY_CODE = '0x608060405234801561001057600080fd5b5060405161124a38038061124a83398101604081905261002f91610124565b600060405161003d906100dd565b604051809103906000f080158015610059573d6000803e3d6000fd5b5090506000816001600160a01b0316638f0684308686866040518463ffffffff1660e01b815260040161008e939291906101fb565b6020604051808303816000875af11580156100ad573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906100d19190610244565b9050806000526001601ff35b610fdc8061026e83390190565b634e487b7160e01b600052604160045260246000fd5b60005b8381101561011b578181015183820152602001610103565b50506000910152565b60008060006060848603121561013957600080fd5b83516001600160a01b038116811461015057600080fd5b6020850151604086015191945092506001600160401b038082111561017457600080fd5b818601915086601f83011261018857600080fd5b81518181111561019a5761019a6100ea565b604051601f8201601f19908116603f011681019083821181831017156101c2576101c26100ea565b816040528281528960208487010111156101db57600080fd5b6101ec836020830160208801610100565b80955050505050509250925092565b60018060a01b0384168152826020820152606060408201526000825180606084015261022e816080850160208701610100565b601f01601f191691909101608001949350505050565b60006020828403121561025657600080fd5b8151801515811461026657600080fd5b939250505056fe608060405234801561001057600080fd5b50610fbc806100206000396000f3fe608060405234801561001057600080fd5b50600436106100675760003560e01c806376be4cea1161005057806376be4cea146100a65780638f068430146100b957806398ef1ed8146100cc57600080fd5b80631c6453271461006c5780633d787b6314610093575b600080fd5b61007f61007a366004610ad4565b6100df565b604051901515815260200160405180910390f35b61007f6100a1366004610ad4565b61023d565b61007f6100b4366004610b3e565b61031e565b61007f6100c7366004610ad4565b6108e1565b61007f6100da366004610ad4565b61096e565b6040517f76be4cea00000000000000000000000000000000000000000000000000000000815260009030906376be4cea9061012890889088908890889088908190600401610bc3565b6020604051808303816000875af1925050508015610181575060408051601f3d9081017fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffe016820190925261017e91810190610c45565b60015b610232573d8080156101af576040519150601f19603f3d011682016040523d82523d6000602084013e6101b4565b606091505b508051600181900361022757816000815181106101d3576101d3610c69565b6020910101517fff00000000000000000000000000000000000000000000000000000000000000167f0100000000000000000000000000000000000000000000000000000000000000149250610235915050565b600092505050610235565b90505b949350505050565b6040517f76be4cea00000000000000000000000000000000000000000000000000000000815260009030906376be4cea906102879088908890889088906001908990600401610bc3565b6020604051808303816000875af19250505080156102e0575060408051601f3d9081017fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffe01682019092526102dd91810190610c45565b60015b610232573d80801561030e576040519150601f19603f3d011682016040523d82523d6000602084013e610313565b606091505b506000915050610235565b600073ffffffffffffffffffffffffffffffffffffffff87163b6060827f64926492649264926492649264926492649264926492649264926492649264928888610369602082610c98565b610375928b9290610cd8565b61037e91610d02565b1490508015610484576000606089828a610399602082610c98565b926103a693929190610cd8565b8101906103b39190610e18565b955090925090508415806103c45750865b1561047d576000808373ffffffffffffffffffffffffffffffffffffffff16836040516103f19190610eb2565b6000604051808303816000865af19150503d806000811461042e576040519150601f19603f3d011682016040523d82523d6000602084013e610433565b606091505b50915091508161047a57806040517f9d0d6e2d0000000000000000000000000000000000000000000000000000000081526004016104719190610f18565b60405180910390fd5b50505b50506104be565b87878080601f0160208091040260200160405190810160405280939291908181526020018383808284376000920191909152509294505050505b80806104ca5750600083115b156106bb576040517f1626ba7e00000000000000000000000000000000000000000000000000000000815273ffffffffffffffffffffffffffffffffffffffff8b1690631626ba7e90610523908c908690600401610f2b565b602060405180830381865afa92505050801561057a575060408051601f3d9081017fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffe016820190925261057791810190610f44565b60015b61060f573d8080156105a8576040519150601f19603f3d011682016040523d82523d6000602084013e6105ad565b606091505b50851580156105bc5750600084115b156105db576105d08b8b8b8b8b600161031e565b9450505050506108d7565b806040517f6f2a95990000000000000000000000000000000000000000000000000000000081526004016104719190610f18565b7fffffffff0000000000000000000000000000000000000000000000000000000081167f1626ba7e000000000000000000000000000000000000000000000000000000001480158161065f575086155b801561066b5750600085115b1561068b5761067f8c8c8c8c8c600161031e565b955050505050506108d7565b841580156106965750825b80156106a0575087155b156106af57806000526001601ffd5b94506108d79350505050565b6041871461074b576040517f08c379a000000000000000000000000000000000000000000000000000000000815260206004820152603a60248201527f5369676e617475726556616c696461746f72237265636f7665725369676e657260448201527f3a20696e76616c6964207369676e6174757265206c656e6774680000000000006064820152608401610471565b600061075a6020828a8c610cd8565b61076391610d02565b90506000610775604060208b8d610cd8565b61077e91610d02565b905060008a8a604081811061079557610795610c69565b919091013560f81c915050601b81148015906107b557508060ff16601c14155b15610842576040517f08c379a000000000000000000000000000000000000000000000000000000000815260206004820152602d60248201527f5369676e617475726556616c696461746f723a20696e76616c6964207369676e60448201527f617475726520762076616c7565000000000000000000000000000000000000006064820152608401610471565b6040805160008152602081018083528e905260ff831691810191909152606081018490526080810183905273ffffffffffffffffffffffffffffffffffffffff8e169060019060a0016020604051602081039080840390855afa1580156108ad573d6000803e3d6000fd5b5050506020604051035173ffffffffffffffffffffffffffffffffffffffff161496505050505050505b9695505050505050565b6040517f76be4cea00000000000000000000000000000000000000000000000000000000815260009030906376be4cea9061092b9088908890889088906001908990600401610bc3565b6020604051808303816000875af115801561094a573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906102329190610c45565b6040517f76be4cea00000000000000000000000000000000000000000000000000000000815260009030906376be4cea906109b790889088908890889088908190600401610bc3565b6020604051808303816000875af1925050508015610a10575060408051601f3d9081017fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffe0168201909252610a0d91810190610c45565b60015b610232573d808015610a3e576040519150601f19603f3d011682016040523d82523d6000602084013e610a43565b606091505b5080516001819003610a6257816000815181106101d3576101d3610c69565b8082fd5b73ffffffffffffffffffffffffffffffffffffffff81168114610a8857600080fd5b50565b60008083601f840112610a9d57600080fd5b50813567ffffffffffffffff811115610ab557600080fd5b602083019150836020828501011115610acd57600080fd5b9250929050565b60008060008060608587031215610aea57600080fd5b8435610af581610a66565b935060208501359250604085013567ffffffffffffffff811115610b1857600080fd5b610b2487828801610a8b565b95989497509550505050565b8015158114610a8857600080fd5b60008060008060008060a08789031215610b5757600080fd5b8635610b6281610a66565b955060208701359450604087013567ffffffffffffffff811115610b8557600080fd5b610b9189828a01610a8b565b9095509350506060870135610ba581610b30565b91506080870135610bb581610b30565b809150509295509295509295565b73ffffffffffffffffffffffffffffffffffffffff8716815285602082015260a060408201528360a0820152838560c0830137600060c085830181019190915292151560608201529015156080820152601f9092017fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffe016909101019392505050565b600060208284031215610c5757600080fd5b8151610c6281610b30565b9392505050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052603260045260246000fd5b81810381811115610cd2577f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b92915050565b60008085851115610ce857600080fd5b83861115610cf557600080fd5b5050820193919092039150565b80356020831015610cd2577fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff602084900360031b1b1692915050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052604160045260246000fd5b600082601f830112610d7e57600080fd5b813567ffffffffffffffff80821115610d9957610d99610d3e565b604051601f83017fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffe0908116603f01168101908282118183101715610ddf57610ddf610d3e565b81604052838152866020858801011115610df857600080fd5b836020870160208301376000602085830101528094505050505092915050565b600080600060608486031215610e2d57600080fd5b8335610e3881610a66565b9250602084013567ffffffffffffffff80821115610e5557600080fd5b610e6187838801610d6d565b93506040860135915080821115610e7757600080fd5b50610e8486828701610d6d565b9150509250925092565b60005b83811015610ea9578181015183820152602001610e91565b50506000910152565b60008251610ec4818460208701610e8e565b9190910192915050565b60008151808452610ee6816020860160208601610e8e565b601f017fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffe0169290920160200192915050565b602081526000610c626020830184610ece565b8281526040602082015260006102356040830184610ece565b600060208284031215610f5657600080fd5b81517fffffffff0000000000000000000000000000000000000000000000000000000081168114610c6257600080fdfea26469706673582212201a72aed4b15ffb05b6502997a9bb655992e06590bd26b336dfbb153d7ff6f34b64736f6c63430008120033';
|
|
5
|
+
export function deploy(deployHash, context) {
|
|
6
|
+
const encoded = AbiFunction.encodeData(DEPLOY, [context.stage1, Hex.from(deployHash)]);
|
|
7
|
+
switch (typeof deployHash) {
|
|
8
|
+
case 'object':
|
|
9
|
+
return { to: context.factory, data: Hex.toBytes(encoded) };
|
|
10
|
+
case 'string':
|
|
11
|
+
return { to: context.factory, data: encoded };
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
export function wrap(signature, { to, data }) {
|
|
15
|
+
const encoded = Hex.concat(AbiParameters.encode([{ type: 'address' }, { type: 'bytes' }, { type: 'bytes' }], [to, Hex.from(data), Hex.from(signature)]), WrappedSignature.magicBytes);
|
|
16
|
+
switch (typeof signature) {
|
|
17
|
+
case 'object':
|
|
18
|
+
return Hex.toBytes(encoded);
|
|
19
|
+
case 'string':
|
|
20
|
+
return encoded;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
export function decode(signature) {
|
|
24
|
+
switch (typeof signature) {
|
|
25
|
+
case 'object':
|
|
26
|
+
if (Bytes.toHex(signature.subarray(-WrappedSignature.magicBytes.slice(2).length / 2)) ===
|
|
27
|
+
WrappedSignature.magicBytes) {
|
|
28
|
+
const [to, data, decoded] = AbiParameters.decode([{ type: 'address' }, { type: 'bytes' }, { type: 'bytes' }], signature.subarray(0, -WrappedSignature.magicBytes.slice(2).length / 2));
|
|
29
|
+
return { signature: Hex.toBytes(decoded), erc6492: { to, data: Hex.toBytes(data) } };
|
|
30
|
+
}
|
|
31
|
+
else {
|
|
32
|
+
return { signature };
|
|
33
|
+
}
|
|
34
|
+
case 'string':
|
|
35
|
+
if (signature.endsWith(WrappedSignature.magicBytes.slice(2))) {
|
|
36
|
+
try {
|
|
37
|
+
const [to, data, decoded] = AbiParameters.decode([{ type: 'address' }, { type: 'bytes' }, { type: 'bytes' }], signature.slice(0, -WrappedSignature.magicBytes.slice(2).length));
|
|
38
|
+
return { signature: decoded, erc6492: { to, data: data } };
|
|
39
|
+
}
|
|
40
|
+
catch {
|
|
41
|
+
return { signature };
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
return { signature };
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
export function isValid(address, messageHash, encodedSignature, provider) {
|
|
50
|
+
// Validate off chain with ERC-6492
|
|
51
|
+
const validationCallData = AbiParameters.encode(AbiParameters.from('address, bytes32, bytes'), [
|
|
52
|
+
address,
|
|
53
|
+
Hex.from(messageHash),
|
|
54
|
+
Hex.from(encodedSignature),
|
|
55
|
+
]);
|
|
56
|
+
const callData = Hex.concat(EIP_6492_OFFCHAIN_DEPLOY_CODE, validationCallData);
|
|
57
|
+
return provider
|
|
58
|
+
.request({
|
|
59
|
+
method: 'eth_call',
|
|
60
|
+
params: [{ data: callData }, 'latest'],
|
|
61
|
+
})
|
|
62
|
+
.then((result) => parseInt(result, 16) === 1);
|
|
63
|
+
}
|
|
64
|
+
//# sourceMappingURL=erc-6492.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"erc-6492.js","sourceRoot":"","sources":["../src/erc-6492.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { Address } from 'ox';
|
|
2
|
+
export type Extensions = {
|
|
3
|
+
passkeys: Address.Address;
|
|
4
|
+
recovery: Address.Address;
|
|
5
|
+
};
|
|
6
|
+
export declare const Dev1: Extensions;
|
|
7
|
+
export * as Passkeys from './passkeys.js';
|
|
8
|
+
export * as Recovery from './recovery.js';
|
|
9
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/extensions/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,IAAI,CAAA;AAE5B,MAAM,MAAM,UAAU,GAAG;IACvB,QAAQ,EAAE,OAAO,CAAC,OAAO,CAAA;IACzB,QAAQ,EAAE,OAAO,CAAC,OAAO,CAAA;CAC1B,CAAA;AAED,eAAO,MAAM,IAAI,EAAE,UAGlB,CAAA;AAED,OAAO,KAAK,QAAQ,MAAM,eAAe,CAAA;AACzC,OAAO,KAAK,QAAQ,MAAM,eAAe,CAAA"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export const Dev1 = {
|
|
2
|
+
passkeys: '0x8f26281dB84C18aAeEa8a53F94c835393229d296',
|
|
3
|
+
recovery: '0xd98da48C4FF9c19742eA5856A277424557C863a6',
|
|
4
|
+
};
|
|
5
|
+
export * as Passkeys from './passkeys.js';
|
|
6
|
+
export * as Recovery from './recovery.js';
|
|
7
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/extensions/index.ts"],"names":[],"mappings":"AAOA,MAAM,CAAC,MAAM,IAAI,GAAe;IAC9B,QAAQ,EAAE,4CAA4C;IACtD,QAAQ,EAAE,4CAA4C;CACvD,CAAA;AAED,OAAO,KAAK,QAAQ,MAAM,eAAe,CAAA;AACzC,OAAO,KAAK,QAAQ,MAAM,eAAe,CAAA"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { Bytes, Hex } from 'ox';
|
|
2
|
+
import * as GenericTree from '../generic-tree.js';
|
|
3
|
+
export type PasskeyMetadata = {
|
|
4
|
+
credentialId: string;
|
|
5
|
+
};
|
|
6
|
+
export type PublicKey = {
|
|
7
|
+
requireUserVerification: boolean;
|
|
8
|
+
x: Hex.Hex;
|
|
9
|
+
y: Hex.Hex;
|
|
10
|
+
metadata?: PasskeyMetadata | Hex.Hex;
|
|
11
|
+
};
|
|
12
|
+
export declare function metadataTree(metadata: Required<PublicKey>['metadata']): GenericTree.Tree;
|
|
13
|
+
export declare function metadataNode(metadata: Required<PublicKey>['metadata']): GenericTree.Node;
|
|
14
|
+
export declare function toTree(publicKey: PublicKey): GenericTree.Tree;
|
|
15
|
+
export declare function fromTree(tree: GenericTree.Tree): PublicKey;
|
|
16
|
+
export declare function rootFor(publicKey: PublicKey): Hex.Hex;
|
|
17
|
+
export type DecodedSignature = {
|
|
18
|
+
publicKey: PublicKey;
|
|
19
|
+
r: Bytes.Bytes;
|
|
20
|
+
s: Bytes.Bytes;
|
|
21
|
+
authenticatorData: Bytes.Bytes;
|
|
22
|
+
clientDataJSON: string;
|
|
23
|
+
embedMetadata?: boolean;
|
|
24
|
+
};
|
|
25
|
+
export declare function encode(decoded: DecodedSignature): Bytes.Bytes;
|
|
26
|
+
export declare function isValidSignature(challenge: Hex.Hex, decoded: DecodedSignature): boolean;
|
|
27
|
+
export declare function decode(data: Bytes.Bytes): Required<DecodedSignature> & {
|
|
28
|
+
challengeIndex: number;
|
|
29
|
+
typeIndex: number;
|
|
30
|
+
};
|
|
31
|
+
//# sourceMappingURL=passkeys.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"passkeys.d.ts","sourceRoot":"","sources":["../../src/extensions/passkeys.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,GAAG,EAAgB,MAAM,IAAI,CAAA;AAC7C,OAAO,KAAK,WAAW,MAAM,oBAAoB,CAAA;AAEjD,MAAM,MAAM,eAAe,GAAG;IAC5B,YAAY,EAAE,MAAM,CAAA;CACrB,CAAA;AAED,MAAM,MAAM,SAAS,GAAG;IACtB,uBAAuB,EAAE,OAAO,CAAA;IAChC,CAAC,EAAE,GAAG,CAAC,GAAG,CAAA;IACV,CAAC,EAAE,GAAG,CAAC,GAAG,CAAA;IACV,QAAQ,CAAC,EAAE,eAAe,GAAG,GAAG,CAAC,GAAG,CAAA;CACrC,CAAA;AAED,wBAAgB,YAAY,CAAC,QAAQ,EAAE,QAAQ,CAAC,SAAS,CAAC,CAAC,UAAU,CAAC,GAAG,WAAW,CAAC,IAAI,CASxF;AAED,wBAAgB,YAAY,CAAC,QAAQ,EAAE,QAAQ,CAAC,SAAS,CAAC,CAAC,UAAU,CAAC,GAAG,WAAW,CAAC,IAAI,CAExF;AAED,wBAAgB,MAAM,CAAC,SAAS,EAAE,SAAS,GAAG,WAAW,CAAC,IAAI,CAgB7D;AAED,wBAAgB,QAAQ,CAAC,IAAI,EAAE,WAAW,CAAC,IAAI,GAAG,SAAS,CAmE1D;AAED,wBAAgB,OAAO,CAAC,SAAS,EAAE,SAAS,GAAG,GAAG,CAAC,GAAG,CAErD;AAED,MAAM,MAAM,gBAAgB,GAAG;IAC7B,SAAS,EAAE,SAAS,CAAA;IACpB,CAAC,EAAE,KAAK,CAAC,KAAK,CAAA;IACd,CAAC,EAAE,KAAK,CAAC,KAAK,CAAA;IACd,iBAAiB,EAAE,KAAK,CAAC,KAAK,CAAA;IAC9B,cAAc,EAAE,MAAM,CAAA;IACtB,aAAa,CAAC,EAAE,OAAO,CAAA;CACxB,CAAA;AAED,wBAAgB,MAAM,CAAC,OAAO,EAAE,gBAAgB,GAAG,KAAK,CAAC,KAAK,CA0D7D;AAED,wBAAgB,gBAAgB,CAAC,SAAS,EAAE,GAAG,CAAC,GAAG,EAAE,OAAO,EAAE,gBAAgB,GAAG,OAAO,CAoBvF;AAED,wBAAgB,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,KAAK,GAAG,QAAQ,CAAC,gBAAgB,CAAC,GAAG;IAAE,cAAc,EAAE,MAAM,CAAC;IAAC,SAAS,EAAE,MAAM,CAAA;CAAE,CAuEpH"}
|
|
@@ -0,0 +1,224 @@
|
|
|
1
|
+
import { Bytes, Hex, WebAuthnP256 } from 'ox';
|
|
2
|
+
import * as GenericTree from '../generic-tree.js';
|
|
3
|
+
export function metadataTree(metadata) {
|
|
4
|
+
if (typeof metadata === 'object') {
|
|
5
|
+
return {
|
|
6
|
+
type: 'leaf',
|
|
7
|
+
value: Bytes.fromString(metadata.credentialId),
|
|
8
|
+
};
|
|
9
|
+
}
|
|
10
|
+
else {
|
|
11
|
+
return metadata;
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
export function metadataNode(metadata) {
|
|
15
|
+
return GenericTree.hash(metadataTree(metadata));
|
|
16
|
+
}
|
|
17
|
+
export function toTree(publicKey) {
|
|
18
|
+
const a = Hex.padLeft(publicKey.x, 32);
|
|
19
|
+
const b = Hex.padLeft(publicKey.y, 32);
|
|
20
|
+
const c = Hex.padLeft(publicKey.requireUserVerification ? '0x01' : '0x00', 32);
|
|
21
|
+
if (publicKey.metadata) {
|
|
22
|
+
return [
|
|
23
|
+
[a, b],
|
|
24
|
+
[c, metadataTree(publicKey.metadata)],
|
|
25
|
+
];
|
|
26
|
+
}
|
|
27
|
+
else {
|
|
28
|
+
return [
|
|
29
|
+
[a, b],
|
|
30
|
+
[c, Hex.padLeft('0x00', 32)],
|
|
31
|
+
];
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
export function fromTree(tree) {
|
|
35
|
+
if (!GenericTree.isBranch(tree) || tree.length !== 2) {
|
|
36
|
+
throw new Error('Invalid tree');
|
|
37
|
+
}
|
|
38
|
+
const [p1, p2] = tree;
|
|
39
|
+
if (!GenericTree.isBranch(p1) || p1.length !== 2) {
|
|
40
|
+
throw new Error('Invalid tree for x,y');
|
|
41
|
+
}
|
|
42
|
+
const [x, y] = p1;
|
|
43
|
+
if (!GenericTree.isNode(x)) {
|
|
44
|
+
throw new Error('Invalid x bytes');
|
|
45
|
+
}
|
|
46
|
+
if (!GenericTree.isNode(y)) {
|
|
47
|
+
throw new Error('Invalid y bytes');
|
|
48
|
+
}
|
|
49
|
+
let requireUserVerification = false;
|
|
50
|
+
let metadata;
|
|
51
|
+
if (GenericTree.isBranch(p2)) {
|
|
52
|
+
if (p2.length !== 2) {
|
|
53
|
+
throw new Error('Invalid tree for c,metadata');
|
|
54
|
+
}
|
|
55
|
+
const [c, meta] = p2;
|
|
56
|
+
if (!GenericTree.isNode(c) || c.length !== 32) {
|
|
57
|
+
throw new Error('Invalid c bytes');
|
|
58
|
+
}
|
|
59
|
+
const cBytes = Hex.toBytes(c);
|
|
60
|
+
requireUserVerification = cBytes[31] === 1;
|
|
61
|
+
if (GenericTree.isBranch(meta)) {
|
|
62
|
+
if (meta.length !== 2) {
|
|
63
|
+
throw new Error('Invalid metadata tree');
|
|
64
|
+
}
|
|
65
|
+
const [credLeaf, sub] = meta;
|
|
66
|
+
if (!GenericTree.isLeaf(credLeaf)) {
|
|
67
|
+
throw new Error('Invalid credentialId leaf');
|
|
68
|
+
}
|
|
69
|
+
const credentialId = new TextDecoder().decode(credLeaf.value);
|
|
70
|
+
if (!GenericTree.isBranch(sub) || sub.length !== 2) {
|
|
71
|
+
throw new Error('Invalid sub-branch for name and createdAt');
|
|
72
|
+
}
|
|
73
|
+
const [nameLeaf, createdAtLeaf] = sub;
|
|
74
|
+
if (!GenericTree.isLeaf(nameLeaf) || !GenericTree.isLeaf(createdAtLeaf)) {
|
|
75
|
+
throw new Error('Invalid metadata leaves');
|
|
76
|
+
}
|
|
77
|
+
metadata = { credentialId };
|
|
78
|
+
}
|
|
79
|
+
else if (GenericTree.isNode(meta) && meta.length === 32) {
|
|
80
|
+
metadata = meta;
|
|
81
|
+
}
|
|
82
|
+
else {
|
|
83
|
+
throw new Error('Invalid metadata node');
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
else {
|
|
87
|
+
if (!GenericTree.isNode(p2) || p2.length !== 32) {
|
|
88
|
+
throw new Error('Invalid c bytes');
|
|
89
|
+
}
|
|
90
|
+
const p2Bytes = Hex.toBytes(p2);
|
|
91
|
+
requireUserVerification = p2Bytes[31] === 1;
|
|
92
|
+
}
|
|
93
|
+
return { requireUserVerification, x, y, metadata };
|
|
94
|
+
}
|
|
95
|
+
export function rootFor(publicKey) {
|
|
96
|
+
return GenericTree.hash(toTree(publicKey));
|
|
97
|
+
}
|
|
98
|
+
export function encode(decoded) {
|
|
99
|
+
const challengeIndex = decoded.clientDataJSON.indexOf('"challenge"');
|
|
100
|
+
const typeIndex = decoded.clientDataJSON.indexOf('"type"');
|
|
101
|
+
const authDataSize = decoded.authenticatorData.length;
|
|
102
|
+
const clientDataJSONSize = decoded.clientDataJSON.length;
|
|
103
|
+
if (authDataSize > 65535) {
|
|
104
|
+
throw new Error('Authenticator data size is too large');
|
|
105
|
+
}
|
|
106
|
+
if (clientDataJSONSize > 65535) {
|
|
107
|
+
throw new Error('Client data JSON size is too large');
|
|
108
|
+
}
|
|
109
|
+
const bytesAuthDataSize = authDataSize <= 255 ? 1 : 2;
|
|
110
|
+
const bytesClientDataJSONSize = clientDataJSONSize <= 255 ? 1 : 2;
|
|
111
|
+
const bytesChallengeIndex = challengeIndex <= 255 ? 1 : 2;
|
|
112
|
+
const bytesTypeIndex = typeIndex <= 255 ? 1 : 2;
|
|
113
|
+
let flags = 0;
|
|
114
|
+
flags |= decoded.publicKey.requireUserVerification ? 1 : 0; // 0x01 bit
|
|
115
|
+
flags |= (bytesAuthDataSize - 1) << 1; // 0x02 bit
|
|
116
|
+
flags |= (bytesClientDataJSONSize - 1) << 2; // 0x04 bit
|
|
117
|
+
flags |= (bytesChallengeIndex - 1) << 3; // 0x08 bit
|
|
118
|
+
flags |= (bytesTypeIndex - 1) << 4; // 0x10 bit
|
|
119
|
+
// Set metadata flag if metadata exists
|
|
120
|
+
if (decoded.embedMetadata) {
|
|
121
|
+
flags |= 1 << 6; // 0x40 bit
|
|
122
|
+
}
|
|
123
|
+
let result = Bytes.from([flags]);
|
|
124
|
+
// Add metadata if it exists
|
|
125
|
+
if (decoded.embedMetadata) {
|
|
126
|
+
if (!decoded.publicKey.metadata) {
|
|
127
|
+
throw new Error('Metadata is not present in the public key');
|
|
128
|
+
}
|
|
129
|
+
result = Bytes.concat(result, Hex.toBytes(metadataNode(decoded.publicKey.metadata)));
|
|
130
|
+
}
|
|
131
|
+
result = Bytes.concat(result, Bytes.padLeft(Bytes.fromNumber(authDataSize), bytesAuthDataSize));
|
|
132
|
+
result = Bytes.concat(result, decoded.authenticatorData);
|
|
133
|
+
result = Bytes.concat(result, Bytes.padLeft(Bytes.fromNumber(decoded.clientDataJSON.length), bytesClientDataJSONSize));
|
|
134
|
+
result = Bytes.concat(result, Bytes.from(new TextEncoder().encode(decoded.clientDataJSON)));
|
|
135
|
+
result = Bytes.concat(result, Bytes.padLeft(Bytes.fromNumber(challengeIndex), bytesChallengeIndex));
|
|
136
|
+
result = Bytes.concat(result, Bytes.padLeft(Bytes.fromNumber(typeIndex), bytesTypeIndex));
|
|
137
|
+
result = Bytes.concat(result, Bytes.padLeft(decoded.r, 32));
|
|
138
|
+
result = Bytes.concat(result, Bytes.padLeft(decoded.s, 32));
|
|
139
|
+
result = Bytes.concat(result, Bytes.fromHex(decoded.publicKey.x));
|
|
140
|
+
result = Bytes.concat(result, Bytes.fromHex(decoded.publicKey.y));
|
|
141
|
+
return result;
|
|
142
|
+
}
|
|
143
|
+
export function isValidSignature(challenge, decoded) {
|
|
144
|
+
return WebAuthnP256.verify({
|
|
145
|
+
challenge,
|
|
146
|
+
publicKey: {
|
|
147
|
+
x: Hex.toBigInt(decoded.publicKey.x),
|
|
148
|
+
y: Hex.toBigInt(decoded.publicKey.y),
|
|
149
|
+
prefix: 4,
|
|
150
|
+
},
|
|
151
|
+
metadata: {
|
|
152
|
+
authenticatorData: Hex.fromBytes(decoded.authenticatorData),
|
|
153
|
+
challengeIndex: decoded.clientDataJSON.indexOf('"challenge"'),
|
|
154
|
+
clientDataJSON: decoded.clientDataJSON,
|
|
155
|
+
typeIndex: decoded.clientDataJSON.indexOf('"type"'),
|
|
156
|
+
userVerificationRequired: decoded.publicKey.requireUserVerification,
|
|
157
|
+
},
|
|
158
|
+
signature: {
|
|
159
|
+
r: Bytes.toBigInt(decoded.r),
|
|
160
|
+
s: Bytes.toBigInt(decoded.s),
|
|
161
|
+
},
|
|
162
|
+
});
|
|
163
|
+
}
|
|
164
|
+
export function decode(data) {
|
|
165
|
+
let offset = 0;
|
|
166
|
+
const flags = data[0];
|
|
167
|
+
offset += 1;
|
|
168
|
+
if (flags === undefined) {
|
|
169
|
+
throw new Error('Invalid flags');
|
|
170
|
+
}
|
|
171
|
+
const requireUserVerification = (flags & 0x01) !== 0x00;
|
|
172
|
+
const bytesAuthDataSize = ((flags >> 1) & 0x01) + 1;
|
|
173
|
+
const bytesClientDataJSONSize = ((flags >> 2) & 0x01) + 1;
|
|
174
|
+
const bytesChallengeIndex = ((flags >> 3) & 0x01) + 1;
|
|
175
|
+
const bytesTypeIndex = ((flags >> 4) & 0x01) + 1;
|
|
176
|
+
const hasMetadata = ((flags >> 6) & 0x01) === 0x01;
|
|
177
|
+
// Check if fallback to abi decode is needed
|
|
178
|
+
if ((flags & 0x20) !== 0) {
|
|
179
|
+
throw new Error('Fallback to abi decode is not supported in this implementation');
|
|
180
|
+
}
|
|
181
|
+
let metadata;
|
|
182
|
+
// Read metadata if present
|
|
183
|
+
if (hasMetadata) {
|
|
184
|
+
const metadataBytes = Bytes.slice(data, offset, offset + 32);
|
|
185
|
+
metadata = Hex.fromBytes(metadataBytes);
|
|
186
|
+
offset += 32;
|
|
187
|
+
}
|
|
188
|
+
const authDataSize = Bytes.toNumber(Bytes.slice(data, offset, offset + bytesAuthDataSize));
|
|
189
|
+
offset += bytesAuthDataSize;
|
|
190
|
+
const authenticatorData = Bytes.slice(data, offset, offset + authDataSize);
|
|
191
|
+
offset += authDataSize;
|
|
192
|
+
const clientDataJSONSize = Bytes.toNumber(Bytes.slice(data, offset, offset + bytesClientDataJSONSize));
|
|
193
|
+
offset += bytesClientDataJSONSize;
|
|
194
|
+
const clientDataJSONBytes = Bytes.slice(data, offset, offset + clientDataJSONSize);
|
|
195
|
+
offset += clientDataJSONSize;
|
|
196
|
+
const clientDataJSON = new TextDecoder().decode(clientDataJSONBytes);
|
|
197
|
+
const challengeIndex = Bytes.toNumber(Bytes.slice(data, offset, offset + bytesChallengeIndex));
|
|
198
|
+
offset += bytesChallengeIndex;
|
|
199
|
+
const typeIndex = Bytes.toNumber(Bytes.slice(data, offset, offset + bytesTypeIndex));
|
|
200
|
+
offset += bytesTypeIndex;
|
|
201
|
+
const r = Bytes.slice(data, offset, offset + 32);
|
|
202
|
+
offset += 32;
|
|
203
|
+
const s = Bytes.slice(data, offset, offset + 32);
|
|
204
|
+
offset += 32;
|
|
205
|
+
const xBytes = Bytes.slice(data, offset, offset + 32);
|
|
206
|
+
offset += 32;
|
|
207
|
+
const yBytes = Bytes.slice(data, offset, offset + 32);
|
|
208
|
+
return {
|
|
209
|
+
publicKey: {
|
|
210
|
+
requireUserVerification,
|
|
211
|
+
x: Hex.fromBytes(xBytes),
|
|
212
|
+
y: Hex.fromBytes(yBytes),
|
|
213
|
+
metadata,
|
|
214
|
+
},
|
|
215
|
+
r,
|
|
216
|
+
s,
|
|
217
|
+
authenticatorData,
|
|
218
|
+
clientDataJSON,
|
|
219
|
+
challengeIndex,
|
|
220
|
+
typeIndex,
|
|
221
|
+
embedMetadata: hasMetadata,
|
|
222
|
+
};
|
|
223
|
+
}
|
|
224
|
+
//# sourceMappingURL=passkeys.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"passkeys.js","sourceRoot":"","sources":["../../src/extensions/passkeys.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,GAAG,EAAE,YAAY,EAAE,MAAM,IAAI,CAAA;AAC7C,OAAO,KAAK,WAAW,MAAM,oBAAoB,CAAA;AAajD,MAAM,UAAU,YAAY,CAAC,QAAyC;IACpE,IAAI,OAAO,QAAQ,KAAK,QAAQ,EAAE,CAAC;QACjC,OAAO;YACL,IAAI,EAAE,MAAM;YACZ,KAAK,EAAE,KAAK,CAAC,UAAU,CAAC,QAAQ,CAAC,YAAY,CAAC;SAC/C,CAAA;IACH,CAAC;SAAM,CAAC;QACN,OAAO,QAAQ,CAAA;IACjB,CAAC;AACH,CAAC;AAED,MAAM,UAAU,YAAY,CAAC,QAAyC;IACpE,OAAO,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC,CAAA;AACjD,CAAC;AAED,MAAM,UAAU,MAAM,CAAC,SAAoB;IACzC,MAAM,CAAC,GAAG,GAAG,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,EAAE,EAAE,CAAC,CAAA;IACtC,MAAM,CAAC,GAAG,GAAG,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,EAAE,EAAE,CAAC,CAAA;IACtC,MAAM,CAAC,GAAG,GAAG,CAAC,OAAO,CAAC,SAAS,CAAC,uBAAuB,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,CAAA;IAE9E,IAAI,SAAS,CAAC,QAAQ,EAAE,CAAC;QACvB,OAAO;YACL,CAAC,CAAC,EAAE,CAAC,CAAC;YACN,CAAC,CAAC,EAAE,YAAY,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;SACtC,CAAA;IACH,CAAC;SAAM,CAAC;QACN,OAAO;YACL,CAAC,CAAC,EAAE,CAAC,CAAC;YACN,CAAC,CAAC,EAAE,GAAG,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;SAC7B,CAAA;IACH,CAAC;AACH,CAAC;AAED,MAAM,UAAU,QAAQ,CAAC,IAAsB;IAC7C,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACrD,MAAM,IAAI,KAAK,CAAC,cAAc,CAAC,CAAA;IACjC,CAAC;IACD,MAAM,CAAC,EAAE,EAAE,EAAE,CAAC,GAAG,IAAI,CAAA;IACrB,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,EAAE,CAAC,IAAI,EAAE,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACjD,MAAM,IAAI,KAAK,CAAC,sBAAsB,CAAC,CAAA;IACzC,CAAC;IAED,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,EAAE,CAAA;IACjB,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC;QAC3B,MAAM,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAA;IACpC,CAAC;IACD,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC;QAC3B,MAAM,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAA;IACpC,CAAC;IAED,IAAI,uBAAuB,GAAG,KAAK,CAAA;IACnC,IAAI,QAA+B,CAAA;IAEnC,IAAI,WAAW,CAAC,QAAQ,CAAC,EAAE,CAAC,EAAE,CAAC;QAC7B,IAAI,EAAE,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACpB,MAAM,IAAI,KAAK,CAAC,6BAA6B,CAAC,CAAA;QAChD,CAAC;QAED,MAAM,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,EAAE,CAAA;QACpB,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,MAAM,KAAK,EAAE,EAAE,CAAC;YAC9C,MAAM,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAA;QACpC,CAAC;QACD,MAAM,MAAM,GAAG,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,CAAA;QAC7B,uBAAuB,GAAG,MAAM,CAAC,EAAE,CAAC,KAAK,CAAC,CAAA;QAE1C,IAAI,WAAW,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;YAC/B,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBACtB,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAA;YAC1C,CAAC;YAED,MAAM,CAAC,QAAQ,EAAE,GAAG,CAAC,GAAG,IAAI,CAAA;YAC5B,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,CAAC;gBAClC,MAAM,IAAI,KAAK,CAAC,2BAA2B,CAAC,CAAA;YAC9C,CAAC;YACD,MAAM,YAAY,GAAG,IAAI,WAAW,EAAE,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAA;YAE7D,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,GAAG,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBACnD,MAAM,IAAI,KAAK,CAAC,2CAA2C,CAAC,CAAA;YAC9D,CAAC;YAED,MAAM,CAAC,QAAQ,EAAE,aAAa,CAAC,GAAG,GAAG,CAAA;YACrC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,aAAa,CAAC,EAAE,CAAC;gBACxE,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAA;YAC5C,CAAC;YAED,QAAQ,GAAG,EAAE,YAAY,EAAE,CAAA;QAC7B,CAAC;aAAM,IAAI,WAAW,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,MAAM,KAAK,EAAE,EAAE,CAAC;YAC1D,QAAQ,GAAG,IAAI,CAAA;QACjB,CAAC;aAAM,CAAC;YACN,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAA;QAC1C,CAAC;IACH,CAAC;SAAM,CAAC;QACN,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,EAAE,CAAC,MAAM,KAAK,EAAE,EAAE,CAAC;YAChD,MAAM,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAA;QACpC,CAAC;QACD,MAAM,OAAO,GAAG,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC,CAAA;QAC/B,uBAAuB,GAAG,OAAO,CAAC,EAAE,CAAC,KAAK,CAAC,CAAA;IAC7C,CAAC;IAED,OAAO,EAAE,uBAAuB,EAAE,CAAC,EAAE,CAAC,EAAE,QAAQ,EAAE,CAAA;AACpD,CAAC;AAED,MAAM,UAAU,OAAO,CAAC,SAAoB;IAC1C,OAAO,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAA;AAC5C,CAAC;AAWD,MAAM,UAAU,MAAM,CAAC,OAAyB;IAC9C,MAAM,cAAc,GAAG,OAAO,CAAC,cAAc,CAAC,OAAO,CAAC,aAAa,CAAC,CAAA;IACpE,MAAM,SAAS,GAAG,OAAO,CAAC,cAAc,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAA;IAE1D,MAAM,YAAY,GAAG,OAAO,CAAC,iBAAiB,CAAC,MAAM,CAAA;IACrD,MAAM,kBAAkB,GAAG,OAAO,CAAC,cAAc,CAAC,MAAM,CAAA;IAExD,IAAI,YAAY,GAAG,KAAK,EAAE,CAAC;QACzB,MAAM,IAAI,KAAK,CAAC,sCAAsC,CAAC,CAAA;IACzD,CAAC;IACD,IAAI,kBAAkB,GAAG,KAAK,EAAE,CAAC;QAC/B,MAAM,IAAI,KAAK,CAAC,oCAAoC,CAAC,CAAA;IACvD,CAAC;IAED,MAAM,iBAAiB,GAAG,YAAY,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;IACrD,MAAM,uBAAuB,GAAG,kBAAkB,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;IACjE,MAAM,mBAAmB,GAAG,cAAc,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;IACzD,MAAM,cAAc,GAAG,SAAS,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;IAE/C,IAAI,KAAK,GAAG,CAAC,CAAA;IAEb,KAAK,IAAI,OAAO,CAAC,SAAS,CAAC,uBAAuB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA,CAAC,WAAW;IACtE,KAAK,IAAI,CAAC,iBAAiB,GAAG,CAAC,CAAC,IAAI,CAAC,CAAA,CAAC,WAAW;IACjD,KAAK,IAAI,CAAC,uBAAuB,GAAG,CAAC,CAAC,IAAI,CAAC,CAAA,CAAC,WAAW;IACvD,KAAK,IAAI,CAAC,mBAAmB,GAAG,CAAC,CAAC,IAAI,CAAC,CAAA,CAAC,WAAW;IACnD,KAAK,IAAI,CAAC,cAAc,GAAG,CAAC,CAAC,IAAI,CAAC,CAAA,CAAC,WAAW;IAE9C,uCAAuC;IACvC,IAAI,OAAO,CAAC,aAAa,EAAE,CAAC;QAC1B,KAAK,IAAI,CAAC,IAAI,CAAC,CAAA,CAAC,WAAW;IAC7B,CAAC;IAED,IAAI,MAAM,GAAgB,KAAK,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC,CAAA;IAE7C,4BAA4B;IAC5B,IAAI,OAAO,CAAC,aAAa,EAAE,CAAC;QAC1B,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;YAChC,MAAM,IAAI,KAAK,CAAC,2CAA2C,CAAC,CAAA;QAC9D,CAAC;QACD,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,OAAO,CAAC,YAAY,CAAC,OAAO,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAA;IACtF,CAAC;IAED,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,UAAU,CAAC,YAAY,CAAC,EAAE,iBAAiB,CAAC,CAAC,CAAA;IAC/F,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,iBAAiB,CAAC,CAAA;IAExD,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,UAAU,CAAC,OAAO,CAAC,cAAc,CAAC,MAAM,CAAC,EAAE,uBAAuB,CAAC,CAAC,CAAA;IACtH,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,IAAI,CAAC,IAAI,WAAW,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC,CAAC,CAAA;IAE3F,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,UAAU,CAAC,cAAc,CAAC,EAAE,mBAAmB,CAAC,CAAC,CAAA;IACnG,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE,cAAc,CAAC,CAAC,CAAA;IAEzF,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAA;IAC3D,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAA;IAE3D,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAA;IACjE,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAA;IAEjE,OAAO,MAAM,CAAA;AACf,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,SAAkB,EAAE,OAAyB;IAC5E,OAAO,YAAY,CAAC,MAAM,CAAC;QACzB,SAAS;QACT,SAAS,EAAE;YACT,CAAC,EAAE,GAAG,CAAC,QAAQ,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC;YACpC,CAAC,EAAE,GAAG,CAAC,QAAQ,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC;YACpC,MAAM,EAAE,CAAC;SACV;QACD,QAAQ,EAAE;YACR,iBAAiB,EAAE,GAAG,CAAC,SAAS,CAAC,OAAO,CAAC,iBAAiB,CAAC;YAC3D,cAAc,EAAE,OAAO,CAAC,cAAc,CAAC,OAAO,CAAC,aAAa,CAAC;YAC7D,cAAc,EAAE,OAAO,CAAC,cAAc;YACtC,SAAS,EAAE,OAAO,CAAC,cAAc,CAAC,OAAO,CAAC,QAAQ,CAAC;YACnD,wBAAwB,EAAE,OAAO,CAAC,SAAS,CAAC,uBAAuB;SACpE;QACD,SAAS,EAAE;YACT,CAAC,EAAE,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC;YAC5B,CAAC,EAAE,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC;SAC7B;KACF,CAAC,CAAA;AACJ,CAAC;AAED,MAAM,UAAU,MAAM,CAAC,IAAiB;IACtC,IAAI,MAAM,GAAG,CAAC,CAAA;IAEd,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,CAAA;IACrB,MAAM,IAAI,CAAC,CAAA;IAEX,IAAI,KAAK,KAAK,SAAS,EAAE,CAAC;QACxB,MAAM,IAAI,KAAK,CAAC,eAAe,CAAC,CAAA;IAClC,CAAC;IAED,MAAM,uBAAuB,GAAG,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,IAAI,CAAA;IACvD,MAAM,iBAAiB,GAAG,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAA;IACnD,MAAM,uBAAuB,GAAG,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAA;IACzD,MAAM,mBAAmB,GAAG,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAA;IACrD,MAAM,cAAc,GAAG,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAA;IAChD,MAAM,WAAW,GAAG,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,IAAI,CAAA;IAElD,4CAA4C;IAC5C,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;QACzB,MAAM,IAAI,KAAK,CAAC,gEAAgE,CAAC,CAAA;IACnF,CAAC;IAED,IAAI,QAA6B,CAAA;IAEjC,2BAA2B;IAC3B,IAAI,WAAW,EAAE,CAAC;QAChB,MAAM,aAAa,GAAG,KAAK,CAAC,KAAK,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,GAAG,EAAE,CAAC,CAAA;QAC5D,QAAQ,GAAG,GAAG,CAAC,SAAS,CAAC,aAAa,CAAC,CAAA;QACvC,MAAM,IAAI,EAAE,CAAA;IACd,CAAC;IAED,MAAM,YAAY,GAAG,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,GAAG,iBAAiB,CAAC,CAAC,CAAA;IAC1F,MAAM,IAAI,iBAAiB,CAAA;IAC3B,MAAM,iBAAiB,GAAG,KAAK,CAAC,KAAK,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,GAAG,YAAY,CAAC,CAAA;IAC1E,MAAM,IAAI,YAAY,CAAA;IAEtB,MAAM,kBAAkB,GAAG,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,GAAG,uBAAuB,CAAC,CAAC,CAAA;IACtG,MAAM,IAAI,uBAAuB,CAAA;IACjC,MAAM,mBAAmB,GAAG,KAAK,CAAC,KAAK,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,GAAG,kBAAkB,CAAC,CAAA;IAClF,MAAM,IAAI,kBAAkB,CAAA;IAC5B,MAAM,cAAc,GAAG,IAAI,WAAW,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC,CAAA;IAEpE,MAAM,cAAc,GAAG,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,GAAG,mBAAmB,CAAC,CAAC,CAAA;IAC9F,MAAM,IAAI,mBAAmB,CAAA;IAC7B,MAAM,SAAS,GAAG,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,GAAG,cAAc,CAAC,CAAC,CAAA;IACpF,MAAM,IAAI,cAAc,CAAA;IAExB,MAAM,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,GAAG,EAAE,CAAC,CAAA;IAChD,MAAM,IAAI,EAAE,CAAA;IACZ,MAAM,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,GAAG,EAAE,CAAC,CAAA;IAChD,MAAM,IAAI,EAAE,CAAA;IAEZ,MAAM,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,GAAG,EAAE,CAAC,CAAA;IACrD,MAAM,IAAI,EAAE,CAAA;IACZ,MAAM,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,GAAG,EAAE,CAAC,CAAA;IAErD,OAAO;QACL,SAAS,EAAE;YACT,uBAAuB;YACvB,CAAC,EAAE,GAAG,CAAC,SAAS,CAAC,MAAM,CAAC;YACxB,CAAC,EAAE,GAAG,CAAC,SAAS,CAAC,MAAM,CAAC;YACxB,QAAQ;SACT;QACD,CAAC;QACD,CAAC;QACD,iBAAiB;QACjB,cAAc;QACd,cAAc;QACd,SAAS;QACT,aAAa,EAAE,WAAW;KAC3B,CAAA;AACH,CAAC"}
|