@gardenfi/utils 2.2.0-beta.1 → 2.2.1-beta.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (81) hide show
  1. package/dist/index195.cjs +1 -1
  2. package/dist/index195.js +3 -3
  3. package/dist/index225.cjs +1 -1
  4. package/dist/index225.js +2 -2
  5. package/dist/index228.cjs +1 -1
  6. package/dist/index228.js +2 -2
  7. package/dist/index229.cjs +1 -1
  8. package/dist/index229.js +1 -1
  9. package/dist/index234.cjs +1 -1
  10. package/dist/index234.js +1 -1
  11. package/dist/index235.cjs +1 -1
  12. package/dist/index235.js +1 -1
  13. package/dist/index236.cjs +1 -1
  14. package/dist/index236.js +2 -2
  15. package/dist/index248.cjs +1 -1
  16. package/dist/index248.js +1 -1
  17. package/dist/index249.cjs +1 -1
  18. package/dist/index249.js +1 -1
  19. package/dist/index28.cjs +1 -1
  20. package/dist/index28.js +2 -2
  21. package/dist/index280.cjs +1 -1
  22. package/dist/index280.js +103 -6
  23. package/dist/index281.cjs +1 -1
  24. package/dist/index281.js +7 -7
  25. package/dist/index282.cjs +1 -1
  26. package/dist/index282.js +223 -25
  27. package/dist/index283.cjs +1 -1
  28. package/dist/index283.js +6 -19
  29. package/dist/index284.cjs +1 -1
  30. package/dist/index284.js +7 -147
  31. package/dist/index285.cjs +1 -1
  32. package/dist/index285.js +24 -101
  33. package/dist/index286.cjs +1 -1
  34. package/dist/index286.js +19 -3
  35. package/dist/index287.cjs +1 -1
  36. package/dist/index287.js +140 -134
  37. package/dist/index288.cjs +1 -1
  38. package/dist/index288.js +3 -155
  39. package/dist/index289.cjs +1 -1
  40. package/dist/index289.js +138 -7
  41. package/dist/index290.cjs +1 -1
  42. package/dist/index290.js +155 -6
  43. package/dist/index291.cjs +1 -1
  44. package/dist/index291.js +8 -223
  45. package/dist/index292.cjs +1 -1
  46. package/dist/index292.js +2 -2
  47. package/dist/index293.cjs +1 -1
  48. package/dist/index293.js +2 -2
  49. package/dist/index294.cjs +1 -1
  50. package/dist/index294.js +138 -10
  51. package/dist/index295.cjs +1 -1
  52. package/dist/index295.js +42 -19
  53. package/dist/index296.cjs +1 -1
  54. package/dist/index296.js +73 -134
  55. package/dist/index297.cjs +1 -1
  56. package/dist/index297.js +2 -43
  57. package/dist/index298.cjs +1 -1
  58. package/dist/index298.js +10 -77
  59. package/dist/index299.cjs +1 -1
  60. package/dist/index299.js +20 -2
  61. package/dist/index301.cjs +1 -2
  62. package/dist/index301.js +695 -63
  63. package/dist/index302.cjs +1 -1
  64. package/dist/index302.js +201 -4
  65. package/dist/index303.cjs +2 -1
  66. package/dist/index303.js +65 -39
  67. package/dist/index304.cjs +1 -1
  68. package/dist/index304.js +4 -698
  69. package/dist/index305.cjs +1 -1
  70. package/dist/index305.js +40 -201
  71. package/dist/index306.cjs +1 -1
  72. package/dist/index306.js +1 -1
  73. package/dist/index307.cjs +1 -1
  74. package/dist/index307.js +1 -1
  75. package/dist/index308.cjs +1 -1
  76. package/dist/index308.js +1 -1
  77. package/dist/index310.cjs +1 -1
  78. package/dist/index310.js +2 -2
  79. package/dist/index311.cjs +1 -1
  80. package/dist/index311.js +3 -3
  81. package/package.json +1 -1
package/dist/index305.cjs CHANGED
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const y=require("./index296.cjs"),v=require("./index291.cjs");/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */const m=BigInt(0),h=BigInt(1);function b(t,r){const e=r.negate();return t?e:r}function B(t,r,e){const n=s=>s.pz,i=v.FpInvertBatch(t.Fp,e.map(n));return e.map((s,a)=>s.toAffine(i[a])).map(t.fromAffine)}function I(t,r){if(!Number.isSafeInteger(t)||t<=0||t>r)throw new Error("invalid window size, expected [1.."+r+"], got W="+t)}function E(t,r){I(t,r);const e=Math.ceil(r/t)+1,n=2**(t-1),i=2**t,o=y.bitMask(t),s=BigInt(t);return{windows:e,windowSize:n,mask:o,maxNumber:i,shiftBy:s}}function M(t,r,e){const{windowSize:n,mask:i,maxNumber:o,shiftBy:s}=e;let a=Number(t&i),f=t>>s;a>n&&(a-=o,f+=h);const d=r*n,c=d+Math.abs(a)-1,p=a===0,l=a<0,w=r%2!==0;return{nextN:f,offset:c,isZero:p,isNeg:l,isNegF:w,offsetF:d}}function O(t,r){if(!Array.isArray(t))throw new Error("array expected");t.forEach((e,n)=>{if(!(e instanceof r))throw new Error("invalid point at index "+n)})}function R(t,r){if(!Array.isArray(t))throw new Error("array of scalars expected");t.forEach((e,n)=>{if(!r.isValid(e))throw new Error("invalid scalar at index "+n)})}const N=new WeakMap,Z=new WeakMap;function A(t){return Z.get(t)||1}function x(t){if(t!==m)throw new Error("invalid wNAF")}function j(t,r){return{constTimeNegate:b,hasPrecomputes(e){return A(e)!==1},unsafeLadder(e,n,i=t.ZERO){let o=e;for(;n>m;)n&h&&(i=i.add(o)),o=o.double(),n>>=h;return i},precomputeWindow(e,n){const{windows:i,windowSize:o}=E(n,r),s=[];let a=e,f=a;for(let d=0;d<i;d++){f=a,s.push(f);for(let c=1;c<o;c++)f=f.add(a),s.push(f);a=f.double()}return s},wNAF(e,n,i){let o=t.ZERO,s=t.BASE;const a=E(e,r);for(let f=0;f<a.windows;f++){const{nextN:d,offset:c,isZero:p,isNeg:l,isNegF:w,offsetF:g}=M(i,f,a);i=d,p?s=s.add(b(w,n[g])):o=o.add(b(l,n[c]))}return x(i),{p:o,f:s}},wNAFUnsafe(e,n,i,o=t.ZERO){const s=E(e,r);for(let a=0;a<s.windows&&i!==m;a++){const{nextN:f,offset:d,isZero:c,isNeg:p}=M(i,a,s);if(i=f,!c){const l=n[d];o=o.add(p?l.negate():l)}}return x(i),o},getPrecomputes(e,n,i){let o=N.get(n);return o||(o=this.precomputeWindow(n,e),e!==1&&(typeof i=="function"&&(o=i(o)),N.set(n,o))),o},wNAFCached(e,n,i){const o=A(e);return this.wNAF(o,this.getPrecomputes(o,e,i),n)},wNAFCachedUnsafe(e,n,i,o){const s=A(e);return s===1?this.unsafeLadder(e,n,o):this.wNAFUnsafe(s,this.getPrecomputes(s,e,i),n,o)},setWindowSize(e,n){I(n,r),Z.set(e,n),N.delete(e)}}}function _(t,r,e,n){let i=r,o=t.ZERO,s=t.ZERO;for(;e>m||n>m;)e&h&&(o=o.add(i)),n&h&&(s=s.add(i)),i=i.double(),e>>=h,n>>=h;return{p1:o,p2:s}}function C(t,r,e,n){O(e,t),R(n,r);const i=e.length,o=n.length;if(i!==o)throw new Error("arrays of points and scalars must have equal length");const s=t.ZERO,a=y.bitLen(BigInt(i));let f=1;a>12?f=a-3:a>4?f=a-2:a>0&&(f=2);const d=y.bitMask(f),c=new Array(Number(d)+1).fill(s),p=Math.floor((r.BITS-1)/f)*f;let l=s;for(let w=p;w>=0;w-=f){c.fill(s);for(let u=0;u<o;u++){const F=n[u],S=Number(F>>BigInt(w)&d);c[S]=c[S].add(e[u])}let g=s;for(let u=c.length-1,F=s;u>0;u--)F=F.add(c[u]),g=g.add(F);if(l=l.add(g),w!==0)for(let u=0;u<f;u++)l=l.double()}return l}function z(t,r){if(r){if(r.ORDER!==t)throw new Error("Field.ORDER must match order: Fp == p, Fn == n");return v.validateField(r),r}else return v.Field(t)}function k(t,r,e={}){if(!r||typeof r!="object")throw new Error(`expected valid ${t} CURVE object`);for(const a of["p","n","h"]){const f=r[a];if(!(typeof f=="bigint"&&f>m))throw new Error(`CURVE.${a} must be positive bigint`)}const n=z(r.p,e.Fp),i=z(r.n,e.Fn),s=["Gx","Gy","a","b"];for(const a of s)if(!n.isValid(r[a]))throw new Error(`CURVE.${a} must be valid field element of CURVE.Fp`);return{Fp:n,Fn:i}}exports._createCurveFields=k;exports.mulEndoUnsafe=_;exports.negateCt=b;exports.normalizeZ=B;exports.pippenger=C;exports.wNAF=j;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const i=require("./index290.cjs");function n(t,e){if(i.size(t)>e)throw new i.SizeOverflowError({givenSize:i.size(t),maxSize:e})}function o(t,e){if(typeof e=="number"&&e>0&&e>i.size(t)-1)throw new i.SliceOffsetOutOfBoundsError({offset:e,position:"start",size:i.size(t)})}function z(t,e,r){if(typeof e=="number"&&typeof r=="number"&&i.size(t)!==r-e)throw new i.SliceOffsetOutOfBoundsError({offset:r,position:"end",size:i.size(t)})}function a(t,e={}){const{dir:r,size:s=32}=e;if(s===0)return t;const f=t.replace("0x","");if(f.length>s*2)throw new i.SizeExceedsPaddingSizeError({size:Math.ceil(f.length/2),targetSize:s,type:"Hex"});return`0x${f[r==="right"?"padEnd":"padStart"](s*2,"0")}`}exports.assertEndOffset=z;exports.assertSize=n;exports.assertStartOffset=o;exports.pad=a;
package/dist/index305.js CHANGED
@@ -1,204 +1,43 @@
1
- import { bitLen as B, bitMask as z } from "./index296.js";
2
- import { validateField as Z, Field as O, FpInvertBatch as R } from "./index291.js";
3
- /*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */
4
- const g = BigInt(0), h = BigInt(1);
5
- function b(t, r) {
6
- const e = r.negate();
7
- return t ? e : r;
8
- }
9
- function L(t, r, e) {
10
- const n = (s) => s.pz, i = R(t.Fp, e.map(n));
11
- return e.map((s, f) => s.toAffine(i[f])).map(t.fromAffine);
12
- }
13
- function I(t, r) {
14
- if (!Number.isSafeInteger(t) || t <= 0 || t > r)
15
- throw new Error("invalid window size, expected [1.." + r + "], got W=" + t);
16
- }
17
- function E(t, r) {
18
- I(t, r);
19
- const e = Math.ceil(r / t) + 1, n = 2 ** (t - 1), i = 2 ** t, o = z(t), s = BigInt(t);
20
- return { windows: e, windowSize: n, mask: o, maxNumber: i, shiftBy: s };
21
- }
22
- function v(t, r, e) {
23
- const { windowSize: n, mask: i, maxNumber: o, shiftBy: s } = e;
24
- let f = Number(t & i), a = t >> s;
25
- f > n && (f -= o, a += h);
26
- const d = r * n, c = d + Math.abs(f) - 1, p = f === 0, l = f < 0, u = r % 2 !== 0;
27
- return { nextN: a, offset: c, isZero: p, isNeg: l, isNegF: u, offsetF: d };
28
- }
29
- function j(t, r) {
30
- if (!Array.isArray(t))
31
- throw new Error("array expected");
32
- t.forEach((e, n) => {
33
- if (!(e instanceof r))
34
- throw new Error("invalid point at index " + n);
35
- });
36
- }
37
- function _(t, r) {
38
- if (!Array.isArray(t))
39
- throw new Error("array of scalars expected");
40
- t.forEach((e, n) => {
41
- if (!r.isValid(e))
42
- throw new Error("invalid scalar at index " + n);
43
- });
44
- }
45
- const N = /* @__PURE__ */ new WeakMap(), M = /* @__PURE__ */ new WeakMap();
46
- function A(t) {
47
- return M.get(t) || 1;
48
- }
49
- function S(t) {
50
- if (t !== g)
51
- throw new Error("invalid wNAF");
52
- }
53
- function U(t, r) {
54
- return {
55
- constTimeNegate: b,
56
- hasPrecomputes(e) {
57
- return A(e) !== 1;
58
- },
59
- // non-const time multiplication ladder
60
- unsafeLadder(e, n, i = t.ZERO) {
61
- let o = e;
62
- for (; n > g; )
63
- n & h && (i = i.add(o)), o = o.double(), n >>= h;
64
- return i;
65
- },
66
- /**
67
- * Creates a wNAF precomputation window. Used for caching.
68
- * Default window size is set by `utils.precompute()` and is equal to 8.
69
- * Number of precomputed points depends on the curve size:
70
- * 2^(𝑊−1) * (Math.ceil(𝑛 / 𝑊) + 1), where:
71
- * - 𝑊 is the window size
72
- * - 𝑛 is the bitlength of the curve order.
73
- * For a 256-bit curve and window size 8, the number of precomputed points is 128 * 33 = 4224.
74
- * @param elm Point instance
75
- * @param W window size
76
- * @returns precomputed point tables flattened to a single array
77
- */
78
- precomputeWindow(e, n) {
79
- const { windows: i, windowSize: o } = E(n, r), s = [];
80
- let f = e, a = f;
81
- for (let d = 0; d < i; d++) {
82
- a = f, s.push(a);
83
- for (let c = 1; c < o; c++)
84
- a = a.add(f), s.push(a);
85
- f = a.double();
86
- }
87
- return s;
88
- },
89
- /**
90
- * Implements ec multiplication using precomputed tables and w-ary non-adjacent form.
91
- * @param W window size
92
- * @param precomputes precomputed tables
93
- * @param n scalar (we don't check here, but should be less than curve order)
94
- * @returns real and fake (for const-time) points
95
- */
96
- wNAF(e, n, i) {
97
- let o = t.ZERO, s = t.BASE;
98
- const f = E(e, r);
99
- for (let a = 0; a < f.windows; a++) {
100
- const { nextN: d, offset: c, isZero: p, isNeg: l, isNegF: u, offsetF: m } = v(i, a, f);
101
- i = d, p ? s = s.add(b(u, n[m])) : o = o.add(b(l, n[c]));
102
- }
103
- return S(i), { p: o, f: s };
104
- },
105
- /**
106
- * Implements ec unsafe (non const-time) multiplication using precomputed tables and w-ary non-adjacent form.
107
- * @param W window size
108
- * @param precomputes precomputed tables
109
- * @param n scalar (we don't check here, but should be less than curve order)
110
- * @param acc accumulator point to add result of multiplication
111
- * @returns point
112
- */
113
- wNAFUnsafe(e, n, i, o = t.ZERO) {
114
- const s = E(e, r);
115
- for (let f = 0; f < s.windows && i !== g; f++) {
116
- const { nextN: a, offset: d, isZero: c, isNeg: p } = v(i, f, s);
117
- if (i = a, !c) {
118
- const l = n[d];
119
- o = o.add(p ? l.negate() : l);
120
- }
121
- }
122
- return S(i), o;
123
- },
124
- getPrecomputes(e, n, i) {
125
- let o = N.get(n);
126
- return o || (o = this.precomputeWindow(n, e), e !== 1 && (typeof i == "function" && (o = i(o)), N.set(n, o))), o;
127
- },
128
- wNAFCached(e, n, i) {
129
- const o = A(e);
130
- return this.wNAF(o, this.getPrecomputes(o, e, i), n);
131
- },
132
- wNAFCachedUnsafe(e, n, i, o) {
133
- const s = A(e);
134
- return s === 1 ? this.unsafeLadder(e, n, o) : this.wNAFUnsafe(s, this.getPrecomputes(s, e, i), n, o);
135
- },
136
- // We calculate precomputes for elliptic curve point multiplication
137
- // using windowed method. This specifies window size and
138
- // stores precomputed values. Usually only base point would be precomputed.
139
- setWindowSize(e, n) {
140
- I(n, r), M.set(e, n), N.delete(e);
141
- }
142
- };
143
- }
144
- function $(t, r, e, n) {
145
- let i = r, o = t.ZERO, s = t.ZERO;
146
- for (; e > g || n > g; )
147
- e & h && (o = o.add(i)), n & h && (s = s.add(i)), i = i.double(), e >>= h, n >>= h;
148
- return { p1: o, p2: s };
149
- }
150
- function D(t, r, e, n) {
151
- j(e, t), _(n, r);
152
- const i = e.length, o = n.length;
153
- if (i !== o)
154
- throw new Error("arrays of points and scalars must have equal length");
155
- const s = t.ZERO, f = B(BigInt(i));
156
- let a = 1;
157
- f > 12 ? a = f - 3 : f > 4 ? a = f - 2 : f > 0 && (a = 2);
158
- const d = z(a), c = new Array(Number(d) + 1).fill(s), p = Math.floor((r.BITS - 1) / a) * a;
159
- let l = s;
160
- for (let u = p; u >= 0; u -= a) {
161
- c.fill(s);
162
- for (let w = 0; w < o; w++) {
163
- const F = n[w], y = Number(F >> BigInt(u) & d);
164
- c[y] = c[y].add(e[w]);
165
- }
166
- let m = s;
167
- for (let w = c.length - 1, F = s; w > 0; w--)
168
- F = F.add(c[w]), m = m.add(F);
169
- if (l = l.add(m), u !== 0)
170
- for (let w = 0; w < a; w++)
171
- l = l.double();
172
- }
173
- return l;
174
- }
175
- function x(t, r) {
176
- if (r) {
177
- if (r.ORDER !== t)
178
- throw new Error("Field.ORDER must match order: Fp == p, Fn == n");
179
- return Z(r), r;
180
- } else
181
- return O(t);
182
- }
183
- function G(t, r, e = {}) {
184
- if (!r || typeof r != "object")
185
- throw new Error(`expected valid ${t} CURVE object`);
186
- for (const f of ["p", "n", "h"]) {
187
- const a = r[f];
188
- if (!(typeof a == "bigint" && a > g))
189
- throw new Error(`CURVE.${f} must be positive bigint`);
190
- }
191
- const n = x(r.p, e.Fp), i = x(r.n, e.Fn), s = ["Gx", "Gy", "a", "b"];
192
- for (const f of s)
193
- if (!n.isValid(r[f]))
194
- throw new Error(`CURVE.${f} must be valid field element of CURVE.Fp`);
195
- return { Fp: n, Fn: i };
1
+ import { SizeExceedsPaddingSizeError as s, size as i, SliceOffsetOutOfBoundsError as f, SizeOverflowError as p } from "./index290.js";
2
+ function c(t, e) {
3
+ if (i(t) > e)
4
+ throw new p({
5
+ givenSize: i(t),
6
+ maxSize: e
7
+ });
8
+ }
9
+ function S(t, e) {
10
+ if (typeof e == "number" && e > 0 && e > i(t) - 1)
11
+ throw new f({
12
+ offset: e,
13
+ position: "start",
14
+ size: i(t)
15
+ });
16
+ }
17
+ function d(t, e, r) {
18
+ if (typeof e == "number" && typeof r == "number" && i(t) !== r - e)
19
+ throw new f({
20
+ offset: r,
21
+ position: "end",
22
+ size: i(t)
23
+ });
24
+ }
25
+ function u(t, e = {}) {
26
+ const { dir: r, size: n = 32 } = e;
27
+ if (n === 0)
28
+ return t;
29
+ const o = t.replace("0x", "");
30
+ if (o.length > n * 2)
31
+ throw new s({
32
+ size: Math.ceil(o.length / 2),
33
+ targetSize: n,
34
+ type: "Hex"
35
+ });
36
+ return `0x${o[r === "right" ? "padEnd" : "padStart"](n * 2, "0")}`;
196
37
  }
197
38
  export {
198
- G as _createCurveFields,
199
- $ as mulEndoUnsafe,
200
- b as negateCt,
201
- L as normalizeZ,
202
- D as pippenger,
203
- U as wNAF
39
+ d as assertEndOffset,
40
+ c as assertSize,
41
+ S as assertStartOffset,
42
+ u as pad
204
43
  };
package/dist/index306.cjs CHANGED
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const c=require("./index228.cjs"),o=require("./index311.cjs"),n=require("./index288.cjs");function i(e,r={}){const{as:s=typeof e=="string"?"Hex":"Bytes"}=r,t=c.keccak_256(o.from(e));return s==="Bytes"?t:n.fromBytes(t)}exports.keccak256=i;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const c=require("./index228.cjs"),o=require("./index311.cjs"),n=require("./index290.cjs");function i(e,r={}){const{as:s=typeof e=="string"?"Hex":"Bytes"}=r,t=c.keccak_256(o.from(e));return s==="Bytes"?t:n.fromBytes(t)}exports.keccak256=i;
package/dist/index306.js CHANGED
@@ -1,6 +1,6 @@
1
1
  import { keccak_256 as f } from "./index228.js";
2
2
  import { from as m } from "./index311.js";
3
- import { fromBytes as s } from "./index288.js";
3
+ import { fromBytes as s } from "./index290.js";
4
4
  function p(t, o = {}) {
5
5
  const { as: e = typeof t == "string" ? "Hex" : "Bytes" } = o, r = f(m(t));
6
6
  return e === "Bytes" ? r : s(r);
package/dist/index307.cjs CHANGED
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const c=require("./index308.cjs"),a=require("./index301.cjs");function d(r){let i=!0,t="",e=0,n="",o=!1;for(let s=0;s<r.length;s++){const u=r[s];if(["(",")",","].includes(u)&&(i=!0),u==="("&&e++,u===")"&&e--,!!i){if(e===0){if(u===" "&&["event","function","error",""].includes(n))n="";else if(n+=u,u===")"){o=!0;break}continue}if(u===" "){r[s-1]!==","&&t!==","&&t!==",("&&(t="",i=!1);continue}n+=u,t+=u}}if(!o)throw new a.BaseError("Unable to normalize signature.");return n}function l(r,i){const t=typeof r,e=i.type;switch(e){case"address":return c.validate(r,{strict:!1});case"bool":return t==="boolean";case"function":return t==="string";case"string":return t==="string";default:return e==="tuple"&&"components"in i?Object.values(i.components).every((n,o)=>l(Object.values(r)[o],n)):/^u?int(8|16|24|32|40|48|56|64|72|80|88|96|104|112|120|128|136|144|152|160|168|176|184|192|200|208|216|224|232|240|248|256)?$/.test(e)?t==="number"||t==="bigint":/^bytes([1-9]|1[0-9]|2[0-9]|3[0-2])?$/.test(e)?t==="string"||r instanceof Uint8Array:/[a-z]+[1-9]{0,3}(\[[0-9]{0,}\])+$/.test(e)?Array.isArray(r)&&r.every(n=>l(n,{...i,type:e.replace(/(\[[0-9]{0,}\])$/,"")})):!1}}function f(r,i,t){for(const e in r){const n=r[e],o=i[e];if(n.type==="tuple"&&o.type==="tuple"&&"components"in n&&"components"in o)return f(n.components,o.components,t[e]);const s=[n.type,o.type];if(s.includes("address")&&s.includes("bytes20")?!0:s.includes("address")&&s.includes("string")?c.validate(t[e],{strict:!1}):s.includes("address")&&s.includes("bytes")?c.validate(t[e],{strict:!1}):!1)return s}}exports.getAmbiguousTypes=f;exports.isArgOfType=l;exports.normalizeSignature=d;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const c=require("./index308.cjs"),a=require("./index303.cjs");function d(r){let i=!0,t="",e=0,n="",o=!1;for(let s=0;s<r.length;s++){const u=r[s];if(["(",")",","].includes(u)&&(i=!0),u==="("&&e++,u===")"&&e--,!!i){if(e===0){if(u===" "&&["event","function","error",""].includes(n))n="";else if(n+=u,u===")"){o=!0;break}continue}if(u===" "){r[s-1]!==","&&t!==","&&t!==",("&&(t="",i=!1);continue}n+=u,t+=u}}if(!o)throw new a.BaseError("Unable to normalize signature.");return n}function l(r,i){const t=typeof r,e=i.type;switch(e){case"address":return c.validate(r,{strict:!1});case"bool":return t==="boolean";case"function":return t==="string";case"string":return t==="string";default:return e==="tuple"&&"components"in i?Object.values(i.components).every((n,o)=>l(Object.values(r)[o],n)):/^u?int(8|16|24|32|40|48|56|64|72|80|88|96|104|112|120|128|136|144|152|160|168|176|184|192|200|208|216|224|232|240|248|256)?$/.test(e)?t==="number"||t==="bigint":/^bytes([1-9]|1[0-9]|2[0-9]|3[0-2])?$/.test(e)?t==="string"||r instanceof Uint8Array:/[a-z]+[1-9]{0,3}(\[[0-9]{0,}\])+$/.test(e)?Array.isArray(r)&&r.every(n=>l(n,{...i,type:e.replace(/(\[[0-9]{0,}\])$/,"")})):!1}}function f(r,i,t){for(const e in r){const n=r[e],o=i[e];if(n.type==="tuple"&&o.type==="tuple"&&"components"in n&&"components"in o)return f(n.components,o.components,t[e]);const s=[n.type,o.type];if(s.includes("address")&&s.includes("bytes20")?!0:s.includes("address")&&s.includes("string")?c.validate(t[e],{strict:!1}):s.includes("address")&&s.includes("bytes")?c.validate(t[e],{strict:!1}):!1)return s}}exports.getAmbiguousTypes=f;exports.isArgOfType=l;exports.normalizeSignature=d;
package/dist/index307.js CHANGED
@@ -1,5 +1,5 @@
1
1
  import { validate as c } from "./index308.js";
2
- import { BaseError as f } from "./index301.js";
2
+ import { BaseError as f } from "./index303.js";
3
3
  function y(r) {
4
4
  let i = !0, t = "", e = 0, n = "", o = !1;
5
5
  for (let s = 0; s < r.length; s++) {
package/dist/index308.cjs CHANGED
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const f=require("./index311.cjs"),c=require("./index314.cjs"),o=require("./index301.cjs"),m=require("./index306.cjs"),b=/^0x[a-fA-F0-9]{40}$/;function i(e,t={}){const{strict:s=!0}=t;if(!b.test(e))throw new a({address:e,cause:new l});if(s){if(e.toLowerCase()===e)return;if(d(e)!==e)throw new a({address:e,cause:new h})}}function d(e){if(c.checksum.has(e))return c.checksum.get(e);i(e,{strict:!1});const t=e.substring(2).toLowerCase(),s=m.keccak256(f.fromString(t),{as:"Bytes"}),n=t.split("");for(let r=0;r<40;r+=2)s[r>>1]>>4>=8&&n[r]&&(n[r]=n[r].toUpperCase()),(s[r>>1]&15)>=8&&n[r+1]&&(n[r+1]=n[r+1].toUpperCase());const u=`0x${n.join("")}`;return c.checksum.set(e,u),u}function p(e,t={}){const{strict:s=!0}=t??{};try{return i(e,{strict:s}),!0}catch{return!1}}class a extends o.BaseError{constructor({address:t,cause:s}){super(`Address "${t}" is invalid.`,{cause:s}),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"Address.InvalidAddressError"})}}class l extends o.BaseError{constructor(){super("Address is not a 20 byte (40 hexadecimal character) value."),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"Address.InvalidInputError"})}}class h extends o.BaseError{constructor(){super("Address does not match its checksum counterpart."),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"Address.InvalidChecksumError"})}}exports.InvalidAddressError=a;exports.InvalidChecksumError=h;exports.InvalidInputError=l;exports.assert=i;exports.checksum=d;exports.validate=p;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const f=require("./index311.cjs"),c=require("./index314.cjs"),o=require("./index303.cjs"),m=require("./index306.cjs"),b=/^0x[a-fA-F0-9]{40}$/;function i(e,t={}){const{strict:s=!0}=t;if(!b.test(e))throw new a({address:e,cause:new l});if(s){if(e.toLowerCase()===e)return;if(d(e)!==e)throw new a({address:e,cause:new h})}}function d(e){if(c.checksum.has(e))return c.checksum.get(e);i(e,{strict:!1});const t=e.substring(2).toLowerCase(),s=m.keccak256(f.fromString(t),{as:"Bytes"}),n=t.split("");for(let r=0;r<40;r+=2)s[r>>1]>>4>=8&&n[r]&&(n[r]=n[r].toUpperCase()),(s[r>>1]&15)>=8&&n[r+1]&&(n[r+1]=n[r+1].toUpperCase());const u=`0x${n.join("")}`;return c.checksum.set(e,u),u}function p(e,t={}){const{strict:s=!0}=t??{};try{return i(e,{strict:s}),!0}catch{return!1}}class a extends o.BaseError{constructor({address:t,cause:s}){super(`Address "${t}" is invalid.`,{cause:s}),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"Address.InvalidAddressError"})}}class l extends o.BaseError{constructor(){super("Address is not a 20 byte (40 hexadecimal character) value."),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"Address.InvalidInputError"})}}class h extends o.BaseError{constructor(){super("Address does not match its checksum counterpart."),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"Address.InvalidChecksumError"})}}exports.InvalidAddressError=a;exports.InvalidChecksumError=h;exports.InvalidInputError=l;exports.assert=i;exports.checksum=d;exports.validate=p;
package/dist/index308.js CHANGED
@@ -1,6 +1,6 @@
1
1
  import { fromString as d } from "./index311.js";
2
2
  import { checksum as o } from "./index314.js";
3
- import { BaseError as c } from "./index301.js";
3
+ import { BaseError as c } from "./index303.js";
4
4
  import { keccak256 as f } from "./index306.js";
5
5
  const l = /^0x[a-fA-F0-9]{40}$/;
6
6
  function u(r, t = {}) {
package/dist/index310.cjs CHANGED
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const m=require("./index293.cjs"),w=require("./index308.cjs"),N=require("./index301.cjs"),c=require("./index288.cjs"),x=require("./index309.cjs");function P({checksumAddress:e,parameters:r,values:n}){const t=[];for(let o=0;o<r.length;o++)t.push(f({checksumAddress:e,parameter:r[o],value:n[o]}));return t}function f({checksumAddress:e=!1,parameter:r,value:n}){const t=r,o=S(t.type);if(o){const[i,s]=o;return h(n,{checksumAddress:e,length:i,parameter:{...t,type:s}})}if(t.type==="tuple")return A(n,{checksumAddress:e,parameter:t});if(t.type==="address")return y(n,{checksum:e});if(t.type==="bool")return g(n);if(t.type.startsWith("uint")||t.type.startsWith("int")){const i=t.type.startsWith("int"),[,,s="256"]=x.integerRegex.exec(t.type)??[];return b(n,{signed:i,size:Number(s)})}if(t.type.startsWith("bytes"))return l(n,{type:t.type});if(t.type==="string")return z(n);throw new m.InvalidTypeError(t.type)}function u(e){let r=0;for(let i=0;i<e.length;i++){const{dynamic:s,encoded:a}=e[i];s?r+=32:r+=c.size(a)}const n=[],t=[];let o=0;for(let i=0;i<e.length;i++){const{dynamic:s,encoded:a}=e[i];s?(n.push(c.fromNumber(r+o,{size:32})),t.push(a),o+=c.size(a)):n.push(a)}return c.concat(...n,...t)}function y(e,r){const{checksum:n=!1}=r;return w.assert(e,{strict:n}),{dynamic:!1,encoded:c.padLeft(e.toLowerCase())}}function h(e,r){const{checksumAddress:n,length:t,parameter:o}=r,i=t===null;if(!Array.isArray(e))throw new m.InvalidArrayError(e);if(!i&&e.length!==t)throw new m.ArrayLengthMismatchError({expectedLength:t,givenLength:e.length,type:`${o.type}[${t}]`});let s=!1;const a=[];for(let d=0;d<e.length;d++){const p=f({checksumAddress:n,parameter:o,value:e[d]});p.dynamic&&(s=!0),a.push(p)}if(i||s){const d=u(a);if(i){const p=c.fromNumber(a.length,{size:32});return{dynamic:!0,encoded:a.length>0?c.concat(p,d):p}}if(s)return{dynamic:!0,encoded:d}}return{dynamic:!1,encoded:c.concat(...a.map(({encoded:d})=>d))}}function l(e,{type:r}){const[,n]=r.split("bytes"),t=c.size(e);if(!n){let o=e;return t%32!==0&&(o=c.padRight(o,Math.ceil((e.length-2)/2/32)*32)),{dynamic:!0,encoded:c.concat(c.padLeft(c.fromNumber(t,{size:32})),o)}}if(t!==Number.parseInt(n))throw new m.BytesSizeMismatchError({expectedSize:Number.parseInt(n),value:e});return{dynamic:!1,encoded:c.padRight(e)}}function g(e){if(typeof e!="boolean")throw new N.BaseError(`Invalid boolean value: "${e}" (type: ${typeof e}). Expected: \`true\` or \`false\`.`);return{dynamic:!1,encoded:c.padLeft(c.fromBoolean(e))}}function b(e,{signed:r,size:n}){if(typeof n=="number"){const t=2n**(BigInt(n)-(r?1n:0n))-1n,o=r?-t-1n:0n;if(e>t||e<o)throw new c.IntegerOutOfRangeError({max:t.toString(),min:o.toString(),signed:r,size:n/8,value:e.toString()})}return{dynamic:!1,encoded:c.fromNumber(e,{size:32,signed:r})}}function z(e){const r=c.fromString(e),n=Math.ceil(c.size(r)/32),t=[];for(let o=0;o<n;o++)t.push(c.padRight(c.slice(r,o*32,(o+1)*32)));return{dynamic:!0,encoded:c.concat(c.padRight(c.fromNumber(c.size(r),{size:32})),...t)}}function A(e,r){const{checksumAddress:n,parameter:t}=r;let o=!1;const i=[];for(let s=0;s<t.components.length;s++){const a=t.components[s],d=Array.isArray(e)?s:a.name,p=f({checksumAddress:n,parameter:a,value:e[d]});i.push(p),p.dynamic&&(o=!0)}return{dynamic:o,encoded:o?u(i):c.concat(...i.map(({encoded:s})=>s))}}function S(e){const r=e.match(/^(.*)\[(\d+)?\]$/);return r?[r[2]?Number(r[2]):null,r[1]]:void 0}exports.encode=u;exports.encodeAddress=y;exports.encodeArray=h;exports.encodeBoolean=g;exports.encodeBytes=l;exports.encodeNumber=b;exports.encodeString=z;exports.encodeTuple=A;exports.getArrayComponents=S;exports.prepareParameter=f;exports.prepareParameters=P;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const m=require("./index293.cjs"),w=require("./index308.cjs"),N=require("./index303.cjs"),c=require("./index290.cjs"),x=require("./index309.cjs");function P({checksumAddress:e,parameters:r,values:n}){const t=[];for(let o=0;o<r.length;o++)t.push(f({checksumAddress:e,parameter:r[o],value:n[o]}));return t}function f({checksumAddress:e=!1,parameter:r,value:n}){const t=r,o=S(t.type);if(o){const[i,s]=o;return h(n,{checksumAddress:e,length:i,parameter:{...t,type:s}})}if(t.type==="tuple")return A(n,{checksumAddress:e,parameter:t});if(t.type==="address")return y(n,{checksum:e});if(t.type==="bool")return g(n);if(t.type.startsWith("uint")||t.type.startsWith("int")){const i=t.type.startsWith("int"),[,,s="256"]=x.integerRegex.exec(t.type)??[];return b(n,{signed:i,size:Number(s)})}if(t.type.startsWith("bytes"))return l(n,{type:t.type});if(t.type==="string")return z(n);throw new m.InvalidTypeError(t.type)}function u(e){let r=0;for(let i=0;i<e.length;i++){const{dynamic:s,encoded:a}=e[i];s?r+=32:r+=c.size(a)}const n=[],t=[];let o=0;for(let i=0;i<e.length;i++){const{dynamic:s,encoded:a}=e[i];s?(n.push(c.fromNumber(r+o,{size:32})),t.push(a),o+=c.size(a)):n.push(a)}return c.concat(...n,...t)}function y(e,r){const{checksum:n=!1}=r;return w.assert(e,{strict:n}),{dynamic:!1,encoded:c.padLeft(e.toLowerCase())}}function h(e,r){const{checksumAddress:n,length:t,parameter:o}=r,i=t===null;if(!Array.isArray(e))throw new m.InvalidArrayError(e);if(!i&&e.length!==t)throw new m.ArrayLengthMismatchError({expectedLength:t,givenLength:e.length,type:`${o.type}[${t}]`});let s=!1;const a=[];for(let d=0;d<e.length;d++){const p=f({checksumAddress:n,parameter:o,value:e[d]});p.dynamic&&(s=!0),a.push(p)}if(i||s){const d=u(a);if(i){const p=c.fromNumber(a.length,{size:32});return{dynamic:!0,encoded:a.length>0?c.concat(p,d):p}}if(s)return{dynamic:!0,encoded:d}}return{dynamic:!1,encoded:c.concat(...a.map(({encoded:d})=>d))}}function l(e,{type:r}){const[,n]=r.split("bytes"),t=c.size(e);if(!n){let o=e;return t%32!==0&&(o=c.padRight(o,Math.ceil((e.length-2)/2/32)*32)),{dynamic:!0,encoded:c.concat(c.padLeft(c.fromNumber(t,{size:32})),o)}}if(t!==Number.parseInt(n))throw new m.BytesSizeMismatchError({expectedSize:Number.parseInt(n),value:e});return{dynamic:!1,encoded:c.padRight(e)}}function g(e){if(typeof e!="boolean")throw new N.BaseError(`Invalid boolean value: "${e}" (type: ${typeof e}). Expected: \`true\` or \`false\`.`);return{dynamic:!1,encoded:c.padLeft(c.fromBoolean(e))}}function b(e,{signed:r,size:n}){if(typeof n=="number"){const t=2n**(BigInt(n)-(r?1n:0n))-1n,o=r?-t-1n:0n;if(e>t||e<o)throw new c.IntegerOutOfRangeError({max:t.toString(),min:o.toString(),signed:r,size:n/8,value:e.toString()})}return{dynamic:!1,encoded:c.fromNumber(e,{size:32,signed:r})}}function z(e){const r=c.fromString(e),n=Math.ceil(c.size(r)/32),t=[];for(let o=0;o<n;o++)t.push(c.padRight(c.slice(r,o*32,(o+1)*32)));return{dynamic:!0,encoded:c.concat(c.padRight(c.fromNumber(c.size(r),{size:32})),...t)}}function A(e,r){const{checksumAddress:n,parameter:t}=r;let o=!1;const i=[];for(let s=0;s<t.components.length;s++){const a=t.components[s],d=Array.isArray(e)?s:a.name,p=f({checksumAddress:n,parameter:a,value:e[d]});i.push(p),p.dynamic&&(o=!0)}return{dynamic:o,encoded:o?u(i):c.concat(...i.map(({encoded:s})=>s))}}function S(e){const r=e.match(/^(.*)\[(\d+)?\]$/);return r?[r[2]?Number(r[2]):null,r[1]]:void 0}exports.encode=u;exports.encodeAddress=y;exports.encodeArray=h;exports.encodeBoolean=g;exports.encodeBytes=l;exports.encodeNumber=b;exports.encodeString=z;exports.encodeTuple=A;exports.getArrayComponents=S;exports.prepareParameter=f;exports.prepareParameters=P;
package/dist/index310.js CHANGED
@@ -1,7 +1,7 @@
1
1
  import { InvalidTypeError as g, InvalidArrayError as b, ArrayLengthMismatchError as w, BytesSizeMismatchError as z } from "./index293.js";
2
2
  import { assert as x } from "./index308.js";
3
- import { BaseError as S } from "./index301.js";
4
- import { size as d, fromNumber as f, concat as p, padLeft as h, fromBoolean as A, IntegerOutOfRangeError as E, padRight as y, fromString as I, slice as B } from "./index288.js";
3
+ import { BaseError as S } from "./index303.js";
4
+ import { size as d, fromNumber as f, concat as p, padLeft as h, fromBoolean as A, IntegerOutOfRangeError as E, padRight as y, fromString as I, slice as B } from "./index290.js";
5
5
  import { integerRegex as L } from "./index309.js";
6
6
  function q({ checksumAddress: e, parameters: n, values: r }) {
7
7
  const t = [];
package/dist/index311.cjs CHANGED
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const a=require("./index301.cjs"),y=require("./index288.cjs"),s=require("./index312.cjs"),z=require("./index303.cjs"),S=new TextEncoder;function x(e){return e instanceof Uint8Array?e:typeof e=="string"?h(e):g(e)}function g(e){return e instanceof Uint8Array?e:new Uint8Array(e)}function h(e,t={}){const{size:r}=t;let n=e;r&&(z.assertSize(e,r),n=y.padRight(e,r));let i=n.slice(2);i.length%2&&(i=`0${i}`);const d=i.length/2,f=new Uint8Array(d);for(let c=0,o=0;c<d;c++){const u=s.charCodeToBase16(i.charCodeAt(o++)),b=s.charCodeToBase16(i.charCodeAt(o++));if(u===void 0||b===void 0)throw new a.BaseError(`Invalid byte sequence ("${i[o-2]}${i[o-1]}" in "${i}").`);f[c]=u*16+b}return f}function m(e,t={}){const{size:r}=t,n=S.encode(e);return typeof r=="number"?(s.assertSize(n,r),l(n,r)):n}function l(e,t){return s.pad(e,{dir:"right",size:t})}function E(e){return e.length}class p extends a.BaseError{constructor({givenSize:t,maxSize:r}){super(`Size cannot exceed \`${r}\` bytes. Given size: \`${t}\` bytes.`),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"Bytes.SizeOverflowError"})}}class $ extends a.BaseError{constructor({size:t,targetSize:r,type:n}){super(`${n.charAt(0).toUpperCase()}${n.slice(1).toLowerCase()} size (\`${t}\`) exceeds padding size (\`${r}\`).`),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"Bytes.SizeExceedsPaddingSizeError"})}}exports.SizeExceedsPaddingSizeError=$;exports.SizeOverflowError=p;exports.from=x;exports.fromArray=g;exports.fromHex=h;exports.fromString=m;exports.padRight=l;exports.size=E;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const a=require("./index303.cjs"),y=require("./index290.cjs"),s=require("./index312.cjs"),z=require("./index305.cjs"),S=new TextEncoder;function x(e){return e instanceof Uint8Array?e:typeof e=="string"?h(e):g(e)}function g(e){return e instanceof Uint8Array?e:new Uint8Array(e)}function h(e,t={}){const{size:r}=t;let n=e;r&&(z.assertSize(e,r),n=y.padRight(e,r));let i=n.slice(2);i.length%2&&(i=`0${i}`);const d=i.length/2,f=new Uint8Array(d);for(let c=0,o=0;c<d;c++){const u=s.charCodeToBase16(i.charCodeAt(o++)),b=s.charCodeToBase16(i.charCodeAt(o++));if(u===void 0||b===void 0)throw new a.BaseError(`Invalid byte sequence ("${i[o-2]}${i[o-1]}" in "${i}").`);f[c]=u*16+b}return f}function m(e,t={}){const{size:r}=t,n=S.encode(e);return typeof r=="number"?(s.assertSize(n,r),l(n,r)):n}function l(e,t){return s.pad(e,{dir:"right",size:t})}function E(e){return e.length}class p extends a.BaseError{constructor({givenSize:t,maxSize:r}){super(`Size cannot exceed \`${r}\` bytes. Given size: \`${t}\` bytes.`),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"Bytes.SizeOverflowError"})}}class $ extends a.BaseError{constructor({size:t,targetSize:r,type:n}){super(`${n.charAt(0).toUpperCase()}${n.slice(1).toLowerCase()} size (\`${t}\`) exceeds padding size (\`${r}\`).`),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"Bytes.SizeExceedsPaddingSizeError"})}}exports.SizeExceedsPaddingSizeError=$;exports.SizeOverflowError=p;exports.from=x;exports.fromArray=g;exports.fromHex=h;exports.fromString=m;exports.padRight=l;exports.size=E;
package/dist/index311.js CHANGED
@@ -1,7 +1,7 @@
1
- import { BaseError as c } from "./index301.js";
2
- import { padRight as h } from "./index288.js";
1
+ import { BaseError as c } from "./index303.js";
2
+ import { padRight as h } from "./index290.js";
3
3
  import { charCodeToBase16 as b, assertSize as g, pad as m } from "./index312.js";
4
- import { assertSize as p } from "./index303.js";
4
+ import { assertSize as p } from "./index305.js";
5
5
  const l = /* @__PURE__ */ new TextEncoder();
6
6
  function E(e) {
7
7
  return e instanceof Uint8Array ? e : typeof e == "string" ? y(e) : z(e);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@gardenfi/utils",
3
- "version": "2.2.0-beta.1",
3
+ "version": "2.2.1-beta.1",
4
4
  "type": "module",
5
5
  "scripts": {
6
6
  "build": "vite build",