@actioncodes/protocol 2.0.10 → 2.0.11

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js.map CHANGED
@@ -9,17 +9,17 @@
9
9
  "/**\n * SHA2 hash function. A.k.a. sha256, sha384, sha512, sha512_224, sha512_256.\n * SHA256 is the fastest hash implementable in JS, even faster than Blake3.\n * Check out [RFC 4634](https://www.rfc-editor.org/rfc/rfc4634) and\n * [FIPS 180-4](https://nvlpubs.nist.gov/nistpubs/FIPS/NIST.FIPS.180-4.pdf).\n * @module\n */\nimport { Chi, HashMD, Maj, SHA224_IV, SHA256_IV, SHA384_IV, SHA512_IV } from \"./_md.js\";\nimport * as u64 from \"./_u64.js\";\nimport { clean, createHasher, oidNist, rotr } from \"./utils.js\";\n/**\n * Round constants:\n * First 32 bits of fractional parts of the cube roots of the first 64 primes 2..311)\n */\n// prettier-ignore\nconst SHA256_K = /* @__PURE__ */ Uint32Array.from([\n 0x428a2f98, 0x71374491, 0xb5c0fbcf, 0xe9b5dba5, 0x3956c25b, 0x59f111f1, 0x923f82a4, 0xab1c5ed5,\n 0xd807aa98, 0x12835b01, 0x243185be, 0x550c7dc3, 0x72be5d74, 0x80deb1fe, 0x9bdc06a7, 0xc19bf174,\n 0xe49b69c1, 0xefbe4786, 0x0fc19dc6, 0x240ca1cc, 0x2de92c6f, 0x4a7484aa, 0x5cb0a9dc, 0x76f988da,\n 0x983e5152, 0xa831c66d, 0xb00327c8, 0xbf597fc7, 0xc6e00bf3, 0xd5a79147, 0x06ca6351, 0x14292967,\n 0x27b70a85, 0x2e1b2138, 0x4d2c6dfc, 0x53380d13, 0x650a7354, 0x766a0abb, 0x81c2c92e, 0x92722c85,\n 0xa2bfe8a1, 0xa81a664b, 0xc24b8b70, 0xc76c51a3, 0xd192e819, 0xd6990624, 0xf40e3585, 0x106aa070,\n 0x19a4c116, 0x1e376c08, 0x2748774c, 0x34b0bcb5, 0x391c0cb3, 0x4ed8aa4a, 0x5b9cca4f, 0x682e6ff3,\n 0x748f82ee, 0x78a5636f, 0x84c87814, 0x8cc70208, 0x90befffa, 0xa4506ceb, 0xbef9a3f7, 0xc67178f2\n]);\n/** Reusable temporary buffer. \"W\" comes straight from spec. */\nconst SHA256_W = /* @__PURE__ */ new Uint32Array(64);\n/** Internal 32-byte base SHA2 hash class. */\nclass SHA2_32B extends HashMD {\n constructor(outputLen) {\n super(64, outputLen, 8, false);\n }\n get() {\n const { A, B, C, D, E, F, G, H } = this;\n return [A, B, C, D, E, F, G, H];\n }\n // prettier-ignore\n set(A, B, C, D, E, F, G, H) {\n this.A = A | 0;\n this.B = B | 0;\n this.C = C | 0;\n this.D = D | 0;\n this.E = E | 0;\n this.F = F | 0;\n this.G = G | 0;\n this.H = H | 0;\n }\n process(view, offset) {\n // Extend the first 16 words into the remaining 48 words w[16..63] of the message schedule array\n for (let i = 0; i < 16; i++, offset += 4)\n SHA256_W[i] = view.getUint32(offset, false);\n for (let i = 16; i < 64; i++) {\n const W15 = SHA256_W[i - 15];\n const W2 = SHA256_W[i - 2];\n const s0 = rotr(W15, 7) ^ rotr(W15, 18) ^ (W15 >>> 3);\n const s1 = rotr(W2, 17) ^ rotr(W2, 19) ^ (W2 >>> 10);\n SHA256_W[i] = (s1 + SHA256_W[i - 7] + s0 + SHA256_W[i - 16]) | 0;\n }\n // Compression function main loop, 64 rounds\n let { A, B, C, D, E, F, G, H } = this;\n for (let i = 0; i < 64; i++) {\n const sigma1 = rotr(E, 6) ^ rotr(E, 11) ^ rotr(E, 25);\n const T1 = (H + sigma1 + Chi(E, F, G) + SHA256_K[i] + SHA256_W[i]) | 0;\n const sigma0 = rotr(A, 2) ^ rotr(A, 13) ^ rotr(A, 22);\n const T2 = (sigma0 + Maj(A, B, C)) | 0;\n H = G;\n G = F;\n F = E;\n E = (D + T1) | 0;\n D = C;\n C = B;\n B = A;\n A = (T1 + T2) | 0;\n }\n // Add the compressed chunk to the current hash value\n A = (A + this.A) | 0;\n B = (B + this.B) | 0;\n C = (C + this.C) | 0;\n D = (D + this.D) | 0;\n E = (E + this.E) | 0;\n F = (F + this.F) | 0;\n G = (G + this.G) | 0;\n H = (H + this.H) | 0;\n this.set(A, B, C, D, E, F, G, H);\n }\n roundClean() {\n clean(SHA256_W);\n }\n destroy() {\n this.set(0, 0, 0, 0, 0, 0, 0, 0);\n clean(this.buffer);\n }\n}\n/** Internal SHA2-256 hash class. */\nexport class _SHA256 extends SHA2_32B {\n // We cannot use array here since array allows indexing by variable\n // which means optimizer/compiler cannot use registers.\n A = SHA256_IV[0] | 0;\n B = SHA256_IV[1] | 0;\n C = SHA256_IV[2] | 0;\n D = SHA256_IV[3] | 0;\n E = SHA256_IV[4] | 0;\n F = SHA256_IV[5] | 0;\n G = SHA256_IV[6] | 0;\n H = SHA256_IV[7] | 0;\n constructor() {\n super(32);\n }\n}\n/** Internal SHA2-224 hash class. */\nexport class _SHA224 extends SHA2_32B {\n A = SHA224_IV[0] | 0;\n B = SHA224_IV[1] | 0;\n C = SHA224_IV[2] | 0;\n D = SHA224_IV[3] | 0;\n E = SHA224_IV[4] | 0;\n F = SHA224_IV[5] | 0;\n G = SHA224_IV[6] | 0;\n H = SHA224_IV[7] | 0;\n constructor() {\n super(28);\n }\n}\n// SHA2-512 is slower than sha256 in js because u64 operations are slow.\n// Round contants\n// First 32 bits of the fractional parts of the cube roots of the first 80 primes 2..409\n// prettier-ignore\nconst K512 = /* @__PURE__ */ (() => u64.split([\n '0x428a2f98d728ae22', '0x7137449123ef65cd', '0xb5c0fbcfec4d3b2f', '0xe9b5dba58189dbbc',\n '0x3956c25bf348b538', '0x59f111f1b605d019', '0x923f82a4af194f9b', '0xab1c5ed5da6d8118',\n '0xd807aa98a3030242', '0x12835b0145706fbe', '0x243185be4ee4b28c', '0x550c7dc3d5ffb4e2',\n '0x72be5d74f27b896f', '0x80deb1fe3b1696b1', '0x9bdc06a725c71235', '0xc19bf174cf692694',\n '0xe49b69c19ef14ad2', '0xefbe4786384f25e3', '0x0fc19dc68b8cd5b5', '0x240ca1cc77ac9c65',\n '0x2de92c6f592b0275', '0x4a7484aa6ea6e483', '0x5cb0a9dcbd41fbd4', '0x76f988da831153b5',\n '0x983e5152ee66dfab', '0xa831c66d2db43210', '0xb00327c898fb213f', '0xbf597fc7beef0ee4',\n '0xc6e00bf33da88fc2', '0xd5a79147930aa725', '0x06ca6351e003826f', '0x142929670a0e6e70',\n '0x27b70a8546d22ffc', '0x2e1b21385c26c926', '0x4d2c6dfc5ac42aed', '0x53380d139d95b3df',\n '0x650a73548baf63de', '0x766a0abb3c77b2a8', '0x81c2c92e47edaee6', '0x92722c851482353b',\n '0xa2bfe8a14cf10364', '0xa81a664bbc423001', '0xc24b8b70d0f89791', '0xc76c51a30654be30',\n '0xd192e819d6ef5218', '0xd69906245565a910', '0xf40e35855771202a', '0x106aa07032bbd1b8',\n '0x19a4c116b8d2d0c8', '0x1e376c085141ab53', '0x2748774cdf8eeb99', '0x34b0bcb5e19b48a8',\n '0x391c0cb3c5c95a63', '0x4ed8aa4ae3418acb', '0x5b9cca4f7763e373', '0x682e6ff3d6b2b8a3',\n '0x748f82ee5defb2fc', '0x78a5636f43172f60', '0x84c87814a1f0ab72', '0x8cc702081a6439ec',\n '0x90befffa23631e28', '0xa4506cebde82bde9', '0xbef9a3f7b2c67915', '0xc67178f2e372532b',\n '0xca273eceea26619c', '0xd186b8c721c0c207', '0xeada7dd6cde0eb1e', '0xf57d4f7fee6ed178',\n '0x06f067aa72176fba', '0x0a637dc5a2c898a6', '0x113f9804bef90dae', '0x1b710b35131c471b',\n '0x28db77f523047d84', '0x32caab7b40c72493', '0x3c9ebe0a15c9bebc', '0x431d67c49c100d4c',\n '0x4cc5d4becb3e42b6', '0x597f299cfc657e2a', '0x5fcb6fab3ad6faec', '0x6c44198c4a475817'\n].map(n => BigInt(n))))();\nconst SHA512_Kh = /* @__PURE__ */ (() => K512[0])();\nconst SHA512_Kl = /* @__PURE__ */ (() => K512[1])();\n// Reusable temporary buffers\nconst SHA512_W_H = /* @__PURE__ */ new Uint32Array(80);\nconst SHA512_W_L = /* @__PURE__ */ new Uint32Array(80);\n/** Internal 64-byte base SHA2 hash class. */\nclass SHA2_64B extends HashMD {\n constructor(outputLen) {\n super(128, outputLen, 16, false);\n }\n // prettier-ignore\n get() {\n const { Ah, Al, Bh, Bl, Ch, Cl, Dh, Dl, Eh, El, Fh, Fl, Gh, Gl, Hh, Hl } = this;\n return [Ah, Al, Bh, Bl, Ch, Cl, Dh, Dl, Eh, El, Fh, Fl, Gh, Gl, Hh, Hl];\n }\n // prettier-ignore\n set(Ah, Al, Bh, Bl, Ch, Cl, Dh, Dl, Eh, El, Fh, Fl, Gh, Gl, Hh, Hl) {\n this.Ah = Ah | 0;\n this.Al = Al | 0;\n this.Bh = Bh | 0;\n this.Bl = Bl | 0;\n this.Ch = Ch | 0;\n this.Cl = Cl | 0;\n this.Dh = Dh | 0;\n this.Dl = Dl | 0;\n this.Eh = Eh | 0;\n this.El = El | 0;\n this.Fh = Fh | 0;\n this.Fl = Fl | 0;\n this.Gh = Gh | 0;\n this.Gl = Gl | 0;\n this.Hh = Hh | 0;\n this.Hl = Hl | 0;\n }\n process(view, offset) {\n // Extend the first 16 words into the remaining 64 words w[16..79] of the message schedule array\n for (let i = 0; i < 16; i++, offset += 4) {\n SHA512_W_H[i] = view.getUint32(offset);\n SHA512_W_L[i] = view.getUint32((offset += 4));\n }\n for (let i = 16; i < 80; i++) {\n // s0 := (w[i-15] rightrotate 1) xor (w[i-15] rightrotate 8) xor (w[i-15] rightshift 7)\n const W15h = SHA512_W_H[i - 15] | 0;\n const W15l = SHA512_W_L[i - 15] | 0;\n const s0h = u64.rotrSH(W15h, W15l, 1) ^ u64.rotrSH(W15h, W15l, 8) ^ u64.shrSH(W15h, W15l, 7);\n const s0l = u64.rotrSL(W15h, W15l, 1) ^ u64.rotrSL(W15h, W15l, 8) ^ u64.shrSL(W15h, W15l, 7);\n // s1 := (w[i-2] rightrotate 19) xor (w[i-2] rightrotate 61) xor (w[i-2] rightshift 6)\n const W2h = SHA512_W_H[i - 2] | 0;\n const W2l = SHA512_W_L[i - 2] | 0;\n const s1h = u64.rotrSH(W2h, W2l, 19) ^ u64.rotrBH(W2h, W2l, 61) ^ u64.shrSH(W2h, W2l, 6);\n const s1l = u64.rotrSL(W2h, W2l, 19) ^ u64.rotrBL(W2h, W2l, 61) ^ u64.shrSL(W2h, W2l, 6);\n // SHA256_W[i] = s0 + s1 + SHA256_W[i - 7] + SHA256_W[i - 16];\n const SUMl = u64.add4L(s0l, s1l, SHA512_W_L[i - 7], SHA512_W_L[i - 16]);\n const SUMh = u64.add4H(SUMl, s0h, s1h, SHA512_W_H[i - 7], SHA512_W_H[i - 16]);\n SHA512_W_H[i] = SUMh | 0;\n SHA512_W_L[i] = SUMl | 0;\n }\n let { Ah, Al, Bh, Bl, Ch, Cl, Dh, Dl, Eh, El, Fh, Fl, Gh, Gl, Hh, Hl } = this;\n // Compression function main loop, 80 rounds\n for (let i = 0; i < 80; i++) {\n // S1 := (e rightrotate 14) xor (e rightrotate 18) xor (e rightrotate 41)\n const sigma1h = u64.rotrSH(Eh, El, 14) ^ u64.rotrSH(Eh, El, 18) ^ u64.rotrBH(Eh, El, 41);\n const sigma1l = u64.rotrSL(Eh, El, 14) ^ u64.rotrSL(Eh, El, 18) ^ u64.rotrBL(Eh, El, 41);\n //const T1 = (H + sigma1 + Chi(E, F, G) + SHA256_K[i] + SHA256_W[i]) | 0;\n const CHIh = (Eh & Fh) ^ (~Eh & Gh);\n const CHIl = (El & Fl) ^ (~El & Gl);\n // T1 = H + sigma1 + Chi(E, F, G) + SHA512_K[i] + SHA512_W[i]\n // prettier-ignore\n const T1ll = u64.add5L(Hl, sigma1l, CHIl, SHA512_Kl[i], SHA512_W_L[i]);\n const T1h = u64.add5H(T1ll, Hh, sigma1h, CHIh, SHA512_Kh[i], SHA512_W_H[i]);\n const T1l = T1ll | 0;\n // S0 := (a rightrotate 28) xor (a rightrotate 34) xor (a rightrotate 39)\n const sigma0h = u64.rotrSH(Ah, Al, 28) ^ u64.rotrBH(Ah, Al, 34) ^ u64.rotrBH(Ah, Al, 39);\n const sigma0l = u64.rotrSL(Ah, Al, 28) ^ u64.rotrBL(Ah, Al, 34) ^ u64.rotrBL(Ah, Al, 39);\n const MAJh = (Ah & Bh) ^ (Ah & Ch) ^ (Bh & Ch);\n const MAJl = (Al & Bl) ^ (Al & Cl) ^ (Bl & Cl);\n Hh = Gh | 0;\n Hl = Gl | 0;\n Gh = Fh | 0;\n Gl = Fl | 0;\n Fh = Eh | 0;\n Fl = El | 0;\n ({ h: Eh, l: El } = u64.add(Dh | 0, Dl | 0, T1h | 0, T1l | 0));\n Dh = Ch | 0;\n Dl = Cl | 0;\n Ch = Bh | 0;\n Cl = Bl | 0;\n Bh = Ah | 0;\n Bl = Al | 0;\n const All = u64.add3L(T1l, sigma0l, MAJl);\n Ah = u64.add3H(All, T1h, sigma0h, MAJh);\n Al = All | 0;\n }\n // Add the compressed chunk to the current hash value\n ({ h: Ah, l: Al } = u64.add(this.Ah | 0, this.Al | 0, Ah | 0, Al | 0));\n ({ h: Bh, l: Bl } = u64.add(this.Bh | 0, this.Bl | 0, Bh | 0, Bl | 0));\n ({ h: Ch, l: Cl } = u64.add(this.Ch | 0, this.Cl | 0, Ch | 0, Cl | 0));\n ({ h: Dh, l: Dl } = u64.add(this.Dh | 0, this.Dl | 0, Dh | 0, Dl | 0));\n ({ h: Eh, l: El } = u64.add(this.Eh | 0, this.El | 0, Eh | 0, El | 0));\n ({ h: Fh, l: Fl } = u64.add(this.Fh | 0, this.Fl | 0, Fh | 0, Fl | 0));\n ({ h: Gh, l: Gl } = u64.add(this.Gh | 0, this.Gl | 0, Gh | 0, Gl | 0));\n ({ h: Hh, l: Hl } = u64.add(this.Hh | 0, this.Hl | 0, Hh | 0, Hl | 0));\n this.set(Ah, Al, Bh, Bl, Ch, Cl, Dh, Dl, Eh, El, Fh, Fl, Gh, Gl, Hh, Hl);\n }\n roundClean() {\n clean(SHA512_W_H, SHA512_W_L);\n }\n destroy() {\n clean(this.buffer);\n this.set(0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0);\n }\n}\n/** Internal SHA2-512 hash class. */\nexport class _SHA512 extends SHA2_64B {\n Ah = SHA512_IV[0] | 0;\n Al = SHA512_IV[1] | 0;\n Bh = SHA512_IV[2] | 0;\n Bl = SHA512_IV[3] | 0;\n Ch = SHA512_IV[4] | 0;\n Cl = SHA512_IV[5] | 0;\n Dh = SHA512_IV[6] | 0;\n Dl = SHA512_IV[7] | 0;\n Eh = SHA512_IV[8] | 0;\n El = SHA512_IV[9] | 0;\n Fh = SHA512_IV[10] | 0;\n Fl = SHA512_IV[11] | 0;\n Gh = SHA512_IV[12] | 0;\n Gl = SHA512_IV[13] | 0;\n Hh = SHA512_IV[14] | 0;\n Hl = SHA512_IV[15] | 0;\n constructor() {\n super(64);\n }\n}\n/** Internal SHA2-384 hash class. */\nexport class _SHA384 extends SHA2_64B {\n Ah = SHA384_IV[0] | 0;\n Al = SHA384_IV[1] | 0;\n Bh = SHA384_IV[2] | 0;\n Bl = SHA384_IV[3] | 0;\n Ch = SHA384_IV[4] | 0;\n Cl = SHA384_IV[5] | 0;\n Dh = SHA384_IV[6] | 0;\n Dl = SHA384_IV[7] | 0;\n Eh = SHA384_IV[8] | 0;\n El = SHA384_IV[9] | 0;\n Fh = SHA384_IV[10] | 0;\n Fl = SHA384_IV[11] | 0;\n Gh = SHA384_IV[12] | 0;\n Gl = SHA384_IV[13] | 0;\n Hh = SHA384_IV[14] | 0;\n Hl = SHA384_IV[15] | 0;\n constructor() {\n super(48);\n }\n}\n/**\n * Truncated SHA512/256 and SHA512/224.\n * SHA512_IV is XORed with 0xa5a5a5a5a5a5a5a5, then used as \"intermediary\" IV of SHA512/t.\n * Then t hashes string to produce result IV.\n * See `test/misc/sha2-gen-iv.js`.\n */\n/** SHA512/224 IV */\nconst T224_IV = /* @__PURE__ */ Uint32Array.from([\n 0x8c3d37c8, 0x19544da2, 0x73e19966, 0x89dcd4d6, 0x1dfab7ae, 0x32ff9c82, 0x679dd514, 0x582f9fcf,\n 0x0f6d2b69, 0x7bd44da8, 0x77e36f73, 0x04c48942, 0x3f9d85a8, 0x6a1d36c8, 0x1112e6ad, 0x91d692a1,\n]);\n/** SHA512/256 IV */\nconst T256_IV = /* @__PURE__ */ Uint32Array.from([\n 0x22312194, 0xfc2bf72c, 0x9f555fa3, 0xc84c64c2, 0x2393b86b, 0x6f53b151, 0x96387719, 0x5940eabd,\n 0x96283ee2, 0xa88effe3, 0xbe5e1e25, 0x53863992, 0x2b0199fc, 0x2c85b8aa, 0x0eb72ddc, 0x81c52ca2,\n]);\n/** Internal SHA2-512/224 hash class. */\nexport class _SHA512_224 extends SHA2_64B {\n Ah = T224_IV[0] | 0;\n Al = T224_IV[1] | 0;\n Bh = T224_IV[2] | 0;\n Bl = T224_IV[3] | 0;\n Ch = T224_IV[4] | 0;\n Cl = T224_IV[5] | 0;\n Dh = T224_IV[6] | 0;\n Dl = T224_IV[7] | 0;\n Eh = T224_IV[8] | 0;\n El = T224_IV[9] | 0;\n Fh = T224_IV[10] | 0;\n Fl = T224_IV[11] | 0;\n Gh = T224_IV[12] | 0;\n Gl = T224_IV[13] | 0;\n Hh = T224_IV[14] | 0;\n Hl = T224_IV[15] | 0;\n constructor() {\n super(28);\n }\n}\n/** Internal SHA2-512/256 hash class. */\nexport class _SHA512_256 extends SHA2_64B {\n Ah = T256_IV[0] | 0;\n Al = T256_IV[1] | 0;\n Bh = T256_IV[2] | 0;\n Bl = T256_IV[3] | 0;\n Ch = T256_IV[4] | 0;\n Cl = T256_IV[5] | 0;\n Dh = T256_IV[6] | 0;\n Dl = T256_IV[7] | 0;\n Eh = T256_IV[8] | 0;\n El = T256_IV[9] | 0;\n Fh = T256_IV[10] | 0;\n Fl = T256_IV[11] | 0;\n Gh = T256_IV[12] | 0;\n Gl = T256_IV[13] | 0;\n Hh = T256_IV[14] | 0;\n Hl = T256_IV[15] | 0;\n constructor() {\n super(32);\n }\n}\n/**\n * SHA2-256 hash function from RFC 4634. In JS it's the fastest: even faster than Blake3. Some info:\n *\n * - Trying 2^128 hashes would get 50% chance of collision, using birthday attack.\n * - BTC network is doing 2^70 hashes/sec (2^95 hashes/year) as per 2025.\n * - Each sha256 hash is executing 2^18 bit operations.\n * - Good 2024 ASICs can do 200Th/sec with 3500 watts of power, corresponding to 2^36 hashes/joule.\n */\nexport const sha256 = /* @__PURE__ */ createHasher(() => new _SHA256(), \n/* @__PURE__ */ oidNist(0x01));\n/** SHA2-224 hash function from RFC 4634 */\nexport const sha224 = /* @__PURE__ */ createHasher(() => new _SHA224(), \n/* @__PURE__ */ oidNist(0x04));\n/** SHA2-512 hash function from RFC 4634. */\nexport const sha512 = /* @__PURE__ */ createHasher(() => new _SHA512(), \n/* @__PURE__ */ oidNist(0x03));\n/** SHA2-384 hash function from RFC 4634. */\nexport const sha384 = /* @__PURE__ */ createHasher(() => new _SHA384(), \n/* @__PURE__ */ oidNist(0x02));\n/**\n * SHA2-512/256 \"truncated\" hash function, with improved resistance to length extension attacks.\n * See the paper on [truncated SHA512](https://eprint.iacr.org/2010/548.pdf).\n */\nexport const sha512_256 = /* @__PURE__ */ createHasher(() => new _SHA512_256(), \n/* @__PURE__ */ oidNist(0x06));\n/**\n * SHA2-512/224 \"truncated\" hash function, with improved resistance to length extension attacks.\n * See the paper on [truncated SHA512](https://eprint.iacr.org/2010/548.pdf).\n */\nexport const sha512_224 = /* @__PURE__ */ createHasher(() => new _SHA512_224(), \n/* @__PURE__ */ oidNist(0x05));\n//# sourceMappingURL=sha2.js.map",
10
10
  "/**\n * HMAC: RFC2104 message authentication code.\n * @module\n */\nimport { abytes, aexists, ahash, clean } from \"./utils.js\";\n/** Internal class for HMAC. */\nexport class _HMAC {\n oHash;\n iHash;\n blockLen;\n outputLen;\n finished = false;\n destroyed = false;\n constructor(hash, key) {\n ahash(hash);\n abytes(key, undefined, 'key');\n this.iHash = hash.create();\n if (typeof this.iHash.update !== 'function')\n throw new Error('Expected instance of class which extends utils.Hash');\n this.blockLen = this.iHash.blockLen;\n this.outputLen = this.iHash.outputLen;\n const blockLen = this.blockLen;\n const pad = new Uint8Array(blockLen);\n // blockLen can be bigger than outputLen\n pad.set(key.length > blockLen ? hash.create().update(key).digest() : key);\n for (let i = 0; i < pad.length; i++)\n pad[i] ^= 0x36;\n this.iHash.update(pad);\n // By doing update (processing of first block) of outer hash here we can re-use it between multiple calls via clone\n this.oHash = hash.create();\n // Undo internal XOR && apply outer XOR\n for (let i = 0; i < pad.length; i++)\n pad[i] ^= 0x36 ^ 0x5c;\n this.oHash.update(pad);\n clean(pad);\n }\n update(buf) {\n aexists(this);\n this.iHash.update(buf);\n return this;\n }\n digestInto(out) {\n aexists(this);\n abytes(out, this.outputLen, 'output');\n this.finished = true;\n this.iHash.digestInto(out);\n this.oHash.update(out);\n this.oHash.digestInto(out);\n this.destroy();\n }\n digest() {\n const out = new Uint8Array(this.oHash.outputLen);\n this.digestInto(out);\n return out;\n }\n _cloneInto(to) {\n // Create new instance without calling constructor since key already in state and we don't know it.\n to ||= Object.create(Object.getPrototypeOf(this), {});\n const { oHash, iHash, finished, destroyed, blockLen, outputLen } = this;\n to = to;\n to.finished = finished;\n to.destroyed = destroyed;\n to.blockLen = blockLen;\n to.outputLen = outputLen;\n to.oHash = oHash._cloneInto(to.oHash);\n to.iHash = iHash._cloneInto(to.iHash);\n return to;\n }\n clone() {\n return this._cloneInto();\n }\n destroy() {\n this.destroyed = true;\n this.oHash.destroy();\n this.iHash.destroy();\n }\n}\n/**\n * HMAC: RFC2104 message authentication code.\n * @param hash - function that would be used e.g. sha256\n * @param key - message key\n * @param message - message data\n * @example\n * import { hmac } from '@noble/hashes/hmac';\n * import { sha256 } from '@noble/hashes/sha2';\n * const mac1 = hmac(sha256, 'key', 'message');\n */\nexport const hmac = (hash, key, message) => new _HMAC(hash, key).update(message).digest();\nhmac.create = (hash, key) => new _HMAC(hash, key);\n//# sourceMappingURL=hmac.js.map",
11
11
  "/**\n * HKDF (RFC 5869): extract + expand in one step.\n * See https://soatok.blog/2021/11/17/understanding-hkdf/.\n * @module\n */\nimport { hmac } from \"./hmac.js\";\nimport { abytes, ahash, anumber, clean } from \"./utils.js\";\n/**\n * HKDF-extract from spec. Less important part. `HKDF-Extract(IKM, salt) -> PRK`\n * Arguments position differs from spec (IKM is first one, since it is not optional)\n * @param hash - hash function that would be used (e.g. sha256)\n * @param ikm - input keying material, the initial key\n * @param salt - optional salt value (a non-secret random value)\n */\nexport function extract(hash, ikm, salt) {\n ahash(hash);\n // NOTE: some libraries treat zero-length array as 'not provided';\n // we don't, since we have undefined as 'not provided'\n // https://github.com/RustCrypto/KDFs/issues/15\n if (salt === undefined)\n salt = new Uint8Array(hash.outputLen);\n return hmac(hash, salt, ikm);\n}\nconst HKDF_COUNTER = /* @__PURE__ */ Uint8Array.of(0);\nconst EMPTY_BUFFER = /* @__PURE__ */ Uint8Array.of();\n/**\n * HKDF-expand from the spec. The most important part. `HKDF-Expand(PRK, info, L) -> OKM`\n * @param hash - hash function that would be used (e.g. sha256)\n * @param prk - a pseudorandom key of at least HashLen octets (usually, the output from the extract step)\n * @param info - optional context and application specific information (can be a zero-length string)\n * @param length - length of output keying material in bytes\n */\nexport function expand(hash, prk, info, length = 32) {\n ahash(hash);\n anumber(length, 'length');\n const olen = hash.outputLen;\n if (length > 255 * olen)\n throw new Error('Length must be <= 255*HashLen');\n const blocks = Math.ceil(length / olen);\n if (info === undefined)\n info = EMPTY_BUFFER;\n else\n abytes(info, undefined, 'info');\n // first L(ength) octets of T\n const okm = new Uint8Array(blocks * olen);\n // Re-use HMAC instance between blocks\n const HMAC = hmac.create(hash, prk);\n const HMACTmp = HMAC._cloneInto();\n const T = new Uint8Array(HMAC.outputLen);\n for (let counter = 0; counter < blocks; counter++) {\n HKDF_COUNTER[0] = counter + 1;\n // T(0) = empty string (zero length)\n // T(N) = HMAC-Hash(PRK, T(N-1) | info | N)\n HMACTmp.update(counter === 0 ? EMPTY_BUFFER : T)\n .update(info)\n .update(HKDF_COUNTER)\n .digestInto(T);\n okm.set(T, olen * counter);\n HMAC._cloneInto(HMACTmp);\n }\n HMAC.destroy();\n HMACTmp.destroy();\n clean(T, HKDF_COUNTER);\n return okm.slice(0, length);\n}\n/**\n * HKDF (RFC 5869): derive keys from an initial input.\n * Combines hkdf_extract + hkdf_expand in one step\n * @param hash - hash function that would be used (e.g. sha256)\n * @param ikm - input keying material, the initial key\n * @param salt - optional salt value (a non-secret random value)\n * @param info - optional context and application specific information (can be a zero-length string)\n * @param length - length of output keying material in bytes\n * @example\n * import { hkdf } from '@noble/hashes/hkdf';\n * import { sha256 } from '@noble/hashes/sha2';\n * import { randomBytes } from '@noble/hashes/utils';\n * const inputKey = randomBytes(32);\n * const salt = randomBytes(32);\n * const info = 'application-key';\n * const hk1 = hkdf(sha256, inputKey, salt, info, 32);\n */\nexport const hkdf = (hash, ikm, salt, info, length) => expand(hash, extract(hash, ikm, salt), info, length);\n//# sourceMappingURL=hkdf.js.map",
12
- "import { sha256 as nobleSha256 } from \"@noble/hashes/sha2.js\";\nimport { hmac } from \"@noble/hashes/hmac.js\";\nimport { hkdf } from \"@noble/hashes/hkdf.js\";\n\nfunction toBytes(input: Uint8Array | string): Uint8Array {\n if (typeof input === \"string\") return new TextEncoder().encode(input);\n return input;\n}\n\nexport function sha256(data: Uint8Array | string): Uint8Array {\n return nobleSha256(toBytes(data));\n}\n\nexport function hmacSha256(\n key: Uint8Array | string,\n data: Uint8Array | string\n): Uint8Array {\n return hmac(nobleSha256, toBytes(key), toBytes(data));\n}\n\n// HKDF implementation using @noble/hashes\nexport function hkdfSha256(\n ikm: Uint8Array | string,\n length: number,\n {\n salt,\n info,\n }: { salt?: Uint8Array | string; info?: Uint8Array | string } = {}\n): Uint8Array {\n const saltBuf = salt ? toBytes(salt) : new Uint8Array(32);\n const ikmBuf = toBytes(ikm);\n const infoBuf = info ? toBytes(info) : new Uint8Array(0);\n\n return hkdf(nobleSha256, ikmBuf, saltBuf, infoBuf, length);\n}\n\n// Crockford Base32 without lookalikes (I L O U mapped) – output uppercase\nconst CROCKFORD_ALPHABET = \"0123456789ABCDEFGHJKMNPQRSTVWXYZ\";\n\nexport function base32EncodeCrockford(data: Uint8Array): string {\n let bits = 0;\n let value = 0;\n let output = \"\";\n for (let i = 0; i < data.length; i++) {\n value = (value << 8) | data[i]!;\n bits += 8;\n while (bits >= 5) {\n output += CROCKFORD_ALPHABET[(value >>> (bits - 5)) & 31];\n bits -= 5;\n }\n }\n if (bits > 0) {\n output += CROCKFORD_ALPHABET[(value << (5 - bits)) & 31];\n }\n return output;\n}\n\nexport function truncateBits(input: Uint8Array, totalBits: number): Uint8Array {\n const totalBytes = Math.ceil(totalBits / 8);\n const out = new Uint8Array(totalBytes);\n const copyBytes = Math.min(totalBytes, input.length);\n out.set(input.subarray(0, copyBytes));\n // If not byte-aligned, mask the last byte\n const extraBits = totalBytes * 8 - totalBits;\n if (extraBits > 0) {\n const mask = 0xff << extraBits;\n out[totalBytes - 1] = out[totalBytes - 1]! & mask;\n }\n return out;\n}\n\n// Derive digits-only code from a digest using modulo bias-reduction (HOTP-style per-digit)\nexport function digestToDigits(digest: Uint8Array, length: number): string {\n if (digest.length === 0) throw new Error(\"digestToDigits: empty digest\");\n // HOTP-like dynamic truncation for unbiased decimal extraction\n // Process 4 bytes windows to produce digits\n let out = \"\";\n const offset = digest[digest.length - 1]! & 0x0f;\n for (let i = 0; out.length < length; i++) {\n const idx = (offset + i * 4) % Math.max(1, digest.length - 4);\n const p =\n ((digest[idx]! & 0x7f) << 24) |\n (digest[idx + 1]! << 16) |\n (digest[idx + 2]! << 8) |\n digest[idx + 3]!;\n const num = p % 1000000000; // up to 9 digits\n const chunk = num.toString().padStart(9, \"0\");\n out += chunk;\n }\n return out.slice(0, length);\n}\n\n// Generate a SHA256 hash of a code string for use as a unique identifier\nexport function codeHash(code: string): string {\n const hash = sha256(code);\n return Array.from(hash)\n .map((b) => b.toString(16).padStart(2, \"0\"))\n .join(\"\");\n}\n\n// Generate a cryptographically secure random secret\nexport function generateRandomSecret(): string {\n const randomBytes = new Uint8Array(32);\n crypto.getRandomValues(randomBytes);\n return btoa(String.fromCharCode(...randomBytes));\n}\n",
13
- "import type {\n CanonicalMessageParts,\n CanonicalRevokeMessageParts,\n DelegationProof,\n} from \"../types\";\n\nexport const CANONICAL_MESSAGE_VERSION = 1;\nexport const CANONICAL_MESSAGE_PREFIX = \"actioncodes\";\nexport const CANONICAL_REVOKE_MESSAGE_PREFIX = \"actioncodes-revoke\";\n\nexport function serializeCanonical(parts: CanonicalMessageParts): Uint8Array {\n const json = JSON.stringify({\n id: CANONICAL_MESSAGE_PREFIX,\n ver: CANONICAL_MESSAGE_VERSION,\n pubkey: parts.pubkey,\n windowStart: parts.windowStart,\n // Include secret if provided for enhanced security\n ...(parts.secret && { secret: parts.secret }),\n });\n return new TextEncoder().encode(json);\n}\n\nexport function serializeCanonicalRevoke(\n parts: CanonicalRevokeMessageParts\n): Uint8Array {\n const json = JSON.stringify({\n id: CANONICAL_REVOKE_MESSAGE_PREFIX,\n ver: CANONICAL_MESSAGE_VERSION,\n pubkey: parts.pubkey,\n codeHash: parts.codeHash,\n windowStart: parts.windowStart,\n });\n return new TextEncoder().encode(json);\n}\n\nexport function getCanonicalMessageParts(\n pubkey: string,\n ttlMs: number,\n providedSecret?: string\n): Uint8Array {\n const windowStart = Math.floor(Date.now() / ttlMs) * ttlMs;\n return serializeCanonical({ pubkey, windowStart, secret: providedSecret });\n}\n\nexport function serializeDelegationProof(proof: DelegationProof): Uint8Array {\n const json = JSON.stringify({\n walletPubkey: proof.walletPubkey,\n delegatedPubkey: proof.delegatedPubkey,\n expiresAt: proof.expiresAt,\n });\n return new TextEncoder().encode(json);\n}\n",
12
+ "import { sha256 as nobleSha256 } from \"@noble/hashes/sha2.js\";\nimport { hmac } from \"@noble/hashes/hmac.js\";\nimport { hkdf } from \"@noble/hashes/hkdf.js\";\n\nfunction toBytes(input: Uint8Array | string): Uint8Array {\n if (typeof input === \"string\") return new TextEncoder().encode(input);\n return input;\n}\n\nexport function sha256(data: Uint8Array | string): Uint8Array {\n return nobleSha256(toBytes(data));\n}\n\nexport function hmacSha256(\n key: Uint8Array | string,\n data: Uint8Array | string\n): Uint8Array {\n return hmac(nobleSha256, toBytes(key), toBytes(data));\n}\n\n// HKDF implementation using @noble/hashes\nexport function hkdfSha256(\n ikm: Uint8Array | string,\n length: number,\n {\n salt,\n info,\n }: { salt?: Uint8Array | string; info?: Uint8Array | string } = {}\n): Uint8Array {\n const saltBuf = salt ? toBytes(salt) : new Uint8Array(32);\n const ikmBuf = toBytes(ikm);\n const infoBuf = info ? toBytes(info) : new Uint8Array(0);\n\n return hkdf(nobleSha256, ikmBuf, saltBuf, infoBuf, length);\n}\n\n// Crockford Base32 without lookalikes (I L O U mapped) – output uppercase\nconst CROCKFORD_ALPHABET = \"0123456789ABCDEFGHJKMNPQRSTVWXYZ\";\n\nexport function base32EncodeCrockford(data: Uint8Array): string {\n let bits = 0;\n let value = 0;\n let output = \"\";\n for (let i = 0; i < data.length; i++) {\n value = (value << 8) | data[i]!;\n bits += 8;\n while (bits >= 5) {\n output += CROCKFORD_ALPHABET[(value >>> (bits - 5)) & 31];\n bits -= 5;\n }\n }\n if (bits > 0) {\n output += CROCKFORD_ALPHABET[(value << (5 - bits)) & 31];\n }\n return output;\n}\n\nexport function truncateBits(input: Uint8Array, totalBits: number): Uint8Array {\n const totalBytes = Math.ceil(totalBits / 8);\n const out = new Uint8Array(totalBytes);\n const copyBytes = Math.min(totalBytes, input.length);\n out.set(input.subarray(0, copyBytes));\n // If not byte-aligned, mask the last byte\n const extraBits = totalBytes * 8 - totalBits;\n if (extraBits > 0) {\n const mask = 0xff << extraBits;\n out[totalBytes - 1] = out[totalBytes - 1]! & mask;\n }\n return out;\n}\n\n// Derive digits-only code from a digest using modulo bias-reduction (HOTP-style per-digit)\nexport function digestToDigits(digest: Uint8Array, length: number): string {\n if (digest.length === 0) throw new Error(\"digestToDigits: empty digest\");\n // HOTP-like dynamic truncation for unbiased decimal extraction\n // Process 4 bytes windows to produce digits\n let out = \"\";\n const offset = digest[digest.length - 1]! & 0x0f;\n for (let i = 0; out.length < length; i++) {\n const idx = (offset + i * 4) % Math.max(1, digest.length - 4);\n const p =\n ((digest[idx]! & 0x7f) << 24) |\n (digest[idx + 1]! << 16) |\n (digest[idx + 2]! << 8) |\n digest[idx + 3]!;\n const num = p % 1000000000; // up to 9 digits\n const chunk = num.toString().padStart(9, \"0\");\n out += chunk;\n }\n return out.slice(0, length);\n}\n\n// Generate a SHA256 hash of a code string for use as a unique identifier\nexport function codeHash(code: string): string {\n const hash = sha256(code);\n return Array.from(hash)\n .map((b) => b.toString(16).padStart(2, \"0\"))\n .join(\"\");\n}\n",
13
+ "import type {\n CanonicalMessageParts,\n CanonicalRevokeMessageParts,\n DelegationProof,\n} from \"../types\";\n\nexport const CANONICAL_MESSAGE_VERSION = 1;\nexport const CANONICAL_MESSAGE_PREFIX = \"actioncodes\";\nexport const CANONICAL_REVOKE_MESSAGE_PREFIX = \"actioncodes-revoke\";\n\nexport function serializeCanonical(parts: CanonicalMessageParts): Uint8Array {\n const json = JSON.stringify({\n id: CANONICAL_MESSAGE_PREFIX,\n ver: CANONICAL_MESSAGE_VERSION,\n pubkey: parts.pubkey,\n windowStart: parts.windowStart,\n });\n return new TextEncoder().encode(json);\n}\n\nexport function serializeCanonicalRevoke(\n parts: CanonicalRevokeMessageParts\n): Uint8Array {\n const json = JSON.stringify({\n id: CANONICAL_REVOKE_MESSAGE_PREFIX,\n ver: CANONICAL_MESSAGE_VERSION,\n pubkey: parts.pubkey,\n codeHash: parts.codeHash,\n windowStart: parts.windowStart,\n });\n return new TextEncoder().encode(json);\n}\n\nexport function getCanonicalMessageParts(\n pubkey: string,\n ttlMs: number\n): Uint8Array {\n const windowStart = Math.floor(Date.now() / ttlMs) * ttlMs;\n return serializeCanonical({ pubkey, windowStart });\n}\n\nexport function serializeDelegationProof(proof: DelegationProof): Uint8Array {\n const json = JSON.stringify({\n walletPubkey: proof.walletPubkey,\n delegatedPubkey: proof.delegatedPubkey,\n expiresAt: proof.expiresAt,\n chain: proof.chain,\n });\n return new TextEncoder().encode(json);\n}\n",
14
14
  "// Protocol-wide constants\n\nexport const PROTOCOL_NORMALIZATION = \"NFC\";\nexport const PROTOCOL_META_MAX_BYTES = 256; // UTF-8 bytes\n\nexport const CODE_MIN_LENGTH = 6;\nexport const CODE_MAX_LENGTH = 24;\nexport const CODE_DEFAULT_LENGTH = 8;\n\n// Digits-only codes (0-9)\nexport const CODE_CHARSET_DIGITS = \"0123456789\";\n\nexport const SUPPORTED_CHAINS = [\"solana\"] as const;\n\n\n",
15
15
  "import { PROTOCOL_META_MAX_BYTES, PROTOCOL_NORMALIZATION } from \"../constants\";\n\n// v2 protocol meta\nexport interface ProtocolMetaFields {\n ver: 2;\n id: string; // code id (usually hex/hash)\n int: string; // intent owner who created the code\n p?: Record<string, unknown>; // optional parameters as JSON object\n}\n\nexport const SCHEME = \"actioncodes:\";\n\nexport function buildProtocolMeta(fields: ProtocolMetaFields): string {\n const norm = normalizeFields(fields);\n if (norm.int != null) guardParamSize(norm.int);\n \n const parts = [\n `ver=${norm.ver}`,\n `id=${encodeURIComponent(norm.id)}`,\n `int=${encodeURIComponent(norm.int)}`,\n ];\n\n if (norm.p != null && Object.keys(norm.p).length > 0) {\n const paramsJson = JSON.stringify(norm.p);\n guardParamSize(paramsJson);\n parts.push(`p=${encodeURIComponent(paramsJson)}`);\n }\n \n const out = SCHEME + parts.join(\"&\");\n guardSize(out);\n return out;\n}\n\nexport function parseProtocolMeta(input: string): ProtocolMetaFields {\n if (!input.startsWith(SCHEME)) throw new Error(\"protocol meta must start with actioncodes:\");\n const q = input.slice(SCHEME.length);\n const pairs = q.split(\"&\").filter(Boolean);\n const map = new Map<string, string>();\n for (const pair of pairs) {\n const [k, vRaw] = pair.split(\"=\", 2);\n if (!k) continue;\n const v = vRaw != null ? decodeURIComponent(vRaw) : \"\";\n map.set(k, v);\n }\n const verStr = map.get(\"ver\");\n const id = map.get(\"id\");\n const int = map.get(\"int\");\n const pStr = map.get(\"p\");\n if (verStr == null || id == null || int == null) throw new Error(\"protocol meta missing required fields ver or id or int\");\n const ver = Number(verStr);\n if (!Number.isInteger(ver) || ver <= 0) throw new Error(\"protocol meta ver must be positive integer\");\n \n let p: Record<string, unknown> | undefined;\n if (pStr != null && pStr !== \"\") {\n try {\n p = JSON.parse(pStr);\n if (typeof p !== \"object\" || p === null || Array.isArray(p)) {\n throw new Error(\"protocol meta p must be a JSON object\");\n }\n } catch {\n throw new Error(\"protocol meta p must be valid JSON\");\n }\n }\n \n const norm = normalizeFields({ ver: ver as 2, id, int, p });\n if (norm.int != null) guardParamSize(norm.int);\n if (norm.p != null) guardParamSize(JSON.stringify(norm.p));\n const unknownKeys = [...map.keys()].filter((k) => k !== \"ver\" && k !== \"id\" && k !== \"int\" && k !== \"p\");\n if (unknownKeys.length > 0) throw new Error(\"protocol meta contains unsupported keys\");\n guardSize(buildProtocolMeta(norm));\n return norm;\n}\n\nexport function validateProtocolMetaFormat(input: string): { ok: true } | { ok: false; reason: string } {\n try {\n parseProtocolMeta(input);\n return { ok: true };\n } catch (e: unknown) {\n return { ok: false, reason: String(e) };\n }\n}\n\nfunction normalizeFields(fields: ProtocolMetaFields): ProtocolMetaFields {\n const id = fields.id.normalize(PROTOCOL_NORMALIZATION).trim();\n const out: ProtocolMetaFields = { ver: fields.ver, id, int: fields.int };\n if (fields.int != null) out.int = fields.int.normalize(PROTOCOL_NORMALIZATION).trim();\n if (fields.p != null) {\n // For JSON objects, we don't normalize the object itself, just ensure it's valid\n out.p = fields.p;\n }\n return out;\n}\n\nfunction guardSize(s: string): void {\n const bytes = new TextEncoder().encode(s);\n if (bytes.length > PROTOCOL_META_MAX_BYTES) throw new Error(`protocol meta exceeds ${PROTOCOL_META_MAX_BYTES} bytes`);\n}\n\nfunction guardParamSize(value: string): void {\n const bytes = new TextEncoder().encode(value);\n if (bytes.length > PROTOCOL_META_MAX_BYTES) throw new Error(`protocol meta params exceed ${PROTOCOL_META_MAX_BYTES} bytes`);\n}\n\n\n",
16
16
  "export enum ProtocolErrorCode {\n // Code validation errors\n EXPIRED_CODE = \"EXPIRED_CODE\",\n INVALID_CODE = \"INVALID_CODE\",\n INVALID_CODE_FORMAT = \"INVALID_CODE_FORMAT\",\n INVALID_SIGNATURE = \"INVALID_SIGNATURE\",\n\n // Meta validation errors\n MISSING_META = \"MISSING_META\",\n INVALID_META_FORMAT = \"INVALID_META_FORMAT\",\n META_MISMATCH = \"META_MISMATCH\",\n META_TOO_LARGE = \"META_TOO_LARGE\",\n\n // Transaction errors\n TRANSACTION_NOT_SIGNED_BY_INTENDED_OWNER = \"TRANSACTION_NOT_SIGNED_BY_INTENDED_OWNER\",\n INVALID_TRANSACTION_FORMAT = \"INVALID_TRANSACTION_FORMAT\",\n INVALID_PUBKEY_FORMAT = \"INVALID_PUBKEY_FORMAT\",\n\n // Input validation errors\n INVALID_INPUT = \"INVALID_INPUT\",\n MISSING_REQUIRED_FIELD = \"MISSING_REQUIRED_FIELD\",\n\n // Crypto errors\n CRYPTO_ERROR = \"CRYPTO_ERROR\",\n INVALID_DIGEST = \"INVALID_DIGEST\",\n\n // Adapter errors\n INVALID_ADAPTER = \"INVALID_ADAPTER\",\n}\n\nexport class ProtocolError extends Error {\n constructor(\n public readonly code: ProtocolErrorCode,\n message: string,\n public readonly details?: Record<string, unknown>\n ) {\n super(message);\n this.name = \"ProtocolError\";\n }\n\n // Code validation errors\n static expiredCode(code: string, expiresAt: number, currentTime: number): ExpiredCodeError {\n return new ExpiredCodeError(code, expiresAt, currentTime);\n }\n\n static invalidCode(expected: string, actual: string): ProtocolError {\n return new ProtocolError(\n ProtocolErrorCode.INVALID_CODE,\n `Invalid code: expected '${expected}', got '${actual}'`,\n { expected, actual }\n );\n }\n\n static invalidCodeFormat(code: string, reason: string): InvalidCodeFormatError {\n return new InvalidCodeFormatError(code, reason);\n }\n\n static invalidSignature(reason: string): InvalidSignatureError {\n return new InvalidSignatureError(reason);\n }\n\n // Meta validation errors\n static missingMeta(): MissingMetaError {\n return new MissingMetaError();\n }\n\n static invalidMetaFormat(reason: string): ProtocolError {\n return new ProtocolError(\n ProtocolErrorCode.INVALID_META_FORMAT,\n `Invalid protocol meta format: ${reason}`,\n { reason }\n );\n }\n\n static metaMismatch(expected: string, actual: string, field: string): MetaMismatchError {\n return new MetaMismatchError(expected, actual, field);\n }\n\n static metaTooLarge(maxBytes: number, actualBytes: number): ProtocolError {\n return new ProtocolError(\n ProtocolErrorCode.META_TOO_LARGE,\n `Protocol meta too large: ${actualBytes} bytes (max: ${maxBytes})`,\n { maxBytes, actualBytes }\n );\n }\n\n // Transaction errors\n static transactionNotSignedByIntendedOwner(intended: string, actualSigners: string[]): TransactionNotSignedByIntendedOwnerError {\n return new TransactionNotSignedByIntendedOwnerError(intended, actualSigners);\n }\n\n static invalidTransactionFormat(reason: string): ProtocolError {\n return new ProtocolError(\n ProtocolErrorCode.INVALID_TRANSACTION_FORMAT,\n `Invalid transaction format: ${reason}`,\n { reason }\n );\n }\n\n static invalidPubkeyFormat(pubkey: string, reason: string): InvalidPubkeyFormatError {\n return new InvalidPubkeyFormatError(pubkey, reason);\n }\n\n // Input validation errors\n static invalidInput(field: string, value: unknown, reason: string): ProtocolError {\n return new ProtocolError(\n ProtocolErrorCode.INVALID_INPUT,\n `Invalid ${field}: ${reason}`,\n { field, value, reason }\n );\n }\n\n static missingRequiredField(field: string): ProtocolError {\n return new ProtocolError(\n ProtocolErrorCode.MISSING_REQUIRED_FIELD,\n `Missing required field: ${field}`,\n { field }\n );\n }\n\n // Crypto errors\n static cryptoError(operation: string, reason: string): ProtocolError {\n return new ProtocolError(\n ProtocolErrorCode.CRYPTO_ERROR,\n `Crypto error in ${operation}: ${reason}`,\n { operation, reason }\n );\n }\n\n static invalidDigest(reason: string): ProtocolError {\n return new ProtocolError(\n ProtocolErrorCode.INVALID_DIGEST,\n `Invalid digest: ${reason}`,\n { reason }\n );\n }\n\n // Adapter errors\n static invalidAdapter(adapter: string): InvalidAdapterError {\n return new InvalidAdapterError(adapter);\n }\n\n // Generic error creator\n static create(code: ProtocolErrorCode, message: string, details?: Record<string, unknown>): ProtocolError {\n return new ProtocolError(code, message, details);\n }\n}\n\n// Specific error classes for instanceof checks\nexport class ExpiredCodeError extends ProtocolError {\n constructor(code: string, expiresAt: number, currentTime: number) {\n super(\n ProtocolErrorCode.EXPIRED_CODE,\n `Action code '${code}' expired at ${expiresAt}, current time: ${currentTime}`,\n { code, expiresAt, currentTime }\n );\n this.name = \"ExpiredCodeError\";\n }\n}\n\nexport class MissingMetaError extends ProtocolError {\n constructor() {\n super(\n ProtocolErrorCode.MISSING_META,\n \"Transaction does not contain valid protocol meta\"\n );\n this.name = \"MissingMetaError\";\n }\n}\n\nexport class MetaMismatchError extends ProtocolError {\n constructor(expected: string, actual: string, field: string) {\n super(\n ProtocolErrorCode.META_MISMATCH,\n `Meta ${field} mismatch: expected '${expected}', got '${actual}'`,\n { expected, actual, field }\n );\n this.name = \"MetaMismatchError\";\n }\n}\n\nexport class TransactionNotSignedByIntendedOwnerError extends ProtocolError {\n constructor(intended: string, actualSigners: string[]) {\n super(\n ProtocolErrorCode.TRANSACTION_NOT_SIGNED_BY_INTENDED_OWNER,\n `Transaction not signed by intended owner '${intended}'. Actual signers: [${actualSigners.join(\n \", \"\n )}]`,\n { intended, actualSigners }\n );\n this.name = \"TransactionNotSignedByIntendedOwnerError\";\n }\n}\n\nexport class InvalidPubkeyFormatError extends ProtocolError {\n constructor(pubkey: string, reason: string) {\n super(\n ProtocolErrorCode.INVALID_PUBKEY_FORMAT,\n `Invalid public key format '${pubkey}': ${reason}`,\n { pubkey, reason }\n );\n this.name = \"InvalidPubkeyFormatError\";\n }\n}\n\nexport class InvalidSignatureError extends ProtocolError {\n constructor(reason: string) {\n super(ProtocolErrorCode.INVALID_SIGNATURE, `Invalid signature: ${reason}`, {\n reason,\n });\n this.name = \"InvalidSignatureError\";\n }\n}\n\nexport class InvalidCodeFormatError extends ProtocolError {\n constructor(code: string, reason: string) {\n super(\n ProtocolErrorCode.INVALID_CODE_FORMAT,\n `Invalid code format '${code}': ${reason}`,\n { code, reason }\n );\n this.name = \"InvalidCodeFormatError\";\n }\n}\n\nexport class InvalidAdapterError extends ProtocolError {\n constructor(adapter: string) {\n super(ProtocolErrorCode.INVALID_ADAPTER, `Invalid adapter: ${adapter}`, { adapter });\n this.name = \"InvalidAdapterError\";\n }\n}",
17
- "import type {\n ActionCode,\n CodeGenerationConfig,\n WalletStrategyCodeGenerationResult,\n} from \"../types\";\nimport {\n sha256,\n hmacSha256,\n truncateBits,\n digestToDigits,\n} from \"../utils/crypto\";\nimport { CODE_MAX_LENGTH, CODE_MIN_LENGTH } from \"../constants\";\nimport {\n serializeCanonical,\n getCanonicalMessageParts,\n} from \"../utils/canonical\";\nimport { ProtocolError } from \"../errors\";\nimport bs58 from \"bs58\";\n\nexport class WalletStrategy {\n constructor(private config: CodeGenerationConfig) {}\n\n generateCode(\n canonicalMessage: Uint8Array,\n signature: string,\n providedSecret?: string\n ): WalletStrategyCodeGenerationResult {\n const canonical = canonicalMessage;\n\n // Parse pubkey and windowStart from canonical message\n const decoded = JSON.parse(new TextDecoder().decode(canonical));\n const pubkey = decoded.pubkey;\n const windowStart = decoded.windowStart;\n\n // Only use secret if explicitly provided\n const secret = providedSecret;\n\n // Use signature if provided, otherwise fall back to secret/HMAC\n let digest: Uint8Array;\n if (signature) {\n // Use signature as the primary entropy source\n // Decode Base58 signature to bytes\n const signatureBytes = bs58.decode(signature);\n digest = hmacSha256(signatureBytes, canonical);\n } else if (secret) {\n // Use secret for HMAC\n digest = hmacSha256(secret, canonical);\n } else {\n // Fall back to SHA256 (less secure)\n digest = sha256(canonical);\n }\n\n const clamped = Math.max(\n CODE_MIN_LENGTH,\n Math.min(CODE_MAX_LENGTH, this.config.codeLength)\n );\n const bitsNeeded = 8 * Math.ceil(clamped / 2);\n const truncated = truncateBits(digest, bitsNeeded);\n const code = digestToDigits(truncated, clamped);\n\n const actionCode: ActionCode = {\n code,\n pubkey,\n timestamp: windowStart,\n expiresAt: windowStart + this.config.ttlMs,\n // Include signature if provided\n ...(signature && { signature }),\n // Only include secret if provided\n ...(secret && { secret }),\n };\n\n return { actionCode, canonicalMessage: canonical };\n }\n\n validateCode(actionCode: ActionCode): void {\n const currentTime = Date.now();\n if (currentTime > actionCode.expiresAt + (this.config.clockSkewMs ?? 0)) {\n throw ProtocolError.expiredCode(\n actionCode.code,\n actionCode.expiresAt,\n currentTime\n );\n }\n\n const canonical = serializeCanonical({\n pubkey: actionCode.pubkey,\n windowStart: actionCode.timestamp,\n secret: actionCode.secret, // Include secret if available\n });\n\n // Use same digest method as generation\n let digest: Uint8Array;\n if (actionCode.signature) {\n // Use signature as the primary entropy source\n // Decode Base58 signature to bytes\n const signatureBytes = bs58.decode(actionCode.signature);\n digest = hmacSha256(signatureBytes, canonical);\n } else if (actionCode.secret) {\n // Use secret for HMAC\n digest = hmacSha256(actionCode.secret, canonical);\n } else {\n // Fall back to SHA256 (less secure)\n digest = sha256(canonical);\n }\n\n const clamped = Math.max(\n CODE_MIN_LENGTH,\n Math.min(CODE_MAX_LENGTH, this.config.codeLength)\n );\n const truncated = truncateBits(digest, 8 * Math.ceil(clamped / 2));\n const expected = digestToDigits(truncated, clamped);\n\n if (expected !== actionCode.code) {\n throw ProtocolError.invalidCode(expected, actionCode.code);\n }\n }\n\n // Instance method for accessing canonical functions\n getCanonicalMessageParts(\n pubkey: string,\n providedSecret?: string\n ): Uint8Array {\n return getCanonicalMessageParts(pubkey, this.config.ttlMs, providedSecret);\n }\n}\n",
18
- "import { WalletStrategy } from \"./WalletStrategy\";\nimport { getCanonicalMessageParts } from \"../utils/canonical\";\nimport type {\n DelegationProof,\n DelegatedActionCode,\n CodeGenerationConfig,\n DelegationStrategyCodeGenerationResult,\n} from \"../types\";\n\nexport class DelegationStrategy {\n private walletStrategy: WalletStrategy;\n private config: CodeGenerationConfig;\n\n constructor(config: CodeGenerationConfig) {\n this.config = config;\n this.walletStrategy = new WalletStrategy(config);\n }\n\n /**\n * Generate a delegated action code using a delegation proof and delegated signature\n */\n generateDelegatedCode(\n delegationProof: DelegationProof,\n delegatedSignature: string\n ): DelegationStrategyCodeGenerationResult {\n // Validate delegation proof format and expiration\n this.validateDelegationProof(delegationProof);\n\n // Generate canonical message using the delegated pubkey\n const canonicalMessage = getCanonicalMessageParts(\n delegationProof.delegatedPubkey,\n this.config.ttlMs\n );\n\n // Generate code using existing WalletStrategy with canonical message\n const result = this.walletStrategy.generateCode(\n canonicalMessage,\n delegatedSignature // Use delegated signature\n );\n\n // Create delegated action code\n const delegatedActionCode: DelegatedActionCode = {\n ...result.actionCode,\n delegationProof: delegationProof,\n delegatedSignature: delegatedSignature,\n };\n\n return {\n actionCode: delegatedActionCode,\n };\n }\n\n /**\n * Validate a delegated action code\n */\n validateDelegatedCode(\n actionCode: DelegatedActionCode,\n delegationProof: DelegationProof\n ): void {\n // Validate the action code itself\n this.walletStrategy.validateCode(actionCode);\n\n // Verify delegation proof is still valid\n this.validateDelegationProof(delegationProof);\n\n // Verify the delegation proof matches the action code\n if (\n actionCode.delegationProof.walletPubkey !== delegationProof.walletPubkey\n ) {\n throw new Error(\n \"Action code wallet pubkey does not match delegation proof\"\n );\n }\n\n if (\n actionCode.delegationProof.delegatedPubkey !==\n delegationProof.delegatedPubkey\n ) {\n throw new Error(\n \"Action code delegated pubkey does not match delegation proof\"\n );\n }\n\n if (actionCode.delegationProof.expiresAt !== delegationProof.expiresAt) {\n throw new Error(\n \"Action code delegation expiration does not match delegation proof\"\n );\n }\n\n if (actionCode.delegationProof.signature !== delegationProof.signature) {\n throw new Error(\n \"Action code delegation signature does not match delegation proof\"\n );\n }\n\n // Verify delegated signature is present\n if (!actionCode.delegatedSignature) {\n throw new Error(\"Delegated signature is required\");\n }\n }\n\n /**\n * Validate a delegation proof\n */\n private validateDelegationProof(delegationProof: DelegationProof): void {\n if (!delegationProof.walletPubkey) {\n throw new Error(\"Wallet pubkey is required\");\n }\n\n if (!delegationProof.delegatedPubkey) {\n throw new Error(\"Delegated pubkey is required\");\n }\n\n if (!delegationProof.expiresAt) {\n throw new Error(\"Expiration time is required\");\n }\n\n if (!delegationProof.signature) {\n throw new Error(\"Delegation signature is required\");\n }\n\n // Check if delegation has expired\n if (delegationProof.expiresAt < Date.now()) {\n throw new Error(\"Delegation proof has expired\");\n }\n }\n\n /**\n * Get the wallet strategy instance for advanced usage\n */\n getWalletStrategy(): WalletStrategy {\n return this.walletStrategy;\n }\n\n /**\n * Get canonical message parts for delegation\n */\n getCanonicalMessageParts(\n pubkey: string,\n providedSecret?: string\n ): Uint8Array {\n return getCanonicalMessageParts(pubkey, this.config.ttlMs, providedSecret);\n }\n}\n",
19
- "import nacl from \"tweetnacl\";\nimport bs58 from \"bs58\";\nimport {\n PublicKey,\n Transaction,\n VersionedTransaction,\n TransactionInstruction,\n MessageV0,\n} from \"@solana/web3.js\";\nimport { createMemoInstruction, MEMO_PROGRAM_ID } from \"@solana/spl-memo\";\nimport {\n BaseChainAdapter,\n type WalletContext,\n type WalletRevokeContext,\n type DelegatedContext,\n type DelegatedRevokeContext,\n} from \"./BaseChainAdapter\";\nimport {\n buildProtocolMeta,\n parseProtocolMeta,\n type ProtocolMetaFields,\n} from \"../utils/protocolMeta\";\nimport { codeHash } from \"../utils/crypto\";\nimport type { ActionCode } from \"../types\";\nimport { ProtocolError } from \"../errors\";\nimport {\n serializeCanonical,\n serializeCanonicalRevoke,\n serializeDelegationProof,\n} from \"../utils/canonical\";\n\nexport const ADAPTER_CHAIN_NAME = \"solana\" as const;\nexport type SolanaWalletContext = WalletContext<{\n chain: typeof ADAPTER_CHAIN_NAME;\n}>;\nexport type SolanaDelegatedContext = DelegatedContext<{\n chain: typeof ADAPTER_CHAIN_NAME;\n}>;\nexport type SolanaWalletRevokeContext = WalletRevokeContext<{\n chain: typeof ADAPTER_CHAIN_NAME;\n}>;\nexport type SolanaDelegatedRevokeContext = DelegatedRevokeContext<{\n chain: typeof ADAPTER_CHAIN_NAME;\n}>;\n\n/** Union of supported Solana txn types */\nexport type SolanaTransaction = Transaction | VersionedTransaction;\n\nexport class SolanaAdapter extends BaseChainAdapter<\n SolanaWalletContext,\n SolanaDelegatedContext,\n SolanaWalletRevokeContext,\n SolanaDelegatedRevokeContext\n> {\n /** Normalize pubkey input to PublicKey */\n private normalizePubkey(input: string | PublicKey): PublicKey {\n if (typeof input === \"string\") {\n return new PublicKey(input);\n }\n return input;\n }\n\n /** Verify the signature over canonical message (protocol-level) */\n verifyWithWallet(context: SolanaWalletContext): boolean {\n // Early validation checks - these are fast and don't leak timing info\n if (context.chain !== ADAPTER_CHAIN_NAME) return false;\n if (!context.message || !context.message.pubkey || !context.walletSignature)\n return false;\n\n // Perform all operations in a single try-catch to ensure consistent timing\n try {\n const message = serializeCanonical(context.message);\n const pub = this.normalizePubkey(context.message.pubkey);\n const sigBytes = bs58.decode(context.walletSignature);\n const pubBytes = pub.toBytes();\n\n // Validate lengths\n if (sigBytes.length !== 64 || pubBytes.length !== 32) {\n return false;\n }\n\n // Perform signature verification\n return nacl.sign.detached.verify(message, sigBytes, pubBytes);\n } catch {\n // All errors result in false with consistent timing\n return false;\n }\n }\n\n /** Verify delegation proof signature */\n verifyWithDelegation(context: SolanaDelegatedContext): boolean {\n // Early validation checks - these are fast and don't leak timing info\n if (context.chain !== ADAPTER_CHAIN_NAME) return false;\n if (\n !context.message.pubkey ||\n !context.delegatedSignature ||\n !context.delegationProof\n )\n return false;\n\n const proof = context.delegationProof;\n\n // Basic validation\n if (\n !proof.walletPubkey ||\n !proof.delegatedPubkey ||\n !proof.expiresAt ||\n !proof.signature\n ) {\n return false;\n }\n\n // The revoke/message pubkey for delegated flow must be the delegated pubkey\n if (proof.delegatedPubkey !== context.message.pubkey) return false;\n\n // Check if delegation has expired\n if (proof.expiresAt < Date.now()) return false;\n\n // Perform all operations in a single try-catch to ensure consistent timing\n try {\n const delegationMessage = serializeDelegationProof(proof);\n const walletPub = this.normalizePubkey(proof.walletPubkey);\n const walletSigBytes = bs58.decode(proof.signature);\n const walletPubBytes = walletPub.toBytes();\n if (walletSigBytes.length !== 64 || walletPubBytes.length !== 32) {\n return false;\n }\n const walletOk = nacl.sign.detached.verify(\n delegationMessage,\n walletSigBytes,\n walletPubBytes\n );\n if (!walletOk) return false;\n\n const canonicalMessage = serializeCanonical(context.message);\n const delegatedPub = this.normalizePubkey(proof.delegatedPubkey);\n const delegatedSigBytes = bs58.decode(context.delegatedSignature);\n const delegatedPubBytes = delegatedPub.toBytes();\n if (delegatedSigBytes.length !== 64 || delegatedPubBytes.length !== 32) {\n return false;\n }\n return nacl.sign.detached.verify(\n canonicalMessage,\n delegatedSigBytes,\n delegatedPubBytes\n );\n } catch {\n // All errors result in false with consistent timing\n return false;\n }\n }\n\n /** Verify the signature over canonical revoke message (protocol-level) */\n verifyRevokeWithWallet(context: SolanaWalletRevokeContext): boolean {\n // Early validation checks - these are fast and don't leak timing info\n if (context.chain !== ADAPTER_CHAIN_NAME) return false;\n if (!context.message || !context.message.pubkey || !context.walletSignature)\n return false;\n\n // Perform all operations in a single try-catch to ensure consistent timing\n try {\n const message = serializeCanonicalRevoke(context.message);\n const pub = this.normalizePubkey(context.message.pubkey);\n const sigBytes = bs58.decode(context.walletSignature);\n const pubBytes = pub.toBytes();\n\n // Validate lengths\n if (sigBytes.length !== 64 || pubBytes.length !== 32) {\n return false;\n }\n\n // Perform signature verification\n return nacl.sign.detached.verify(message, sigBytes, pubBytes);\n } catch {\n // All errors result in false with consistent timing\n return false;\n }\n }\n\n verifyRevokeWithDelegation(context: SolanaDelegatedRevokeContext): boolean {\n // Early validation checks - these are fast and don't leak timing info\n if (context.chain !== ADAPTER_CHAIN_NAME) return false;\n if (\n !context.message ||\n !context.message.pubkey ||\n !context.delegatedSignature ||\n !context.delegationProof\n )\n return false;\n\n const proof = context.delegationProof;\n\n // Basic validation\n if (\n !proof.walletPubkey ||\n !proof.delegatedPubkey ||\n !proof.expiresAt ||\n !proof.signature\n ) {\n return false;\n }\n\n // The revoke/message pubkey for delegated flow must be the delegated pubkey\n if (proof.delegatedPubkey !== context.message.pubkey) return false;\n\n // Check if delegation has expired\n if (proof.expiresAt < Date.now()) return false;\n\n try {\n const delegationMessage = serializeDelegationProof(proof);\n const walletPub = this.normalizePubkey(proof.walletPubkey);\n const walletSigBytes = bs58.decode(proof.signature);\n const walletPubBytes = walletPub.toBytes();\n if (walletSigBytes.length !== 64 || walletPubBytes.length !== 32) {\n return false;\n }\n const walletOk = nacl.sign.detached.verify(\n delegationMessage,\n walletSigBytes,\n walletPubBytes\n );\n if (!walletOk) return false;\n\n const revokeMessage = serializeCanonicalRevoke(context.message);\n const delegatedPub = this.normalizePubkey(proof.delegatedPubkey);\n const delegatedSigBytes = bs58.decode(context.delegatedSignature);\n const delegatedPubBytes = delegatedPub.toBytes();\n if (delegatedSigBytes.length !== 64 || delegatedPubBytes.length !== 32) {\n return false;\n }\n return nacl.sign.detached.verify(\n revokeMessage,\n delegatedSigBytes,\n delegatedPubBytes\n );\n } catch {\n // All errors result in false with consistent timing\n return false;\n }\n }\n\n /** Create a Solana memo instruction carrying protocol meta (for SDK/clients) */\n static createProtocolMetaIx(\n meta: ProtocolMetaFields\n ): TransactionInstruction {\n const metaString = buildProtocolMeta(meta);\n return createMemoInstruction(metaString);\n }\n\n /** Extract protocol metadata string (memo) from a base64-encoded transaction, or null */\n getProtocolMeta(txString: string): string | null {\n try {\n const tx = this.deserializeTransaction(txString);\n for (const ix of this.getMemoInstructions(tx)) {\n const data = ix.data;\n try {\n const s = new TextDecoder().decode(data);\n // Optionally: test parse\n const parsed = parseProtocolMeta(s);\n if (parsed) return s;\n } catch {\n // ignore\n }\n }\n return null;\n } catch {\n return null;\n }\n }\n\n /** Deserialize a base64-encoded transaction string to SolanaTransaction */\n private deserializeTransaction(txString: string): SolanaTransaction {\n try {\n // Try versioned first (most common now)\n const versionedTx = VersionedTransaction.deserialize(\n Buffer.from(txString, \"base64\")\n );\n\n // Check if this is actually a versioned transaction by checking if it has a MessageV0\n if (versionedTx.message instanceof MessageV0) {\n return versionedTx;\n } else {\n // This is likely a legacy transaction that was incorrectly deserialized as versioned\n // Fall back to legacy deserialization\n return Transaction.from(Buffer.from(txString, \"base64\"));\n }\n } catch {\n try {\n // Fallback to legacy\n return Transaction.from(Buffer.from(txString, \"base64\"));\n } catch {\n throw ProtocolError.invalidTransactionFormat(\n \"Invalid base64 transaction format\"\n );\n }\n }\n }\n\n /** Get parsed ProtocolMeta object from base64-encoded transaction, or null if none or invalid */\n parseMeta(txString: string): ProtocolMetaFields | null {\n const s = this.getProtocolMeta(txString);\n if (!s) return null;\n return parseProtocolMeta(s);\n }\n\n /** List memo instructions from the transaction (legacy & versioned) */\n private getMemoInstructions(tx: SolanaTransaction): TransactionInstruction[] {\n if (tx instanceof Transaction) {\n return tx.instructions.filter((ix) =>\n ix.programId.equals(MEMO_PROGRAM_ID)\n );\n } else {\n // VersionedTransaction: inspect `message.compiledInstructions` / static keys\n const vtx = tx as VersionedTransaction;\n const msg = vtx.message;\n if (msg instanceof MessageV0) {\n const memos: TransactionInstruction[] = [];\n for (const ix of msg.compiledInstructions) {\n const pid = msg.staticAccountKeys[ix.programIdIndex];\n if (pid && pid.equals(MEMO_PROGRAM_ID)) {\n // reconstruct a TransactionInstruction for inspection\n const keys = ix.accountKeyIndexes.map((i) => ({\n pubkey: msg.staticAccountKeys[i]!,\n isSigner: false,\n isWritable: false,\n }));\n memos.push(\n new TransactionInstruction({\n keys,\n programId: pid,\n data: ix.data as Buffer,\n })\n );\n }\n }\n return memos;\n }\n return [];\n }\n }\n\n /**\n * Validate that a base64-encoded transaction's memo meta aligns with the bound `actionCode`.\n * Throws ProtocolError if validation fails.\n */\n verifyTransactionMatchesCode(actionCode: ActionCode, txString: string): void {\n // Check expiration first\n const currentTime = Date.now();\n if (currentTime > actionCode.expiresAt) {\n throw ProtocolError.expiredCode(\n actionCode.code,\n actionCode.expiresAt,\n currentTime\n );\n }\n\n const meta = this.parseMeta(txString);\n if (!meta) {\n throw ProtocolError.missingMeta();\n }\n\n // Check version\n if (meta.ver !== 2) {\n throw ProtocolError.metaMismatch(\"2\", String(meta.ver), \"ver\");\n }\n\n // Check code ID - should be codeHash of the code, not the code itself\n const expectedCodeHash = codeHash(actionCode.code);\n if (meta.id !== expectedCodeHash) {\n throw ProtocolError.metaMismatch(expectedCodeHash, meta.id, \"id\");\n }\n\n // Check intended pubkey\n if (meta.int !== actionCode.pubkey) {\n throw ProtocolError.metaMismatch(actionCode.pubkey, meta.int, \"int\");\n }\n }\n\n /**\n * Verify that the base64-encoded transaction is signed by the \"intendedFor\" pubkey\n * as declared in the protocol meta of the transaction.\n * Throws ProtocolError if validation fails.\n */\n verifyTransactionSignedByIntentOwner(txString: string): void {\n const meta = this.parseMeta(txString);\n if (!meta) {\n throw ProtocolError.missingMeta();\n }\n\n const intended = meta.int;\n if (!intended) {\n throw ProtocolError.invalidMetaFormat(\n \"Missing 'int' (intendedFor) field\"\n );\n }\n\n let pubkey: PublicKey;\n try {\n pubkey = new PublicKey(intended);\n } catch {\n throw ProtocolError.invalidPubkeyFormat(\n intended,\n \"Invalid public key format\"\n );\n }\n\n const tx = this.deserializeTransaction(txString);\n const actualSigners: string[] = [];\n\n // For legacy Transaction\n if (tx instanceof Transaction) {\n const isSigned = tx.signatures.some((sig) => {\n if (!sig.signature) return false;\n actualSigners.push(sig.publicKey.toString());\n return sig.publicKey.equals(pubkey);\n });\n\n if (!isSigned) {\n throw ProtocolError.transactionNotSignedByIntendedOwner(\n intended,\n actualSigners\n );\n }\n return;\n }\n\n // For VersionedTransaction (MessageV0)\n if (tx instanceof VersionedTransaction) {\n const msg = tx.message;\n if (msg instanceof MessageV0) {\n const signerCount = msg.header.numRequiredSignatures;\n for (let i = 0; i < signerCount; i++) {\n const key = msg.staticAccountKeys[i];\n if (key) {\n actualSigners.push(key.toString());\n if (key.equals(pubkey)) {\n return; // Found the intended signer\n }\n }\n }\n throw ProtocolError.transactionNotSignedByIntendedOwner(\n intended,\n actualSigners\n );\n }\n }\n\n throw ProtocolError.invalidTransactionFormat(\n \"Unsupported transaction format\"\n );\n }\n\n /**\n * Attach protocol meta into a base64-encoded transaction and return the modified transaction as base64.\n * Throws ProtocolError if the transaction already contains protocol meta.\n */\n static attachProtocolMeta(\n txString: string,\n meta: ProtocolMetaFields\n ): string {\n // Check if transaction already has protocol meta\n const adapter = new SolanaAdapter();\n const existingMeta = adapter.getProtocolMeta(txString);\n if (existingMeta) {\n throw ProtocolError.invalidTransactionFormat(\n \"Transaction already contains protocol meta. Cannot attach additional protocol meta.\"\n );\n }\n\n const metaIx = SolanaAdapter.createProtocolMetaIx(meta);\n\n try {\n // Try to deserialize as versioned first\n const versionedTx = VersionedTransaction.deserialize(\n Buffer.from(txString, \"base64\")\n );\n\n // Check if this is actually a versioned transaction by checking if it has a MessageV0\n if (versionedTx.message instanceof MessageV0) {\n const msg = versionedTx.message;\n\n // Extend static account keys with programId if missing\n const newStaticKeys = [...msg.staticAccountKeys];\n if (!newStaticKeys.some((k) => k.equals(MEMO_PROGRAM_ID))) {\n newStaticKeys.push(MEMO_PROGRAM_ID);\n }\n\n // Program ID index\n const programIdIndex = newStaticKeys.findIndex((k) =>\n k.equals(MEMO_PROGRAM_ID)\n );\n\n // Memo instruction as compiled instruction\n const compiledIx = {\n programIdIndex,\n accountKeyIndexes: [],\n data: metaIx.data,\n };\n\n const newMsg = new MessageV0({\n header: msg.header,\n staticAccountKeys: newStaticKeys,\n recentBlockhash: msg.recentBlockhash,\n compiledInstructions: [...msg.compiledInstructions, compiledIx],\n addressTableLookups: msg.addressTableLookups,\n });\n\n // Re-wrap in VersionedTransaction\n const newTx = new VersionedTransaction(newMsg);\n // Preserve existing signatures if any\n newTx.signatures = versionedTx.signatures;\n\n return Buffer.from(newTx.serialize()).toString(\"base64\");\n } else {\n // This is likely a legacy transaction that was incorrectly deserialized as versioned\n // Fall back to legacy deserialization\n const legacyTx = Transaction.from(Buffer.from(txString, \"base64\"));\n\n // Legacy tx: just push memo instruction\n legacyTx.add(metaIx);\n\n return Buffer.from(\n legacyTx.serialize({ requireAllSignatures: false })\n ).toString(\"base64\");\n }\n } catch {\n try {\n // Fallback to legacy transaction\n const legacyTx = Transaction.from(Buffer.from(txString, \"base64\"));\n\n // Legacy tx: just push memo instruction\n legacyTx.add(metaIx);\n\n return Buffer.from(\n legacyTx.serialize({ requireAllSignatures: false })\n ).toString(\"base64\");\n } catch {\n throw ProtocolError.invalidTransactionFormat(\n \"Invalid base64 transaction format\"\n );\n }\n }\n }\n}\n",
20
- "import type {\n ActionCode,\n CodeGenerationConfig,\n DelegationProof,\n DelegatedActionCode,\n} from \"./types\";\nimport type {\n ChainAdapter,\n WalletContext,\n DelegatedContext,\n} from \"./adapters/BaseChainAdapter\";\nimport { WalletStrategy } from \"./strategy/WalletStrategy\";\nimport { DelegationStrategy } from \"./strategy/DelegationStrategy\";\nimport { SolanaAdapter } from \"./adapters/SolanaAdapter\";\nimport { ProtocolError } from \"./errors\";\n\nexport class ActionCodesProtocol {\n private adapters: Record<string, ChainAdapter> = {};\n private _walletStrategy: WalletStrategy;\n private _delegationStrategy: DelegationStrategy;\n\n constructor(private readonly config: CodeGenerationConfig) {\n // Register default adapters\n this.adapters.solana = new SolanaAdapter() as unknown as ChainAdapter;\n\n // Initialize strategies\n this._walletStrategy = new WalletStrategy(config);\n this._delegationStrategy = new DelegationStrategy(config);\n }\n\n public getConfig(): CodeGenerationConfig {\n return this.config;\n }\n\n /** Register a chain adapter */\n registerAdapter(chain: string, adapter: ChainAdapter): void {\n this.adapters[chain] = adapter;\n }\n\n /** Get a registered adapter */\n getAdapter(chain: string): ChainAdapter | undefined {\n return this.adapters[chain];\n }\n\n /** Typed access to specific adapters */\n get adapter() {\n return {\n solana: this.adapters.solana as unknown as SolanaAdapter,\n };\n }\n\n /** Access to strategies */\n get walletStrategy() {\n return this._walletStrategy;\n }\n\n get delegationStrategy() {\n return this._delegationStrategy;\n }\n\n // Generate code\n generateCode(\n strategy: \"wallet\",\n canonicalMessage: Uint8Array,\n signature: string,\n providedSecret?: string\n ): {\n actionCode: ActionCode;\n canonicalMessage: Uint8Array;\n };\n generateCode(\n strategy: \"delegation\",\n delegationProof: DelegationProof,\n delegatedSignature: string\n ): {\n actionCode: DelegatedActionCode;\n };\n generateCode(\n strategy: \"wallet\" | \"delegation\",\n param1: Uint8Array | DelegationProof,\n signature?: string,\n providedSecret?: string\n ): {\n actionCode: ActionCode | DelegatedActionCode;\n canonicalMessage?: Uint8Array;\n } {\n if (strategy === \"wallet\") {\n // Here param1 must be Uint8Array (canonical message)\n if (!signature) {\n throw ProtocolError.invalidSignature(\n \"Missing signature over canonical message\"\n );\n }\n return this.walletStrategy.generateCode(\n param1 as Uint8Array,\n signature,\n providedSecret\n );\n } else {\n // Here param1 must be DelegationProof\n if (!signature) {\n throw ProtocolError.invalidSignature(\"Missing delegated signature\");\n }\n return this.delegationStrategy.generateDelegatedCode(\n param1 as DelegationProof,\n signature\n );\n }\n }\n\n // Overloaded validateCode methods with strategy parameter\n validateCode(\n strategy: \"wallet\",\n actionCode: ActionCode,\n context?: WalletContext<unknown>\n ): void;\n validateCode(\n strategy: \"delegation\",\n actionCode: DelegatedActionCode,\n context?: DelegatedContext<unknown>\n ): void;\n validateCode(\n strategy: \"wallet\" | \"delegation\",\n actionCode: ActionCode | DelegatedActionCode,\n param2?: WalletContext<unknown> | DelegatedContext<unknown>\n ): void {\n if (strategy === \"wallet\") {\n // This will throw if validation fails\n this.walletStrategy.validateCode(actionCode as ActionCode);\n\n if (!param2) return;\n\n const context = param2 as Omit<WalletContext<unknown>, \"message\">;\n const adapter = this.getAdapter(context.chain);\n if (!adapter) throw ProtocolError.invalidAdapter(context.chain);\n\n const ok = adapter.verifyWithWallet({\n ...(context as Record<string, unknown>),\n message: {\n pubkey: (actionCode as ActionCode).pubkey,\n windowStart: (actionCode as ActionCode).timestamp,\n },\n } as unknown as WalletContext<unknown>);\n\n if (!ok) {\n throw new Error(\"Signature verification failed\");\n }\n } else {\n const context = param2 as Omit<DelegatedContext<unknown>, \"message\">;\n\n // CRITICAL: First validate the delegated action code\n // This ensures the code was actually generated from this delegation proof\n this.delegationStrategy.validateDelegatedCode(\n actionCode as DelegatedActionCode,\n context.delegationProof\n );\n\n // Then verify the delegation proof signature\n const adapter = this.getAdapter(context.chain);\n if (!adapter) throw ProtocolError.invalidAdapter(context.chain);\n\n const ok = adapter.verifyWithDelegation({\n ...(context as Record<string, unknown>),\n message: {\n pubkey: (actionCode as ActionCode).pubkey,\n windowStart: (actionCode as ActionCode).timestamp,\n },\n } as unknown as DelegatedContext<unknown>);\n\n if (!ok) {\n throw new Error(\"Signature verification failed\");\n }\n }\n }\n}\n"
17
+ "import type {\n ActionCode,\n CodeGenerationConfig,\n WalletStrategyCodeGenerationResult,\n} from \"../types\";\nimport {\n hmacSha256,\n truncateBits,\n digestToDigits,\n} from \"../utils/crypto\";\nimport { CODE_MAX_LENGTH, CODE_MIN_LENGTH } from \"../constants\";\nimport {\n serializeCanonical,\n getCanonicalMessageParts,\n} from \"../utils/canonical\";\nimport { ProtocolError } from \"../errors\";\nimport bs58 from \"bs58\";\n\nexport class WalletStrategy {\n constructor(private config: CodeGenerationConfig) {}\n\n generateCode(\n canonicalMessage: Uint8Array,\n signature: string\n ): WalletStrategyCodeGenerationResult {\n const canonical = canonicalMessage;\n\n // Parse pubkey and windowStart from canonical message\n const decoded = JSON.parse(new TextDecoder().decode(canonical));\n const pubkey = decoded.pubkey;\n const windowStart = decoded.windowStart;\n\n // Use signature as the primary entropy source\n // Decode Base58 signature to bytes\n const signatureBytes = bs58.decode(signature);\n const digest = hmacSha256(signatureBytes, canonical);\n\n const clamped = Math.max(\n CODE_MIN_LENGTH,\n Math.min(CODE_MAX_LENGTH, this.config.codeLength)\n );\n const bitsNeeded = 8 * Math.ceil(clamped / 2);\n const truncated = truncateBits(digest, bitsNeeded);\n const code = digestToDigits(truncated, clamped);\n\n const actionCode: ActionCode = {\n code,\n pubkey,\n timestamp: windowStart,\n expiresAt: windowStart + this.config.ttlMs,\n signature,\n };\n\n return { actionCode, canonicalMessage: canonical };\n }\n\n validateCode(actionCode: ActionCode): void {\n const currentTime = Date.now();\n if (currentTime > actionCode.expiresAt + (this.config.clockSkewMs ?? 0)) {\n throw ProtocolError.expiredCode(\n actionCode.code,\n actionCode.expiresAt,\n currentTime\n );\n }\n\n const canonical = serializeCanonical({\n pubkey: actionCode.pubkey,\n windowStart: actionCode.timestamp,\n });\n\n // Use same digest method as generation\n if (!actionCode.signature) {\n throw ProtocolError.missingRequiredField(\"signature\");\n }\n \n // Use signature as the primary entropy source\n // Decode Base58 signature to bytes\n const signatureBytes = bs58.decode(actionCode.signature);\n const digest = hmacSha256(signatureBytes, canonical);\n\n const clamped = Math.max(\n CODE_MIN_LENGTH,\n Math.min(CODE_MAX_LENGTH, this.config.codeLength)\n );\n const truncated = truncateBits(digest, 8 * Math.ceil(clamped / 2));\n const expected = digestToDigits(truncated, clamped);\n\n if (expected !== actionCode.code) {\n throw ProtocolError.invalidCode(expected, actionCode.code);\n }\n }\n\n // Instance method for accessing canonical functions\n getCanonicalMessageParts(pubkey: string): Uint8Array {\n return getCanonicalMessageParts(pubkey, this.config.ttlMs);\n }\n}\n",
18
+ "import { WalletStrategy } from \"./WalletStrategy\";\nimport { getCanonicalMessageParts } from \"../utils/canonical\";\nimport { ProtocolError } from \"../errors\";\nimport { PublicKey } from \"@solana/web3.js\";\n\nimport type {\n DelegationProof,\n DelegatedActionCode,\n CodeGenerationConfig,\n DelegationStrategyCodeGenerationResult,\n} from \"../types\";\n\nexport class DelegationStrategy {\n private walletStrategy: WalletStrategy;\n private config: CodeGenerationConfig;\n\n constructor(config: CodeGenerationConfig) {\n this.config = config;\n this.walletStrategy = new WalletStrategy(config);\n }\n\n /**\n * Generate a delegated action code using a delegation proof and delegated signature\n */\n generateDelegatedCode(\n delegationProof: DelegationProof,\n delegatedSignature: string\n ): DelegationStrategyCodeGenerationResult {\n // Validate delegation proof format and expiration\n this.validateDelegationProof(delegationProof);\n\n // Generate canonical message using the delegated pubkey\n const canonicalMessage = getCanonicalMessageParts(\n delegationProof.delegatedPubkey,\n this.config.ttlMs\n );\n\n // Generate code using existing WalletStrategy with canonical message\n const result = this.walletStrategy.generateCode(\n canonicalMessage,\n delegatedSignature // Use delegated signature\n );\n\n // Create delegated action code\n const delegatedActionCode: DelegatedActionCode = {\n ...result.actionCode,\n delegationProof: delegationProof,\n delegatedSignature: delegatedSignature,\n };\n\n return {\n actionCode: delegatedActionCode,\n };\n }\n\n /**\n * Validate a delegated action code\n */\n validateDelegatedCode(\n actionCode: DelegatedActionCode,\n delegationProof: DelegationProof\n ): void {\n // Validate the action code itself\n this.walletStrategy.validateCode(actionCode);\n\n // Verify delegation proof is still valid\n this.validateDelegationProof(delegationProof);\n\n // Verify the delegation proof matches the action code\n if (\n actionCode.delegationProof.walletPubkey !== delegationProof.walletPubkey\n ) {\n throw ProtocolError.invalidInput(\n \"walletPubkey\",\n actionCode.delegationProof.walletPubkey,\n \"Action code wallet pubkey does not match delegation proof\"\n );\n }\n\n if (\n actionCode.delegationProof.delegatedPubkey !==\n delegationProof.delegatedPubkey\n ) {\n throw ProtocolError.invalidInput(\n \"delegatedPubkey\",\n actionCode.delegationProof.delegatedPubkey,\n \"Invalid delegatedPubkey: Action code delegated pubkey does not match delegation proof\"\n );\n }\n\n if (actionCode.delegationProof.expiresAt !== delegationProof.expiresAt) {\n throw ProtocolError.invalidInput(\n \"expiresAt\",\n actionCode.delegationProof.expiresAt,\n \"Action code delegation expiration does not match delegation proof\"\n );\n }\n\n if (actionCode.delegationProof.signature !== delegationProof.signature) {\n throw ProtocolError.invalidInput(\n \"signature\",\n actionCode.delegationProof.signature,\n \"Invalid signature: Action code delegation signature does not match delegation proof\"\n );\n }\n\n // Verify delegated signature is present\n if (!actionCode.delegatedSignature) {\n throw ProtocolError.missingRequiredField(\"delegatedSignature\");\n }\n }\n\n /**\n * Validate a delegation proof with comprehensive input validation\n */\n private validateDelegationProof(delegationProof: DelegationProof): void {\n // Validate walletPubkey using Solana's PublicKey constructor\n if (!delegationProof.walletPubkey || typeof delegationProof.walletPubkey !== 'string') {\n throw ProtocolError.invalidInput(\"walletPubkey\", delegationProof.walletPubkey, \"Wallet pubkey is required and must be a string\");\n }\n try {\n new PublicKey(delegationProof.walletPubkey);\n } catch {\n throw ProtocolError.invalidInput(\"walletPubkey\", delegationProof.walletPubkey, \"Invalid wallet pubkey format\");\n }\n\n // Validate delegatedPubkey using Solana's PublicKey constructor\n if (!delegationProof.delegatedPubkey || typeof delegationProof.delegatedPubkey !== 'string') {\n throw ProtocolError.invalidInput(\"delegatedPubkey\", delegationProof.delegatedPubkey, \"Delegated pubkey is required and must be a string\");\n }\n try {\n new PublicKey(delegationProof.delegatedPubkey);\n } catch {\n throw ProtocolError.invalidInput(\"delegatedPubkey\", delegationProof.delegatedPubkey, \"Invalid delegated pubkey format\");\n }\n\n // Validate chain\n if (!delegationProof.chain || typeof delegationProof.chain !== 'string') {\n throw ProtocolError.invalidInput(\"chain\", delegationProof.chain, \"Chain is required and must be a string\");\n }\n if (delegationProof.chain.length === 0 || delegationProof.chain.length > 50) {\n throw ProtocolError.invalidInput(\"chain\", delegationProof.chain, \"Chain must be between 1 and 50 characters\");\n }\n if (!/^[a-z0-9-]+$/.test(delegationProof.chain)) {\n throw ProtocolError.invalidInput(\"chain\", delegationProof.chain, \"Chain contains invalid characters (only lowercase letters, numbers, and hyphens allowed)\");\n }\n\n // Validate expiresAt\n if (typeof delegationProof.expiresAt !== 'number' || !Number.isInteger(delegationProof.expiresAt)) {\n throw ProtocolError.invalidInput(\"expiresAt\", delegationProof.expiresAt, \"Expiration time must be a valid integer timestamp\");\n }\n if (delegationProof.expiresAt <= 0) {\n throw ProtocolError.invalidInput(\"expiresAt\", delegationProof.expiresAt, \"Expiration time must be positive\");\n }\n \n // Check for reasonable expiration bounds (not too far in the future)\n const now = Date.now();\n const maxFuture = 365 * 24 * 60 * 60 * 1000; // 1 year from now\n \n if (delegationProof.expiresAt > now + maxFuture) {\n throw ProtocolError.invalidInput(\"expiresAt\", delegationProof.expiresAt, \"Expiration time is too far in the future\");\n }\n\n // Check if delegation has expired\n if (delegationProof.expiresAt < now) {\n throw ProtocolError.expiredCode(\"Delegation proof has expired\", delegationProof.expiresAt, now);\n }\n\n // Validate signature\n if (!delegationProof.signature || typeof delegationProof.signature !== 'string') {\n throw ProtocolError.invalidInput(\"signature\", delegationProof.signature, \"Delegation signature is required and must be a string\");\n }\n if (delegationProof.signature.length === 0 || delegationProof.signature.length > 200) {\n throw ProtocolError.invalidInput(\"signature\", delegationProof.signature, \"Delegation signature must be between 1 and 200 characters\");\n }\n // Note: Signature format validation will be done during actual verification\n }\n\n /**\n * Get the wallet strategy instance for advanced usage\n */\n getWalletStrategy(): WalletStrategy {\n return this.walletStrategy;\n }\n\n /**\n * Get canonical message parts for delegation\n */\n getCanonicalMessageParts(pubkey: string): Uint8Array {\n return getCanonicalMessageParts(pubkey, this.config.ttlMs);\n }\n}\n",
19
+ "import nacl from \"tweetnacl\";\nimport bs58 from \"bs58\";\nimport {\n PublicKey,\n Transaction,\n VersionedTransaction,\n TransactionInstruction,\n MessageV0,\n} from \"@solana/web3.js\";\nimport { createMemoInstruction, MEMO_PROGRAM_ID } from \"@solana/spl-memo\";\nimport {\n BaseChainAdapter,\n type WalletContext,\n type WalletRevokeContext,\n type DelegatedContext,\n type DelegatedRevokeContext,\n} from \"./BaseChainAdapter\";\nimport {\n buildProtocolMeta,\n parseProtocolMeta,\n type ProtocolMetaFields,\n} from \"../utils/protocolMeta\";\nimport { codeHash } from \"../utils/crypto\";\nimport type { ActionCode } from \"../types\";\nimport { ProtocolError } from \"../errors\";\nimport {\n serializeCanonical,\n serializeCanonicalRevoke,\n serializeDelegationProof,\n} from \"../utils/canonical\";\n\nexport const ADAPTER_CHAIN_NAME = \"solana\" as const;\nexport type SolanaWalletContext = WalletContext<{\n chain: typeof ADAPTER_CHAIN_NAME;\n}>;\nexport type SolanaDelegatedContext = DelegatedContext<{\n chain: typeof ADAPTER_CHAIN_NAME;\n}>;\nexport type SolanaWalletRevokeContext = WalletRevokeContext<{\n chain: typeof ADAPTER_CHAIN_NAME;\n}>;\nexport type SolanaDelegatedRevokeContext = DelegatedRevokeContext<{\n chain: typeof ADAPTER_CHAIN_NAME;\n}>;\n\n/** Union of supported Solana txn types */\nexport type SolanaTransaction = Transaction | VersionedTransaction;\n\nexport class SolanaAdapter extends BaseChainAdapter<\n SolanaWalletContext,\n SolanaDelegatedContext,\n SolanaWalletRevokeContext,\n SolanaDelegatedRevokeContext\n> {\n /** Normalize pubkey input to PublicKey */\n private normalizePubkey(input: string | PublicKey): PublicKey {\n if (typeof input === \"string\") {\n return new PublicKey(input);\n }\n return input;\n }\n\n /** Verify the signature over canonical message (protocol-level) */\n verifyWithWallet(context: SolanaWalletContext): boolean {\n // Early validation checks - these are fast and don't leak timing info\n if (context.chain !== ADAPTER_CHAIN_NAME) return false;\n if (!context.message || !context.message.pubkey || !context.walletSignature)\n return false;\n\n // Perform all operations in a single try-catch to ensure consistent timing\n try {\n const message = serializeCanonical(context.message);\n const pub = this.normalizePubkey(context.message.pubkey);\n const sigBytes = bs58.decode(context.walletSignature);\n const pubBytes = pub.toBytes();\n\n // Validate lengths\n if (sigBytes.length !== 64 || pubBytes.length !== 32) {\n return false;\n }\n\n // Perform signature verification\n return nacl.sign.detached.verify(message, sigBytes, pubBytes);\n } catch {\n // All errors result in false with consistent timing\n return false;\n }\n }\n\n /** Verify delegation proof signature */\n verifyWithDelegation(context: SolanaDelegatedContext): boolean {\n // Early validation checks - these are fast and don't leak timing info\n if (context.chain !== ADAPTER_CHAIN_NAME) return false;\n if (\n !context.message.pubkey ||\n !context.delegatedSignature ||\n !context.delegationProof\n )\n return false;\n\n const proof = context.delegationProof;\n\n // Basic validation\n if (\n !proof.walletPubkey ||\n !proof.delegatedPubkey ||\n !proof.chain ||\n !proof.expiresAt ||\n !proof.signature\n ) {\n return false;\n }\n\n // Validate chain matches adapter\n if (proof.chain !== ADAPTER_CHAIN_NAME) {\n return false;\n }\n\n // The revoke/message pubkey for delegated flow must be the delegated pubkey\n if (proof.delegatedPubkey !== context.message.pubkey) return false;\n\n // Check if delegation has expired\n if (proof.expiresAt < Date.now()) return false;\n\n // Perform all operations in a single try-catch to ensure consistent timing\n try {\n const delegationMessage = serializeDelegationProof(proof);\n const walletPub = this.normalizePubkey(proof.walletPubkey);\n const walletSigBytes = bs58.decode(proof.signature);\n const walletPubBytes = walletPub.toBytes();\n \n const canonicalMessage = serializeCanonical(context.message);\n const delegatedPub = this.normalizePubkey(proof.delegatedPubkey);\n const delegatedSigBytes = bs58.decode(context.delegatedSignature);\n const delegatedPubBytes = delegatedPub.toBytes();\n \n // Validate lengths first to prevent timing attacks\n if (walletSigBytes.length !== 64 || walletPubBytes.length !== 32) {\n return false;\n }\n if (delegatedSigBytes.length !== 64 || delegatedPubBytes.length !== 32) {\n return false;\n }\n \n // Perform both signature verifications regardless of first result\n // This prevents timing attacks that could leak information about which signature failed\n const walletOk = nacl.sign.detached.verify(\n delegationMessage,\n walletSigBytes,\n walletPubBytes\n );\n \n const delegatedOk = nacl.sign.detached.verify(\n canonicalMessage,\n delegatedSigBytes,\n delegatedPubBytes\n );\n \n // Return result only after both operations complete\n return walletOk && delegatedOk;\n } catch {\n // All errors result in false with consistent timing\n return false;\n }\n }\n\n /** Verify the signature over canonical revoke message (protocol-level) */\n verifyRevokeWithWallet(context: SolanaWalletRevokeContext): boolean {\n // Early validation checks - these are fast and don't leak timing info\n if (context.chain !== ADAPTER_CHAIN_NAME) return false;\n if (!context.message || !context.message.pubkey || !context.walletSignature)\n return false;\n\n // Perform all operations in a single try-catch to ensure consistent timing\n try {\n const message = serializeCanonicalRevoke(context.message);\n const pub = this.normalizePubkey(context.message.pubkey);\n const sigBytes = bs58.decode(context.walletSignature);\n const pubBytes = pub.toBytes();\n\n // Validate lengths\n if (sigBytes.length !== 64 || pubBytes.length !== 32) {\n return false;\n }\n\n // Perform signature verification\n return nacl.sign.detached.verify(message, sigBytes, pubBytes);\n } catch {\n // All errors result in false with consistent timing\n return false;\n }\n }\n\n verifyRevokeWithDelegation(context: SolanaDelegatedRevokeContext): boolean {\n // Early validation checks - these are fast and don't leak timing info\n if (context.chain !== ADAPTER_CHAIN_NAME) return false;\n if (\n !context.message ||\n !context.message.pubkey ||\n !context.delegatedSignature ||\n !context.delegationProof\n )\n return false;\n\n const proof = context.delegationProof;\n\n // Basic validation\n if (\n !proof.walletPubkey ||\n !proof.delegatedPubkey ||\n !proof.chain ||\n !proof.expiresAt ||\n !proof.signature\n ) {\n return false;\n }\n\n // Validate chain matches adapter\n if (proof.chain !== ADAPTER_CHAIN_NAME) {\n return false;\n }\n\n // The revoke/message pubkey for delegated flow must be the delegated pubkey\n if (proof.delegatedPubkey !== context.message.pubkey) return false;\n\n // Check if delegation has expired\n if (proof.expiresAt < Date.now()) return false;\n\n try {\n const delegationMessage = serializeDelegationProof(proof);\n const walletPub = this.normalizePubkey(proof.walletPubkey);\n const walletSigBytes = bs58.decode(proof.signature);\n const walletPubBytes = walletPub.toBytes();\n if (walletSigBytes.length !== 64 || walletPubBytes.length !== 32) {\n return false;\n }\n const walletOk = nacl.sign.detached.verify(\n delegationMessage,\n walletSigBytes,\n walletPubBytes\n );\n if (!walletOk) return false;\n\n const revokeMessage = serializeCanonicalRevoke(context.message);\n const delegatedPub = this.normalizePubkey(proof.delegatedPubkey);\n const delegatedSigBytes = bs58.decode(context.delegatedSignature);\n const delegatedPubBytes = delegatedPub.toBytes();\n if (delegatedSigBytes.length !== 64 || delegatedPubBytes.length !== 32) {\n return false;\n }\n return nacl.sign.detached.verify(\n revokeMessage,\n delegatedSigBytes,\n delegatedPubBytes\n );\n } catch {\n // All errors result in false with consistent timing\n return false;\n }\n }\n\n /** Create a Solana memo instruction carrying protocol meta (for SDK/clients) */\n static createProtocolMetaIx(\n meta: ProtocolMetaFields\n ): TransactionInstruction {\n const metaString = buildProtocolMeta(meta);\n return createMemoInstruction(metaString);\n }\n\n /** Extract protocol metadata string (memo) from a base64-encoded transaction, or null */\n getProtocolMeta(txString: string): string | null {\n try {\n const tx = this.deserializeTransaction(txString);\n for (const ix of this.getMemoInstructions(tx)) {\n const data = ix.data;\n try {\n const s = new TextDecoder().decode(data);\n // Optionally: test parse\n const parsed = parseProtocolMeta(s);\n if (parsed) return s;\n } catch {\n // ignore\n }\n }\n return null;\n } catch {\n return null;\n }\n }\n\n /** Deserialize a base64-encoded transaction string to SolanaTransaction */\n private deserializeTransaction(txString: string): SolanaTransaction {\n try {\n // Try versioned first (most common now)\n const versionedTx = VersionedTransaction.deserialize(\n Buffer.from(txString, \"base64\")\n );\n\n // Check if this is actually a versioned transaction by checking if it has a MessageV0\n if (versionedTx.message instanceof MessageV0) {\n return versionedTx;\n } else {\n // This is likely a legacy transaction that was incorrectly deserialized as versioned\n // Fall back to legacy deserialization\n return Transaction.from(Buffer.from(txString, \"base64\"));\n }\n } catch {\n try {\n // Fallback to legacy\n return Transaction.from(Buffer.from(txString, \"base64\"));\n } catch {\n throw ProtocolError.invalidTransactionFormat(\n \"Invalid base64 transaction format\"\n );\n }\n }\n }\n\n /** Get parsed ProtocolMeta object from base64-encoded transaction, or null if none or invalid */\n parseMeta(txString: string): ProtocolMetaFields | null {\n const s = this.getProtocolMeta(txString);\n if (!s) return null;\n return parseProtocolMeta(s);\n }\n\n /** List memo instructions from the transaction (legacy & versioned) */\n private getMemoInstructions(tx: SolanaTransaction): TransactionInstruction[] {\n if (tx instanceof Transaction) {\n return tx.instructions.filter((ix) =>\n ix.programId.equals(MEMO_PROGRAM_ID)\n );\n } else {\n // VersionedTransaction: inspect `message.compiledInstructions` / static keys\n const vtx = tx as VersionedTransaction;\n const msg = vtx.message;\n if (msg instanceof MessageV0) {\n const memos: TransactionInstruction[] = [];\n for (const ix of msg.compiledInstructions) {\n const pid = msg.staticAccountKeys[ix.programIdIndex];\n if (pid && pid.equals(MEMO_PROGRAM_ID)) {\n // reconstruct a TransactionInstruction for inspection\n const keys = ix.accountKeyIndexes.map((i) => ({\n pubkey: msg.staticAccountKeys[i]!,\n isSigner: false,\n isWritable: false,\n }));\n memos.push(\n new TransactionInstruction({\n keys,\n programId: pid,\n data: ix.data as Buffer,\n })\n );\n }\n }\n return memos;\n }\n return [];\n }\n }\n\n /**\n * Validate that a base64-encoded transaction's memo meta aligns with the bound `actionCode`.\n * Throws ProtocolError if validation fails.\n */\n verifyTransactionMatchesCode(actionCode: ActionCode, txString: string): void {\n // Check expiration first\n const currentTime = Date.now();\n if (currentTime > actionCode.expiresAt) {\n throw ProtocolError.expiredCode(\n actionCode.code,\n actionCode.expiresAt,\n currentTime\n );\n }\n\n const meta = this.parseMeta(txString);\n if (!meta) {\n throw ProtocolError.missingMeta();\n }\n\n // Check version\n if (meta.ver !== 2) {\n throw ProtocolError.metaMismatch(\"2\", String(meta.ver), \"ver\");\n }\n\n // Check code ID - should be codeHash of the code, not the code itself\n const expectedCodeHash = codeHash(actionCode.code);\n if (meta.id !== expectedCodeHash) {\n throw ProtocolError.metaMismatch(expectedCodeHash, meta.id, \"id\");\n }\n\n // Check intended pubkey\n if (meta.int !== actionCode.pubkey) {\n throw ProtocolError.metaMismatch(actionCode.pubkey, meta.int, \"int\");\n }\n }\n\n /**\n * Verify that the base64-encoded transaction is signed by the \"intendedFor\" pubkey\n * as declared in the protocol meta of the transaction.\n * Throws ProtocolError if validation fails.\n */\n verifyTransactionSignedByIntentOwner(txString: string): void {\n const meta = this.parseMeta(txString);\n if (!meta) {\n throw ProtocolError.missingMeta();\n }\n\n const intended = meta.int;\n if (!intended) {\n throw ProtocolError.invalidMetaFormat(\n \"Missing 'int' (intendedFor) field\"\n );\n }\n\n let pubkey: PublicKey;\n try {\n pubkey = new PublicKey(intended);\n } catch {\n throw ProtocolError.invalidPubkeyFormat(\n intended,\n \"Invalid public key format\"\n );\n }\n\n const tx = this.deserializeTransaction(txString);\n const actualSigners: string[] = [];\n\n // For legacy Transaction\n if (tx instanceof Transaction) {\n const isSigned = tx.signatures.some((sig) => {\n if (!sig.signature) return false;\n actualSigners.push(sig.publicKey.toString());\n return sig.publicKey.equals(pubkey);\n });\n\n if (!isSigned) {\n throw ProtocolError.transactionNotSignedByIntendedOwner(\n intended,\n actualSigners\n );\n }\n return;\n }\n\n // For VersionedTransaction (MessageV0)\n if (tx instanceof VersionedTransaction) {\n const msg = tx.message;\n if (msg instanceof MessageV0) {\n const signerCount = msg.header.numRequiredSignatures;\n for (let i = 0; i < signerCount; i++) {\n const key = msg.staticAccountKeys[i];\n if (key) {\n actualSigners.push(key.toString());\n if (key.equals(pubkey)) {\n return; // Found the intended signer\n }\n }\n }\n throw ProtocolError.transactionNotSignedByIntendedOwner(\n intended,\n actualSigners\n );\n }\n }\n\n throw ProtocolError.invalidTransactionFormat(\n \"Unsupported transaction format\"\n );\n }\n\n /**\n * Attach protocol meta into a base64-encoded transaction and return the modified transaction as base64.\n * Throws ProtocolError if the transaction already contains protocol meta.\n */\n static attachProtocolMeta(\n txString: string,\n meta: ProtocolMetaFields\n ): string {\n // Check if transaction already has protocol meta\n const adapter = new SolanaAdapter();\n const existingMeta = adapter.getProtocolMeta(txString);\n if (existingMeta) {\n throw ProtocolError.invalidTransactionFormat(\n \"Transaction already contains protocol meta. Cannot attach additional protocol meta.\"\n );\n }\n\n const metaIx = SolanaAdapter.createProtocolMetaIx(meta);\n\n try {\n // Try to deserialize as versioned first\n const versionedTx = VersionedTransaction.deserialize(\n Buffer.from(txString, \"base64\")\n );\n\n // Check if this is actually a versioned transaction by checking if it has a MessageV0\n if (versionedTx.message instanceof MessageV0) {\n const msg = versionedTx.message;\n\n // Extend static account keys with programId if missing\n const newStaticKeys = [...msg.staticAccountKeys];\n if (!newStaticKeys.some((k) => k.equals(MEMO_PROGRAM_ID))) {\n newStaticKeys.push(MEMO_PROGRAM_ID);\n }\n\n // Program ID index\n const programIdIndex = newStaticKeys.findIndex((k) =>\n k.equals(MEMO_PROGRAM_ID)\n );\n\n // Memo instruction as compiled instruction\n const compiledIx = {\n programIdIndex,\n accountKeyIndexes: [],\n data: metaIx.data,\n };\n\n const newMsg = new MessageV0({\n header: msg.header,\n staticAccountKeys: newStaticKeys,\n recentBlockhash: msg.recentBlockhash,\n compiledInstructions: [...msg.compiledInstructions, compiledIx],\n addressTableLookups: msg.addressTableLookups,\n });\n\n // Re-wrap in VersionedTransaction\n const newTx = new VersionedTransaction(newMsg);\n // Preserve existing signatures if any\n newTx.signatures = versionedTx.signatures;\n\n return Buffer.from(newTx.serialize()).toString(\"base64\");\n } else {\n // This is likely a legacy transaction that was incorrectly deserialized as versioned\n // Fall back to legacy deserialization\n const legacyTx = Transaction.from(Buffer.from(txString, \"base64\"));\n\n // Legacy tx: just push memo instruction\n legacyTx.add(metaIx);\n\n return Buffer.from(\n legacyTx.serialize({ requireAllSignatures: false })\n ).toString(\"base64\");\n }\n } catch {\n try {\n // Fallback to legacy transaction\n const legacyTx = Transaction.from(Buffer.from(txString, \"base64\"));\n\n // Legacy tx: just push memo instruction\n legacyTx.add(metaIx);\n\n return Buffer.from(\n legacyTx.serialize({ requireAllSignatures: false })\n ).toString(\"base64\");\n } catch {\n throw ProtocolError.invalidTransactionFormat(\n \"Invalid base64 transaction format\"\n );\n }\n }\n }\n}\n",
20
+ "import type {\n ActionCode,\n CodeGenerationConfig,\n DelegationProof,\n DelegatedActionCode,\n} from \"./types\";\nimport type {\n ChainAdapter,\n WalletContext,\n DelegatedContext,\n} from \"./adapters/BaseChainAdapter\";\nimport { WalletStrategy } from \"./strategy/WalletStrategy\";\nimport { DelegationStrategy } from \"./strategy/DelegationStrategy\";\nimport { SolanaAdapter } from \"./adapters/SolanaAdapter\";\nimport { ProtocolError } from \"./errors\";\n\nexport class ActionCodesProtocol {\n private adapters: Record<string, ChainAdapter> = {};\n private _walletStrategy: WalletStrategy;\n private _delegationStrategy: DelegationStrategy;\n\n constructor(private readonly config: CodeGenerationConfig) {\n // Register default adapters\n this.adapters.solana = new SolanaAdapter() as unknown as ChainAdapter;\n\n // Initialize strategies\n this._walletStrategy = new WalletStrategy(config);\n this._delegationStrategy = new DelegationStrategy(config);\n }\n\n public getConfig(): CodeGenerationConfig {\n return this.config;\n }\n\n /** Register a chain adapter */\n registerAdapter(chain: string, adapter: ChainAdapter): void {\n this.adapters[chain] = adapter;\n }\n\n /** Get a registered adapter */\n getAdapter(chain: string): ChainAdapter | undefined {\n return this.adapters[chain];\n }\n\n /** Typed access to specific adapters */\n get adapter() {\n return {\n solana: this.adapters.solana as unknown as SolanaAdapter,\n };\n }\n\n /** Access to strategies */\n get walletStrategy() {\n return this._walletStrategy;\n }\n\n get delegationStrategy() {\n return this._delegationStrategy;\n }\n\n // Generate code\n generateCode(\n strategy: \"wallet\",\n canonicalMessage: Uint8Array,\n signature: string\n ): {\n actionCode: ActionCode;\n canonicalMessage: Uint8Array;\n };\n generateCode(\n strategy: \"delegation\",\n delegationProof: DelegationProof,\n delegatedSignature: string\n ): {\n actionCode: DelegatedActionCode;\n };\n generateCode(\n strategy: \"wallet\" | \"delegation\",\n param1: Uint8Array | DelegationProof,\n signature?: string\n ): {\n actionCode: ActionCode | DelegatedActionCode;\n canonicalMessage?: Uint8Array;\n } {\n if (strategy === \"wallet\") {\n // Here param1 must be Uint8Array (canonical message)\n if (!signature) {\n throw ProtocolError.invalidSignature(\n \"Missing signature over canonical message\"\n );\n }\n return this.walletStrategy.generateCode(param1 as Uint8Array, signature);\n } else {\n // Here param1 must be DelegationProof\n if (!signature) {\n throw ProtocolError.invalidSignature(\"Missing delegated signature\");\n }\n return this.delegationStrategy.generateDelegatedCode(\n param1 as DelegationProof,\n signature\n );\n }\n }\n\n // Overloaded validateCode methods with strategy parameter\n validateCode(\n strategy: \"wallet\",\n actionCode: ActionCode,\n context?: WalletContext<unknown>\n ): void;\n validateCode(\n strategy: \"delegation\",\n actionCode: DelegatedActionCode,\n context?: DelegatedContext<unknown>\n ): void;\n validateCode(\n strategy: \"wallet\" | \"delegation\",\n actionCode: ActionCode | DelegatedActionCode,\n param2?: WalletContext<unknown> | DelegatedContext<unknown>\n ): void {\n if (strategy === \"wallet\") {\n // This will throw if validation fails\n this.walletStrategy.validateCode(actionCode as ActionCode);\n\n if (!param2) return;\n\n const context = param2 as Omit<WalletContext<unknown>, \"message\">;\n const adapter = this.getAdapter(context.chain);\n if (!adapter) throw ProtocolError.invalidAdapter(context.chain);\n\n const ok = adapter.verifyWithWallet({\n ...(context as Record<string, unknown>),\n message: {\n pubkey: (actionCode as ActionCode).pubkey,\n windowStart: (actionCode as ActionCode).timestamp,\n },\n } as unknown as WalletContext<unknown>);\n\n if (!ok) {\n throw ProtocolError.invalidSignature(\n \"Wallet signature verification failed\"\n );\n }\n } else {\n const context = param2 as Omit<DelegatedContext<unknown>, \"message\">;\n\n // CRITICAL: First validate the delegated action code\n // This ensures the code was actually generated from this delegation proof\n this.delegationStrategy.validateDelegatedCode(\n actionCode as DelegatedActionCode,\n context.delegationProof\n );\n\n // Then verify the delegation proof signature\n const adapter = this.getAdapter(context.chain);\n if (!adapter) throw ProtocolError.invalidAdapter(context.chain);\n\n const ok = adapter.verifyWithDelegation({\n ...(context as Record<string, unknown>),\n message: {\n pubkey: (actionCode as ActionCode).pubkey,\n windowStart: (actionCode as ActionCode).timestamp,\n },\n } as unknown as DelegatedContext<unknown>);\n\n if (!ok) {\n throw ProtocolError.invalidSignature(\n \"Delegation signature verification failed\"\n );\n }\n }\n }\n}\n"
21
21
  ],
22
- "mappings": "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",
23
- "debugId": "AA589150D1EA6CB564756E2164756E21",
22
+ "mappings": "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",
23
+ "debugId": "856032EB4655E73B64756E2164756E21",
24
24
  "names": []
25
25
  }
@@ -13,7 +13,7 @@ export declare class DelegationStrategy {
13
13
  */
14
14
  validateDelegatedCode(actionCode: DelegatedActionCode, delegationProof: DelegationProof): void;
15
15
  /**
16
- * Validate a delegation proof
16
+ * Validate a delegation proof with comprehensive input validation
17
17
  */
18
18
  private validateDelegationProof;
19
19
  /**
@@ -23,6 +23,6 @@ export declare class DelegationStrategy {
23
23
  /**
24
24
  * Get canonical message parts for delegation
25
25
  */
26
- getCanonicalMessageParts(pubkey: string, providedSecret?: string): Uint8Array;
26
+ getCanonicalMessageParts(pubkey: string): Uint8Array;
27
27
  }
28
28
  //# sourceMappingURL=DelegationStrategy.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"DelegationStrategy.d.ts","sourceRoot":"","sources":["../../src/strategy/DelegationStrategy.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAElD,OAAO,KAAK,EACV,eAAe,EACf,mBAAmB,EACnB,oBAAoB,EACpB,sCAAsC,EACvC,MAAM,UAAU,CAAC;AAElB,qBAAa,kBAAkB;IAC7B,OAAO,CAAC,cAAc,CAAiB;IACvC,OAAO,CAAC,MAAM,CAAuB;gBAEzB,MAAM,EAAE,oBAAoB;IAKxC;;OAEG;IACH,qBAAqB,CACnB,eAAe,EAAE,eAAe,EAChC,kBAAkB,EAAE,MAAM,GACzB,sCAAsC;IA4BzC;;OAEG;IACH,qBAAqB,CACnB,UAAU,EAAE,mBAAmB,EAC/B,eAAe,EAAE,eAAe,GAC/B,IAAI;IA2CP;;OAEG;IACH,OAAO,CAAC,uBAAuB;IAuB/B;;OAEG;IACH,iBAAiB,IAAI,cAAc;IAInC;;OAEG;IACH,wBAAwB,CACtB,MAAM,EAAE,MAAM,EACd,cAAc,CAAC,EAAE,MAAM,GACtB,UAAU;CAGd"}
1
+ {"version":3,"file":"DelegationStrategy.d.ts","sourceRoot":"","sources":["../../src/strategy/DelegationStrategy.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAKlD,OAAO,KAAK,EACV,eAAe,EACf,mBAAmB,EACnB,oBAAoB,EACpB,sCAAsC,EACvC,MAAM,UAAU,CAAC;AAElB,qBAAa,kBAAkB;IAC7B,OAAO,CAAC,cAAc,CAAiB;IACvC,OAAO,CAAC,MAAM,CAAuB;gBAEzB,MAAM,EAAE,oBAAoB;IAKxC;;OAEG;IACH,qBAAqB,CACnB,eAAe,EAAE,eAAe,EAChC,kBAAkB,EAAE,MAAM,GACzB,sCAAsC;IA4BzC;;OAEG;IACH,qBAAqB,CACnB,UAAU,EAAE,mBAAmB,EAC/B,eAAe,EAAE,eAAe,GAC/B,IAAI;IAmDP;;OAEG;IACH,OAAO,CAAC,uBAAuB;IA+D/B;;OAEG;IACH,iBAAiB,IAAI,cAAc;IAInC;;OAEG;IACH,wBAAwB,CAAC,MAAM,EAAE,MAAM,GAAG,UAAU;CAGrD"}
@@ -2,8 +2,8 @@ import type { ActionCode, CodeGenerationConfig, WalletStrategyCodeGenerationResu
2
2
  export declare class WalletStrategy {
3
3
  private config;
4
4
  constructor(config: CodeGenerationConfig);
5
- generateCode(canonicalMessage: Uint8Array, signature: string, providedSecret?: string): WalletStrategyCodeGenerationResult;
5
+ generateCode(canonicalMessage: Uint8Array, signature: string): WalletStrategyCodeGenerationResult;
6
6
  validateCode(actionCode: ActionCode): void;
7
- getCanonicalMessageParts(pubkey: string, providedSecret?: string): Uint8Array;
7
+ getCanonicalMessageParts(pubkey: string): Uint8Array;
8
8
  }
9
9
  //# sourceMappingURL=WalletStrategy.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"WalletStrategy.d.ts","sourceRoot":"","sources":["../../src/strategy/WalletStrategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,UAAU,EACV,oBAAoB,EACpB,kCAAkC,EACnC,MAAM,UAAU,CAAC;AAelB,qBAAa,cAAc;IACb,OAAO,CAAC,MAAM;gBAAN,MAAM,EAAE,oBAAoB;IAEhD,YAAY,CACV,gBAAgB,EAAE,UAAU,EAC5B,SAAS,EAAE,MAAM,EACjB,cAAc,CAAC,EAAE,MAAM,GACtB,kCAAkC;IAgDrC,YAAY,CAAC,UAAU,EAAE,UAAU,GAAG,IAAI;IA4C1C,wBAAwB,CACtB,MAAM,EAAE,MAAM,EACd,cAAc,CAAC,EAAE,MAAM,GACtB,UAAU;CAGd"}
1
+ {"version":3,"file":"WalletStrategy.d.ts","sourceRoot":"","sources":["../../src/strategy/WalletStrategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,UAAU,EACV,oBAAoB,EACpB,kCAAkC,EACnC,MAAM,UAAU,CAAC;AAclB,qBAAa,cAAc;IACb,OAAO,CAAC,MAAM;gBAAN,MAAM,EAAE,oBAAoB;IAEhD,YAAY,CACV,gBAAgB,EAAE,UAAU,EAC5B,SAAS,EAAE,MAAM,GAChB,kCAAkC;IAgCrC,YAAY,CAAC,UAAU,EAAE,UAAU,GAAG,IAAI;IAsC1C,wBAAwB,CAAC,MAAM,EAAE,MAAM,GAAG,UAAU;CAGrD"}
package/dist/types.d.ts CHANGED
@@ -4,13 +4,10 @@ export interface ActionCode {
4
4
  timestamp: number;
5
5
  expiresAt: number;
6
6
  signature?: string;
7
- secretHint?: string;
8
- secret?: string;
9
7
  }
10
8
  export interface CanonicalMessageParts {
11
9
  pubkey: string;
12
10
  windowStart: number;
13
- secret?: string;
14
11
  }
15
12
  export interface CanonicalRevokeMessageParts {
16
13
  pubkey: string;
@@ -33,6 +30,7 @@ export interface DelegationProof {
33
30
  walletPubkey: string;
34
31
  delegatedPubkey: string;
35
32
  expiresAt: number;
33
+ chain: string;
36
34
  signature: string;
37
35
  }
38
36
  export interface DelegatedActionCode extends ActionCode {
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,UAAU;IACzB,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,UAAU,CAAC,EAAE,MAAM,CAAC;IAEpB,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,qBAAqB;IACpC,MAAM,EAAE,MAAM,CAAC;IACf,WAAW,EAAE,MAAM,CAAC;IAEpB,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,2BAA2B;IAC1C,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC;IACjB,WAAW,EAAE,MAAM,CAAC;CACrB;AAED,MAAM,WAAW,oBAAoB;IACnC,UAAU,EAAE,MAAM,CAAC;IACnB,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAED,MAAM,WAAW,kCAAkC;IACjD,UAAU,EAAE,UAAU,CAAC;IACvB,gBAAgB,EAAE,UAAU,CAAC;CAC9B;AAED,MAAM,WAAW,sCAAsC;IACrD,UAAU,EAAE,mBAAmB,CAAC;CACjC;AAED,MAAM,WAAW,eAAe;IAC9B,YAAY,EAAE,MAAM,CAAC;IACrB,eAAe,EAAE,MAAM,CAAC;IACxB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,mBAAoB,SAAQ,UAAU;IACrD,eAAe,EAAE,eAAe,CAAC;IACjC,kBAAkB,EAAE,MAAM,CAAC;CAC5B"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,UAAU;IACzB,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,qBAAqB;IACpC,MAAM,EAAE,MAAM,CAAC;IACf,WAAW,EAAE,MAAM,CAAC;CACrB;AAED,MAAM,WAAW,2BAA2B;IAC1C,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC;IACjB,WAAW,EAAE,MAAM,CAAC;CACrB;AAED,MAAM,WAAW,oBAAoB;IACnC,UAAU,EAAE,MAAM,CAAC;IACnB,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAED,MAAM,WAAW,kCAAkC;IACjD,UAAU,EAAE,UAAU,CAAC;IACvB,gBAAgB,EAAE,UAAU,CAAC;CAC9B;AAED,MAAM,WAAW,sCAAsC;IACrD,UAAU,EAAE,mBAAmB,CAAC;CACjC;AAED,MAAM,WAAW,eAAe;IAC9B,YAAY,EAAE,MAAM,CAAC;IACrB,eAAe,EAAE,MAAM,CAAC;IACxB,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,EAAE,MAAM,CAAC;IACd,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,mBAAoB,SAAQ,UAAU;IACrD,eAAe,EAAE,eAAe,CAAC;IACjC,kBAAkB,EAAE,MAAM,CAAC;CAC5B"}
@@ -4,6 +4,6 @@ export declare const CANONICAL_MESSAGE_PREFIX = "actioncodes";
4
4
  export declare const CANONICAL_REVOKE_MESSAGE_PREFIX = "actioncodes-revoke";
5
5
  export declare function serializeCanonical(parts: CanonicalMessageParts): Uint8Array;
6
6
  export declare function serializeCanonicalRevoke(parts: CanonicalRevokeMessageParts): Uint8Array;
7
- export declare function getCanonicalMessageParts(pubkey: string, ttlMs: number, providedSecret?: string): Uint8Array;
7
+ export declare function getCanonicalMessageParts(pubkey: string, ttlMs: number): Uint8Array;
8
8
  export declare function serializeDelegationProof(proof: DelegationProof): Uint8Array;
9
9
  //# sourceMappingURL=canonical.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"canonical.d.ts","sourceRoot":"","sources":["../../src/utils/canonical.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,qBAAqB,EACrB,2BAA2B,EAC3B,eAAe,EAChB,MAAM,UAAU,CAAC;AAElB,eAAO,MAAM,yBAAyB,IAAI,CAAC;AAC3C,eAAO,MAAM,wBAAwB,gBAAgB,CAAC;AACtD,eAAO,MAAM,+BAA+B,uBAAuB,CAAC;AAEpE,wBAAgB,kBAAkB,CAAC,KAAK,EAAE,qBAAqB,GAAG,UAAU,CAU3E;AAED,wBAAgB,wBAAwB,CACtC,KAAK,EAAE,2BAA2B,GACjC,UAAU,CASZ;AAED,wBAAgB,wBAAwB,CACtC,MAAM,EAAE,MAAM,EACd,KAAK,EAAE,MAAM,EACb,cAAc,CAAC,EAAE,MAAM,GACtB,UAAU,CAGZ;AAED,wBAAgB,wBAAwB,CAAC,KAAK,EAAE,eAAe,GAAG,UAAU,CAO3E"}
1
+ {"version":3,"file":"canonical.d.ts","sourceRoot":"","sources":["../../src/utils/canonical.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,qBAAqB,EACrB,2BAA2B,EAC3B,eAAe,EAChB,MAAM,UAAU,CAAC;AAElB,eAAO,MAAM,yBAAyB,IAAI,CAAC;AAC3C,eAAO,MAAM,wBAAwB,gBAAgB,CAAC;AACtD,eAAO,MAAM,+BAA+B,uBAAuB,CAAC;AAEpE,wBAAgB,kBAAkB,CAAC,KAAK,EAAE,qBAAqB,GAAG,UAAU,CAQ3E;AAED,wBAAgB,wBAAwB,CACtC,KAAK,EAAE,2BAA2B,GACjC,UAAU,CASZ;AAED,wBAAgB,wBAAwB,CACtC,MAAM,EAAE,MAAM,EACd,KAAK,EAAE,MAAM,GACZ,UAAU,CAGZ;AAED,wBAAgB,wBAAwB,CAAC,KAAK,EAAE,eAAe,GAAG,UAAU,CAQ3E"}
@@ -8,5 +8,4 @@ export declare function base32EncodeCrockford(data: Uint8Array): string;
8
8
  export declare function truncateBits(input: Uint8Array, totalBits: number): Uint8Array;
9
9
  export declare function digestToDigits(digest: Uint8Array, length: number): string;
10
10
  export declare function codeHash(code: string): string;
11
- export declare function generateRandomSecret(): string;
12
11
  //# sourceMappingURL=crypto.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"crypto.d.ts","sourceRoot":"","sources":["../../src/utils/crypto.ts"],"names":[],"mappings":"AASA,wBAAgB,MAAM,CAAC,IAAI,EAAE,UAAU,GAAG,MAAM,GAAG,UAAU,CAE5D;AAED,wBAAgB,UAAU,CACxB,GAAG,EAAE,UAAU,GAAG,MAAM,EACxB,IAAI,EAAE,UAAU,GAAG,MAAM,GACxB,UAAU,CAEZ;AAGD,wBAAgB,UAAU,CACxB,GAAG,EAAE,UAAU,GAAG,MAAM,EACxB,MAAM,EAAE,MAAM,EACd,EACE,IAAI,EACJ,IAAI,GACL,GAAE;IAAE,IAAI,CAAC,EAAE,UAAU,GAAG,MAAM,CAAC;IAAC,IAAI,CAAC,EAAE,UAAU,GAAG,MAAM,CAAA;CAAO,GACjE,UAAU,CAMZ;AAKD,wBAAgB,qBAAqB,CAAC,IAAI,EAAE,UAAU,GAAG,MAAM,CAgB9D;AAED,wBAAgB,YAAY,CAAC,KAAK,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,GAAG,UAAU,CAY7E;AAGD,wBAAgB,cAAc,CAAC,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM,CAkBzE;AAGD,wBAAgB,QAAQ,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CAK7C;AAGD,wBAAgB,oBAAoB,IAAI,MAAM,CAI7C"}
1
+ {"version":3,"file":"crypto.d.ts","sourceRoot":"","sources":["../../src/utils/crypto.ts"],"names":[],"mappings":"AASA,wBAAgB,MAAM,CAAC,IAAI,EAAE,UAAU,GAAG,MAAM,GAAG,UAAU,CAE5D;AAED,wBAAgB,UAAU,CACxB,GAAG,EAAE,UAAU,GAAG,MAAM,EACxB,IAAI,EAAE,UAAU,GAAG,MAAM,GACxB,UAAU,CAEZ;AAGD,wBAAgB,UAAU,CACxB,GAAG,EAAE,UAAU,GAAG,MAAM,EACxB,MAAM,EAAE,MAAM,EACd,EACE,IAAI,EACJ,IAAI,GACL,GAAE;IAAE,IAAI,CAAC,EAAE,UAAU,GAAG,MAAM,CAAC;IAAC,IAAI,CAAC,EAAE,UAAU,GAAG,MAAM,CAAA;CAAO,GACjE,UAAU,CAMZ;AAKD,wBAAgB,qBAAqB,CAAC,IAAI,EAAE,UAAU,GAAG,MAAM,CAgB9D;AAED,wBAAgB,YAAY,CAAC,KAAK,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,GAAG,UAAU,CAY7E;AAGD,wBAAgB,cAAc,CAAC,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM,CAkBzE;AAGD,wBAAgB,QAAQ,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CAK7C"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@actioncodes/protocol",
3
- "version": "2.0.10",
3
+ "version": "2.0.11",
4
4
  "module": "index.ts",
5
5
  "type": "module",
6
6
  "license": "Apache-2.0",