@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.
Files changed (96) hide show
  1. package/.turbo/turbo-build.log +5 -0
  2. package/CHANGELOG.md +7 -0
  3. package/LICENSE +202 -0
  4. package/dist/address.d.ts +5 -0
  5. package/dist/address.d.ts.map +1 -0
  6. package/dist/address.js +7 -0
  7. package/dist/address.js.map +1 -0
  8. package/dist/attestation.d.ts +24 -0
  9. package/dist/attestation.d.ts.map +1 -0
  10. package/dist/attestation.js +77 -0
  11. package/dist/attestation.js.map +1 -0
  12. package/dist/config.d.ts +85 -0
  13. package/dist/config.d.ts.map +1 -0
  14. package/dist/config.js +381 -0
  15. package/dist/config.js.map +1 -0
  16. package/dist/constants.d.ts +173 -0
  17. package/dist/constants.d.ts.map +1 -0
  18. package/dist/constants.js +31 -0
  19. package/dist/constants.js.map +1 -0
  20. package/dist/context.d.ts +9 -0
  21. package/dist/context.d.ts.map +1 -0
  22. package/dist/context.js +8 -0
  23. package/dist/context.js.map +1 -0
  24. package/dist/erc-6492.d.ts +19 -0
  25. package/dist/erc-6492.d.ts.map +1 -0
  26. package/dist/erc-6492.js +64 -0
  27. package/dist/erc-6492.js.map +1 -0
  28. package/dist/extensions/index.d.ts +9 -0
  29. package/dist/extensions/index.d.ts.map +1 -0
  30. package/dist/extensions/index.js +7 -0
  31. package/dist/extensions/index.js.map +1 -0
  32. package/dist/extensions/passkeys.d.ts +31 -0
  33. package/dist/extensions/passkeys.d.ts.map +1 -0
  34. package/dist/extensions/passkeys.js +224 -0
  35. package/dist/extensions/passkeys.js.map +1 -0
  36. package/dist/extensions/recovery.d.ts +310 -0
  37. package/dist/extensions/recovery.d.ts.map +1 -0
  38. package/dist/extensions/recovery.js +444 -0
  39. package/dist/extensions/recovery.js.map +1 -0
  40. package/dist/generic-tree.d.ts +14 -0
  41. package/dist/generic-tree.d.ts.map +1 -0
  42. package/dist/generic-tree.js +34 -0
  43. package/dist/generic-tree.js.map +1 -0
  44. package/dist/index.d.ts +16 -0
  45. package/dist/index.d.ts.map +1 -0
  46. package/dist/index.js +16 -0
  47. package/dist/index.js.map +1 -0
  48. package/dist/network.d.ts +15 -0
  49. package/dist/network.d.ts.map +1 -0
  50. package/dist/network.js +24 -0
  51. package/dist/network.js.map +1 -0
  52. package/dist/payload.d.ts +108 -0
  53. package/dist/payload.d.ts.map +1 -0
  54. package/dist/payload.js +627 -0
  55. package/dist/payload.js.map +1 -0
  56. package/dist/permission.d.ts +73 -0
  57. package/dist/permission.d.ts.map +1 -0
  58. package/dist/permission.js +188 -0
  59. package/dist/permission.js.map +1 -0
  60. package/dist/session-config.d.ts +113 -0
  61. package/dist/session-config.d.ts.map +1 -0
  62. package/dist/session-config.js +554 -0
  63. package/dist/session-config.js.map +1 -0
  64. package/dist/session-signature.d.ts +24 -0
  65. package/dist/session-signature.d.ts.map +1 -0
  66. package/dist/session-signature.js +141 -0
  67. package/dist/session-signature.js.map +1 -0
  68. package/dist/signature.d.ts +108 -0
  69. package/dist/signature.d.ts.map +1 -0
  70. package/dist/signature.js +1079 -0
  71. package/dist/signature.js.map +1 -0
  72. package/dist/utils.d.ts +45 -0
  73. package/dist/utils.d.ts.map +1 -0
  74. package/dist/utils.js +100 -0
  75. package/dist/utils.js.map +1 -0
  76. package/eslint.config.mjs +4 -0
  77. package/package.json +27 -0
  78. package/src/address.ts +19 -0
  79. package/src/attestation.ts +114 -0
  80. package/src/config.ts +521 -0
  81. package/src/constants.ts +39 -0
  82. package/src/context.ts +16 -0
  83. package/src/erc-6492.ts +97 -0
  84. package/src/extensions/index.ts +14 -0
  85. package/src/extensions/passkeys.ts +283 -0
  86. package/src/extensions/recovery.ts +542 -0
  87. package/src/generic-tree.ts +55 -0
  88. package/src/index.ts +15 -0
  89. package/src/network.ts +37 -0
  90. package/src/payload.ts +825 -0
  91. package/src/permission.ts +252 -0
  92. package/src/session-config.ts +681 -0
  93. package/src/session-signature.ts +197 -0
  94. package/src/signature.ts +1398 -0
  95. package/src/utils.ts +114 -0
  96. 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"}
@@ -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":"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"}