@hashgraphonline/standards-sdk 0.0.75 → 0.0.76

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 (117) hide show
  1. package/dist/es/standards-sdk.es100.js +31 -3
  2. package/dist/es/standards-sdk.es100.js.map +1 -1
  3. package/dist/es/standards-sdk.es101.js +14 -3
  4. package/dist/es/standards-sdk.es101.js.map +1 -1
  5. package/dist/es/standards-sdk.es102.js +4 -13
  6. package/dist/es/standards-sdk.es102.js.map +1 -1
  7. package/dist/es/standards-sdk.es103.js +4 -13
  8. package/dist/es/standards-sdk.es103.js.map +1 -1
  9. package/dist/es/standards-sdk.es110.js +1 -1
  10. package/dist/es/standards-sdk.es12.js +3 -3
  11. package/dist/es/standards-sdk.es14.js +1 -1
  12. package/dist/es/standards-sdk.es17.js +2 -2
  13. package/dist/es/standards-sdk.es18.js +3 -3
  14. package/dist/es/standards-sdk.es21.js +1692 -966
  15. package/dist/es/standards-sdk.es21.js.map +1 -1
  16. package/dist/es/standards-sdk.es22.js +3 -5
  17. package/dist/es/standards-sdk.es22.js.map +1 -1
  18. package/dist/es/standards-sdk.es23.js +4103 -1703
  19. package/dist/es/standards-sdk.es23.js.map +1 -1
  20. package/dist/es/standards-sdk.es24.js +941 -7090
  21. package/dist/es/standards-sdk.es24.js.map +1 -1
  22. package/dist/es/standards-sdk.es25.js +5 -36
  23. package/dist/es/standards-sdk.es25.js.map +1 -1
  24. package/dist/es/standards-sdk.es26.js +36 -48
  25. package/dist/es/standards-sdk.es26.js.map +1 -1
  26. package/dist/es/standards-sdk.es27.js +48 -3
  27. package/dist/es/standards-sdk.es27.js.map +1 -1
  28. package/dist/es/standards-sdk.es28.js +7190 -2
  29. package/dist/es/standards-sdk.es28.js.map +1 -1
  30. package/dist/es/standards-sdk.es29.js +2 -4167
  31. package/dist/es/standards-sdk.es29.js.map +1 -1
  32. package/dist/es/standards-sdk.es35.js +96 -79
  33. package/dist/es/standards-sdk.es35.js.map +1 -1
  34. package/dist/es/standards-sdk.es36.js +2 -23
  35. package/dist/es/standards-sdk.es36.js.map +1 -1
  36. package/dist/es/standards-sdk.es37.js +15 -147
  37. package/dist/es/standards-sdk.es37.js.map +1 -1
  38. package/dist/es/standards-sdk.es38.js +403 -85
  39. package/dist/es/standards-sdk.es38.js.map +1 -1
  40. package/dist/es/standards-sdk.es39.js +79 -7131
  41. package/dist/es/standards-sdk.es39.js.map +1 -1
  42. package/dist/es/standards-sdk.es4.js +1 -1
  43. package/dist/es/standards-sdk.es40.js +18 -190
  44. package/dist/es/standards-sdk.es40.js.map +1 -1
  45. package/dist/es/standards-sdk.es41.js +127 -417
  46. package/dist/es/standards-sdk.es41.js.map +1 -1
  47. package/dist/es/standards-sdk.es42.js +87 -21
  48. package/dist/es/standards-sdk.es42.js.map +1 -1
  49. package/dist/es/standards-sdk.es43.js +161 -126
  50. package/dist/es/standards-sdk.es43.js.map +1 -1
  51. package/dist/es/standards-sdk.es44.js +5 -17
  52. package/dist/es/standards-sdk.es44.js.map +1 -1
  53. package/dist/es/standards-sdk.es45.js +136 -22
  54. package/dist/es/standards-sdk.es45.js.map +1 -1
  55. package/dist/es/standards-sdk.es46.js +191 -25
  56. package/dist/es/standards-sdk.es46.js.map +1 -1
  57. package/dist/es/standards-sdk.es47.js +432 -15
  58. package/dist/es/standards-sdk.es47.js.map +1 -1
  59. package/dist/es/standards-sdk.es48.js +15 -34
  60. package/dist/es/standards-sdk.es48.js.map +1 -1
  61. package/dist/es/standards-sdk.es49.js +131 -10
  62. package/dist/es/standards-sdk.es49.js.map +1 -1
  63. package/dist/es/standards-sdk.es5.js +3 -3
  64. package/dist/es/standards-sdk.es50.js +10 -53
  65. package/dist/es/standards-sdk.es50.js.map +1 -1
  66. package/dist/es/standards-sdk.es51.js +21 -1281
  67. package/dist/es/standards-sdk.es51.js.map +1 -1
  68. package/dist/es/standards-sdk.es52.js +25 -28
  69. package/dist/es/standards-sdk.es52.js.map +1 -1
  70. package/dist/es/standards-sdk.es53.js +20 -5
  71. package/dist/es/standards-sdk.es53.js.map +1 -1
  72. package/dist/es/standards-sdk.es54.js +36 -151
  73. package/dist/es/standards-sdk.es54.js.map +1 -1
  74. package/dist/es/standards-sdk.es55.js +13 -788
  75. package/dist/es/standards-sdk.es55.js.map +1 -1
  76. package/dist/es/standards-sdk.es56.js +55 -168
  77. package/dist/es/standards-sdk.es56.js.map +1 -1
  78. package/dist/es/standards-sdk.es57.js +1262 -116
  79. package/dist/es/standards-sdk.es57.js.map +1 -1
  80. package/dist/es/standards-sdk.es58.js +32 -3
  81. package/dist/es/standards-sdk.es58.js.map +1 -1
  82. package/dist/es/standards-sdk.es59.js +154 -16
  83. package/dist/es/standards-sdk.es59.js.map +1 -1
  84. package/dist/es/standards-sdk.es60.js +790 -24
  85. package/dist/es/standards-sdk.es60.js.map +1 -1
  86. package/dist/es/standards-sdk.es61.js +2282 -26
  87. package/dist/es/standards-sdk.es61.js.map +1 -1
  88. package/dist/es/standards-sdk.es62.js +163 -37
  89. package/dist/es/standards-sdk.es62.js.map +1 -1
  90. package/dist/es/standards-sdk.es63.js +26 -100
  91. package/dist/es/standards-sdk.es63.js.map +1 -1
  92. package/dist/es/standards-sdk.es64.js +26 -2
  93. package/dist/es/standards-sdk.es64.js.map +1 -1
  94. package/dist/es/standards-sdk.es65.js +37 -15
  95. package/dist/es/standards-sdk.es65.js.map +1 -1
  96. package/dist/es/standards-sdk.es66.js +17 -405
  97. package/dist/es/standards-sdk.es66.js.map +1 -1
  98. package/dist/es/standards-sdk.es67.js +2 -2
  99. package/dist/es/standards-sdk.es7.js +3 -3
  100. package/dist/es/standards-sdk.es77.js +1 -1
  101. package/dist/es/standards-sdk.es8.js +3 -3
  102. package/dist/es/standards-sdk.es84.js +3 -2282
  103. package/dist/es/standards-sdk.es84.js.map +1 -1
  104. package/dist/es/standards-sdk.es85.js +7102 -130
  105. package/dist/es/standards-sdk.es85.js.map +1 -1
  106. package/dist/es/standards-sdk.es86.js +1 -1
  107. package/dist/es/standards-sdk.es88.js +1 -1
  108. package/dist/es/standards-sdk.es89.js +2 -2
  109. package/dist/es/standards-sdk.es9.js +1 -1
  110. package/dist/es/standards-sdk.es93.js +2 -2
  111. package/dist/es/standards-sdk.es98.js +12 -31
  112. package/dist/es/standards-sdk.es98.js.map +1 -1
  113. package/dist/es/standards-sdk.es99.js +13 -15
  114. package/dist/es/standards-sdk.es99.js.map +1 -1
  115. package/dist/umd/standards-sdk.umd.js +5 -5
  116. package/dist/umd/standards-sdk.umd.js.map +1 -1
  117. package/package.json +2 -2
@@ -1,28 +1,94 @@
1
- import { toBeHex } from "./standards-sdk.es54.js";
2
- import { Typed } from "./standards-sdk.es55.js";
3
- import { Coder } from "./standards-sdk.es41.js";
4
- import { getAddress } from "./standards-sdk.es35.js";
5
- class AddressCoder extends Coder {
6
- constructor(localName) {
7
- super("address", "address", localName, false);
8
- }
9
- defaultValue() {
10
- return "0x0000000000000000000000000000000000000000";
11
- }
12
- encode(writer, _value) {
13
- let value = Typed.dereference(_value, "string");
14
- try {
15
- value = getAddress(value);
16
- } catch (error) {
17
- return this._throwError(error.message, _value);
1
+ import { assert, assertArgument } from "./standards-sdk.es41.js";
2
+ function _getBytes(value, name, copy) {
3
+ if (value instanceof Uint8Array) {
4
+ if (copy) {
5
+ return new Uint8Array(value);
18
6
  }
19
- return writer.writeValue(value);
7
+ return value;
20
8
  }
21
- decode(reader) {
22
- return getAddress(toBeHex(reader.readValue(), 20));
9
+ if (typeof value === "string" && value.match(/^0x(?:[0-9a-f][0-9a-f])*$/i)) {
10
+ const result = new Uint8Array((value.length - 2) / 2);
11
+ let offset = 2;
12
+ for (let i = 0; i < result.length; i++) {
13
+ result[i] = parseInt(value.substring(offset, offset + 2), 16);
14
+ offset += 2;
15
+ }
16
+ return result;
17
+ }
18
+ assertArgument(false, "invalid BytesLike value", name || "value", value);
19
+ }
20
+ function getBytes(value, name) {
21
+ return _getBytes(value, name, false);
22
+ }
23
+ function getBytesCopy(value, name) {
24
+ return _getBytes(value, name, true);
25
+ }
26
+ function isHexString(value, length) {
27
+ if (typeof value !== "string" || !value.match(/^0x[0-9A-Fa-f]*$/)) {
28
+ return false;
29
+ }
30
+ if (typeof length === "number" && value.length !== 2 + 2 * length) {
31
+ return false;
32
+ }
33
+ if (length === true && value.length % 2 !== 0) {
34
+ return false;
35
+ }
36
+ return true;
37
+ }
38
+ const HexCharacters = "0123456789abcdef";
39
+ function hexlify(data) {
40
+ const bytes = getBytes(data);
41
+ let result = "0x";
42
+ for (let i = 0; i < bytes.length; i++) {
43
+ const v = bytes[i];
44
+ result += HexCharacters[(v & 240) >> 4] + HexCharacters[v & 15];
45
+ }
46
+ return result;
47
+ }
48
+ function concat(datas) {
49
+ return "0x" + datas.map((d) => hexlify(d).substring(2)).join("");
50
+ }
51
+ function dataSlice(data, start, end) {
52
+ const bytes = getBytes(data);
53
+ if (end != null && end > bytes.length) {
54
+ assert(false, "cannot slice beyond data bounds", "BUFFER_OVERRUN", {
55
+ buffer: bytes,
56
+ length: bytes.length,
57
+ offset: end
58
+ });
23
59
  }
60
+ return hexlify(bytes.slice(start == null ? 0 : start, end == null ? bytes.length : end));
61
+ }
62
+ function zeroPad(data, length, left) {
63
+ const bytes = getBytes(data);
64
+ assert(length >= bytes.length, "padding exceeds data length", "BUFFER_OVERRUN", {
65
+ buffer: new Uint8Array(bytes),
66
+ length,
67
+ offset: length + 1
68
+ });
69
+ const result = new Uint8Array(length);
70
+ result.fill(0);
71
+ if (left) {
72
+ result.set(bytes, length - bytes.length);
73
+ } else {
74
+ result.set(bytes, 0);
75
+ }
76
+ return hexlify(result);
77
+ }
78
+ function zeroPadValue(data, length) {
79
+ return zeroPad(data, length, true);
80
+ }
81
+ function zeroPadBytes(data, length) {
82
+ return zeroPad(data, length, false);
24
83
  }
25
84
  export {
26
- AddressCoder
85
+ concat,
86
+ dataSlice,
87
+ getBytes,
88
+ getBytesCopy,
89
+ hexlify,
90
+ isHexString,
91
+ zeroPadBytes,
92
+ zeroPadValue
27
93
  };
28
94
  //# sourceMappingURL=standards-sdk.es42.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"standards-sdk.es42.js","sources":["../../node_modules/ethers/lib.esm/abi/coders/address.js"],"sourcesContent":["import { getAddress } from \"../../address/index.js\";\nimport { toBeHex } from \"../../utils/maths.js\";\nimport { Typed } from \"../typed.js\";\nimport { Coder } from \"./abstract-coder.js\";\n/**\n * @_ignore\n */\nexport class AddressCoder extends Coder {\n constructor(localName) {\n super(\"address\", \"address\", localName, false);\n }\n defaultValue() {\n return \"0x0000000000000000000000000000000000000000\";\n }\n encode(writer, _value) {\n let value = Typed.dereference(_value, \"string\");\n try {\n value = getAddress(value);\n }\n catch (error) {\n return this._throwError(error.message, _value);\n }\n return writer.writeValue(value);\n }\n decode(reader) {\n return getAddress(toBeHex(reader.readValue(), 20));\n }\n}\n//# sourceMappingURL=address.js.map"],"names":[],"mappings":";;;;AAOO,MAAM,qBAAqB,MAAM;AAAA,EACpC,YAAY,WAAW;AACnB,UAAM,WAAW,WAAW,WAAW,KAAK;AAAA,EACpD;AAAA,EACI,eAAe;AACX,WAAO;AAAA,EACf;AAAA,EACI,OAAO,QAAQ,QAAQ;AACnB,QAAI,QAAQ,MAAM,YAAY,QAAQ,QAAQ;AAC9C,QAAI;AACA,cAAQ,WAAW,KAAK;AAAA,IACpC,SACe,OAAO;AACV,aAAO,KAAK,YAAY,MAAM,SAAS,MAAM;AAAA,IACzD;AACQ,WAAO,OAAO,WAAW,KAAK;AAAA,EACtC;AAAA,EACI,OAAO,QAAQ;AACX,WAAO,WAAW,QAAQ,OAAO,UAAW,GAAE,EAAE,CAAC;AAAA,EACzD;AACA;","x_google_ignoreList":[0]}
1
+ {"version":3,"file":"standards-sdk.es42.js","sources":["../../node_modules/ethers/lib.esm/utils/data.js"],"sourcesContent":["/**\n * Some data helpers.\n *\n *\n * @_subsection api/utils:Data Helpers [about-data]\n */\nimport { assert, assertArgument } from \"./errors.js\";\nfunction _getBytes(value, name, copy) {\n if (value instanceof Uint8Array) {\n if (copy) {\n return new Uint8Array(value);\n }\n return value;\n }\n if (typeof (value) === \"string\" && value.match(/^0x(?:[0-9a-f][0-9a-f])*$/i)) {\n const result = new Uint8Array((value.length - 2) / 2);\n let offset = 2;\n for (let i = 0; i < result.length; i++) {\n result[i] = parseInt(value.substring(offset, offset + 2), 16);\n offset += 2;\n }\n return result;\n }\n assertArgument(false, \"invalid BytesLike value\", name || \"value\", value);\n}\n/**\n * Get a typed Uint8Array for %%value%%. If already a Uint8Array\n * the original %%value%% is returned; if a copy is required use\n * [[getBytesCopy]].\n *\n * @see: getBytesCopy\n */\nexport function getBytes(value, name) {\n return _getBytes(value, name, false);\n}\n/**\n * Get a typed Uint8Array for %%value%%, creating a copy if necessary\n * to prevent any modifications of the returned value from being\n * reflected elsewhere.\n *\n * @see: getBytes\n */\nexport function getBytesCopy(value, name) {\n return _getBytes(value, name, true);\n}\n/**\n * Returns true if %%value%% is a valid [[HexString]].\n *\n * If %%length%% is ``true`` or a //number//, it also checks that\n * %%value%% is a valid [[DataHexString]] of %%length%% (if a //number//)\n * bytes of data (e.g. ``0x1234`` is 2 bytes).\n */\nexport function isHexString(value, length) {\n if (typeof (value) !== \"string\" || !value.match(/^0x[0-9A-Fa-f]*$/)) {\n return false;\n }\n if (typeof (length) === \"number\" && value.length !== 2 + 2 * length) {\n return false;\n }\n if (length === true && (value.length % 2) !== 0) {\n return false;\n }\n return true;\n}\n/**\n * Returns true if %%value%% is a valid representation of arbitrary\n * data (i.e. a valid [[DataHexString]] or a Uint8Array).\n */\nexport function isBytesLike(value) {\n return (isHexString(value, true) || (value instanceof Uint8Array));\n}\nconst HexCharacters = \"0123456789abcdef\";\n/**\n * Returns a [[DataHexString]] representation of %%data%%.\n */\nexport function hexlify(data) {\n const bytes = getBytes(data);\n let result = \"0x\";\n for (let i = 0; i < bytes.length; i++) {\n const v = bytes[i];\n result += HexCharacters[(v & 0xf0) >> 4] + HexCharacters[v & 0x0f];\n }\n return result;\n}\n/**\n * Returns a [[DataHexString]] by concatenating all values\n * within %%data%%.\n */\nexport function concat(datas) {\n return \"0x\" + datas.map((d) => hexlify(d).substring(2)).join(\"\");\n}\n/**\n * Returns the length of %%data%%, in bytes.\n */\nexport function dataLength(data) {\n if (isHexString(data, true)) {\n return (data.length - 2) / 2;\n }\n return getBytes(data).length;\n}\n/**\n * Returns a [[DataHexString]] by slicing %%data%% from the %%start%%\n * offset to the %%end%% offset.\n *\n * By default %%start%% is 0 and %%end%% is the length of %%data%%.\n */\nexport function dataSlice(data, start, end) {\n const bytes = getBytes(data);\n if (end != null && end > bytes.length) {\n assert(false, \"cannot slice beyond data bounds\", \"BUFFER_OVERRUN\", {\n buffer: bytes, length: bytes.length, offset: end\n });\n }\n return hexlify(bytes.slice((start == null) ? 0 : start, (end == null) ? bytes.length : end));\n}\n/**\n * Return the [[DataHexString]] result by stripping all **leading**\n ** zero bytes from %%data%%.\n */\nexport function stripZerosLeft(data) {\n let bytes = hexlify(data).substring(2);\n while (bytes.startsWith(\"00\")) {\n bytes = bytes.substring(2);\n }\n return \"0x\" + bytes;\n}\nfunction zeroPad(data, length, left) {\n const bytes = getBytes(data);\n assert(length >= bytes.length, \"padding exceeds data length\", \"BUFFER_OVERRUN\", {\n buffer: new Uint8Array(bytes),\n length: length,\n offset: length + 1\n });\n const result = new Uint8Array(length);\n result.fill(0);\n if (left) {\n result.set(bytes, length - bytes.length);\n }\n else {\n result.set(bytes, 0);\n }\n return hexlify(result);\n}\n/**\n * Return the [[DataHexString]] of %%data%% padded on the **left**\n * to %%length%% bytes.\n *\n * If %%data%% already exceeds %%length%%, a [[BufferOverrunError]] is\n * thrown.\n *\n * This pads data the same as **values** are in Solidity\n * (e.g. ``uint128``).\n */\nexport function zeroPadValue(data, length) {\n return zeroPad(data, length, true);\n}\n/**\n * Return the [[DataHexString]] of %%data%% padded on the **right**\n * to %%length%% bytes.\n *\n * If %%data%% already exceeds %%length%%, a [[BufferOverrunError]] is\n * thrown.\n *\n * This pads data the same as **bytes** are in Solidity\n * (e.g. ``bytes16``).\n */\nexport function zeroPadBytes(data, length) {\n return zeroPad(data, length, false);\n}\n//# sourceMappingURL=data.js.map"],"names":[],"mappings":";AAOA,SAAS,UAAU,OAAO,MAAM,MAAM;AAClC,MAAI,iBAAiB,YAAY;AAC7B,QAAI,MAAM;AACN,aAAO,IAAI,WAAW,KAAK;AAAA,IACvC;AACQ,WAAO;AAAA,EACf;AACI,MAAI,OAAQ,UAAW,YAAY,MAAM,MAAM,4BAA4B,GAAG;AAC1E,UAAM,SAAS,IAAI,YAAY,MAAM,SAAS,KAAK,CAAC;AACpD,QAAI,SAAS;AACb,aAAS,IAAI,GAAG,IAAI,OAAO,QAAQ,KAAK;AACpC,aAAO,CAAC,IAAI,SAAS,MAAM,UAAU,QAAQ,SAAS,CAAC,GAAG,EAAE;AAC5D,gBAAU;AAAA,IACtB;AACQ,WAAO;AAAA,EACf;AACI,iBAAe,OAAO,2BAA2B,QAAQ,SAAS,KAAK;AAC3E;AAQO,SAAS,SAAS,OAAO,MAAM;AAClC,SAAO,UAAU,OAAO,MAAM,KAAK;AACvC;AAQO,SAAS,aAAa,OAAO,MAAM;AACtC,SAAO,UAAU,OAAO,MAAM,IAAI;AACtC;AAQO,SAAS,YAAY,OAAO,QAAQ;AACvC,MAAI,OAAQ,UAAW,YAAY,CAAC,MAAM,MAAM,kBAAkB,GAAG;AACjE,WAAO;AAAA,EACf;AACI,MAAI,OAAQ,WAAY,YAAY,MAAM,WAAW,IAAI,IAAI,QAAQ;AACjE,WAAO;AAAA,EACf;AACI,MAAI,WAAW,QAAS,MAAM,SAAS,MAAO,GAAG;AAC7C,WAAO;AAAA,EACf;AACI,SAAO;AACX;AAQA,MAAM,gBAAgB;AAIf,SAAS,QAAQ,MAAM;AAC1B,QAAM,QAAQ,SAAS,IAAI;AAC3B,MAAI,SAAS;AACb,WAAS,IAAI,GAAG,IAAI,MAAM,QAAQ,KAAK;AACnC,UAAM,IAAI,MAAM,CAAC;AACjB,cAAU,eAAe,IAAI,QAAS,CAAC,IAAI,cAAc,IAAI,EAAI;AAAA,EACzE;AACI,SAAO;AACX;AAKO,SAAS,OAAO,OAAO;AAC1B,SAAO,OAAO,MAAM,IAAI,CAAC,MAAM,QAAQ,CAAC,EAAE,UAAU,CAAC,CAAC,EAAE,KAAK,EAAE;AACnE;AAgBO,SAAS,UAAU,MAAM,OAAO,KAAK;AACxC,QAAM,QAAQ,SAAS,IAAI;AAC3B,MAAI,OAAO,QAAQ,MAAM,MAAM,QAAQ;AACnC,WAAO,OAAO,mCAAmC,kBAAkB;AAAA,MAC/D,QAAQ;AAAA,MAAO,QAAQ,MAAM;AAAA,MAAQ,QAAQ;AAAA,IACzD,CAAS;AAAA,EACT;AACI,SAAO,QAAQ,MAAM,MAAO,SAAS,OAAQ,IAAI,OAAQ,OAAO,OAAQ,MAAM,SAAS,GAAG,CAAC;AAC/F;AAYA,SAAS,QAAQ,MAAM,QAAQ,MAAM;AACjC,QAAM,QAAQ,SAAS,IAAI;AAC3B,SAAO,UAAU,MAAM,QAAQ,+BAA+B,kBAAkB;AAAA,IAC5E,QAAQ,IAAI,WAAW,KAAK;AAAA,IAC5B;AAAA,IACA,QAAQ,SAAS;AAAA,EACzB,CAAK;AACD,QAAM,SAAS,IAAI,WAAW,MAAM;AACpC,SAAO,KAAK,CAAC;AACb,MAAI,MAAM;AACN,WAAO,IAAI,OAAO,SAAS,MAAM,MAAM;AAAA,EAC/C,OACS;AACD,WAAO,IAAI,OAAO,CAAC;AAAA,EAC3B;AACI,SAAO,QAAQ,MAAM;AACzB;AAWO,SAAS,aAAa,MAAM,QAAQ;AACvC,SAAO,QAAQ,MAAM,QAAQ,IAAI;AACrC;AAWO,SAAS,aAAa,MAAM,QAAQ;AACvC,SAAO,QAAQ,MAAM,QAAQ,KAAK;AACtC;","x_google_ignoreList":[0]}
@@ -1,142 +1,177 @@
1
- var __defProp = Object.defineProperty;
2
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
3
- var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
4
- import { Typed } from "./standards-sdk.es55.js";
5
- import { Coder, WordSize, Writer, Result } from "./standards-sdk.es41.js";
6
- import { AnonymousCoder } from "./standards-sdk.es59.js";
7
- import { defineProperties } from "./standards-sdk.es52.js";
8
- import { assertArgumentCount, assert, assertArgument, isError } from "./standards-sdk.es37.js";
9
- function pack(writer, coders, values) {
10
- let arrayValues = [];
11
- if (Array.isArray(values)) {
12
- arrayValues = values;
13
- } else if (values && typeof values === "object") {
14
- let unique = {};
15
- arrayValues = coders.map((coder) => {
16
- const name = coder.localName;
17
- assert(name, "cannot encode object for signature with missing names", "INVALID_ARGUMENT", { argument: "values", info: { coder }, value: values });
18
- assert(!unique[name], "cannot encode object for signature with duplicate names", "INVALID_ARGUMENT", { argument: "values", info: { coder }, value: values });
19
- unique[name] = true;
20
- return values[name];
21
- });
22
- } else {
23
- assertArgument(false, "invalid tuple value", "tuple", values);
1
+ import { number, exists, bytes, output } from "./standards-sdk.es63.js";
2
+ import { rotlSH, rotlSL, rotlBH, rotlBL, split } from "./standards-sdk.es64.js";
3
+ import { wrapConstructor, Hash, u32, toBytes } from "./standards-sdk.es65.js";
4
+ const [SHA3_PI, SHA3_ROTL, _SHA3_IOTA] = [[], [], []];
5
+ const _0n = /* @__PURE__ */ BigInt(0);
6
+ const _1n = /* @__PURE__ */ BigInt(1);
7
+ const _2n = /* @__PURE__ */ BigInt(2);
8
+ const _7n = /* @__PURE__ */ BigInt(7);
9
+ const _256n = /* @__PURE__ */ BigInt(256);
10
+ const _0x71n = /* @__PURE__ */ BigInt(113);
11
+ for (let round = 0, R = _1n, x = 1, y = 0; round < 24; round++) {
12
+ [x, y] = [y, (2 * x + 3 * y) % 5];
13
+ SHA3_PI.push(2 * (5 * y + x));
14
+ SHA3_ROTL.push((round + 1) * (round + 2) / 2 % 64);
15
+ let t = _0n;
16
+ for (let j = 0; j < 7; j++) {
17
+ R = (R << _1n ^ (R >> _7n) * _0x71n) % _256n;
18
+ if (R & _2n)
19
+ t ^= _1n << (_1n << /* @__PURE__ */ BigInt(j)) - _1n;
24
20
  }
25
- assertArgument(coders.length === arrayValues.length, "types/value length mismatch", "tuple", values);
26
- let staticWriter = new Writer();
27
- let dynamicWriter = new Writer();
28
- let updateFuncs = [];
29
- coders.forEach((coder, index) => {
30
- let value = arrayValues[index];
31
- if (coder.dynamic) {
32
- let dynamicOffset = dynamicWriter.length;
33
- coder.encode(dynamicWriter, value);
34
- let updateFunc = staticWriter.writeUpdatableValue();
35
- updateFuncs.push((baseOffset) => {
36
- updateFunc(baseOffset + dynamicOffset);
37
- });
38
- } else {
39
- coder.encode(staticWriter, value);
40
- }
41
- });
42
- updateFuncs.forEach((func) => {
43
- func(staticWriter.length);
44
- });
45
- let length = writer.appendWriter(staticWriter);
46
- length += writer.appendWriter(dynamicWriter);
47
- return length;
21
+ _SHA3_IOTA.push(t);
48
22
  }
49
- function unpack(reader, coders) {
50
- let values = [];
51
- let keys = [];
52
- let baseReader = reader.subReader(0);
53
- coders.forEach((coder) => {
54
- let value = null;
55
- if (coder.dynamic) {
56
- let offset = reader.readIndex();
57
- let offsetReader = baseReader.subReader(offset);
58
- try {
59
- value = coder.decode(offsetReader);
60
- } catch (error) {
61
- if (isError(error, "BUFFER_OVERRUN")) {
62
- throw error;
63
- }
64
- value = error;
65
- value.baseType = coder.name;
66
- value.name = coder.localName;
67
- value.type = coder.type;
68
- }
69
- } else {
70
- try {
71
- value = coder.decode(reader);
72
- } catch (error) {
73
- if (isError(error, "BUFFER_OVERRUN")) {
74
- throw error;
75
- }
76
- value = error;
77
- value.baseType = coder.name;
78
- value.name = coder.localName;
79
- value.type = coder.type;
23
+ const [SHA3_IOTA_H, SHA3_IOTA_L] = /* @__PURE__ */ split(_SHA3_IOTA, true);
24
+ const rotlH = (h, l, s) => s > 32 ? rotlBH(h, l, s) : rotlSH(h, l, s);
25
+ const rotlL = (h, l, s) => s > 32 ? rotlBL(h, l, s) : rotlSL(h, l, s);
26
+ function keccakP(s, rounds = 24) {
27
+ const B = new Uint32Array(5 * 2);
28
+ for (let round = 24 - rounds; round < 24; round++) {
29
+ for (let x = 0; x < 10; x++)
30
+ B[x] = s[x] ^ s[x + 10] ^ s[x + 20] ^ s[x + 30] ^ s[x + 40];
31
+ for (let x = 0; x < 10; x += 2) {
32
+ const idx1 = (x + 8) % 10;
33
+ const idx0 = (x + 2) % 10;
34
+ const B0 = B[idx0];
35
+ const B1 = B[idx0 + 1];
36
+ const Th = rotlH(B0, B1, 1) ^ B[idx1];
37
+ const Tl = rotlL(B0, B1, 1) ^ B[idx1 + 1];
38
+ for (let y = 0; y < 50; y += 10) {
39
+ s[x + y] ^= Th;
40
+ s[x + y + 1] ^= Tl;
80
41
  }
81
42
  }
82
- if (value == void 0) {
83
- throw new Error("investigate");
43
+ let curH = s[2];
44
+ let curL = s[3];
45
+ for (let t = 0; t < 24; t++) {
46
+ const shift = SHA3_ROTL[t];
47
+ const Th = rotlH(curH, curL, shift);
48
+ const Tl = rotlL(curH, curL, shift);
49
+ const PI = SHA3_PI[t];
50
+ curH = s[PI];
51
+ curL = s[PI + 1];
52
+ s[PI] = Th;
53
+ s[PI + 1] = Tl;
84
54
  }
85
- values.push(value);
86
- keys.push(coder.localName || null);
87
- });
88
- return Result.fromItems(values, keys);
55
+ for (let y = 0; y < 50; y += 10) {
56
+ for (let x = 0; x < 10; x++)
57
+ B[x] = s[y + x];
58
+ for (let x = 0; x < 10; x++)
59
+ s[y + x] ^= ~B[(x + 2) % 10] & B[(x + 4) % 10];
60
+ }
61
+ s[0] ^= SHA3_IOTA_H[round];
62
+ s[1] ^= SHA3_IOTA_L[round];
63
+ }
64
+ B.fill(0);
89
65
  }
90
- class ArrayCoder extends Coder {
91
- constructor(coder, length, localName) {
92
- const type = coder.type + "[" + (length >= 0 ? length : "") + "]";
93
- const dynamic = length === -1 || coder.dynamic;
94
- super("array", type, localName, dynamic);
95
- __publicField(this, "coder");
96
- __publicField(this, "length");
97
- defineProperties(this, { coder, length });
66
+ class Keccak extends Hash {
67
+ // NOTE: we accept arguments in bytes instead of bits here.
68
+ constructor(blockLen, suffix, outputLen, enableXOF = false, rounds = 24) {
69
+ super();
70
+ this.blockLen = blockLen;
71
+ this.suffix = suffix;
72
+ this.outputLen = outputLen;
73
+ this.enableXOF = enableXOF;
74
+ this.rounds = rounds;
75
+ this.pos = 0;
76
+ this.posOut = 0;
77
+ this.finished = false;
78
+ this.destroyed = false;
79
+ number(outputLen);
80
+ if (0 >= this.blockLen || this.blockLen >= 200)
81
+ throw new Error("Sha3 supports only keccak-f1600 function");
82
+ this.state = new Uint8Array(200);
83
+ this.state32 = u32(this.state);
98
84
  }
99
- defaultValue() {
100
- const defaultChild = this.coder.defaultValue();
101
- const result = [];
102
- for (let i = 0; i < this.length; i++) {
103
- result.push(defaultChild);
104
- }
105
- return result;
85
+ keccak() {
86
+ keccakP(this.state32, this.rounds);
87
+ this.posOut = 0;
88
+ this.pos = 0;
106
89
  }
107
- encode(writer, _value) {
108
- const value = Typed.dereference(_value, "array");
109
- if (!Array.isArray(value)) {
110
- this._throwError("expected array value", value);
111
- }
112
- let count = this.length;
113
- if (count === -1) {
114
- count = value.length;
115
- writer.writeValue(value.length);
90
+ update(data) {
91
+ exists(this);
92
+ const { blockLen, state } = this;
93
+ data = toBytes(data);
94
+ const len = data.length;
95
+ for (let pos = 0; pos < len; ) {
96
+ const take = Math.min(blockLen - this.pos, len - pos);
97
+ for (let i = 0; i < take; i++)
98
+ state[this.pos++] ^= data[pos++];
99
+ if (this.pos === blockLen)
100
+ this.keccak();
116
101
  }
117
- assertArgumentCount(value.length, count, "coder array" + (this.localName ? " " + this.localName : ""));
118
- let coders = [];
119
- for (let i = 0; i < value.length; i++) {
120
- coders.push(this.coder);
121
- }
122
- return pack(writer, coders, value);
102
+ return this;
123
103
  }
124
- decode(reader) {
125
- let count = this.length;
126
- if (count === -1) {
127
- count = reader.readIndex();
128
- assert(count * WordSize <= reader.dataLength, "insufficient data length", "BUFFER_OVERRUN", { buffer: reader.bytes, offset: count * WordSize, length: reader.dataLength });
129
- }
130
- let coders = [];
131
- for (let i = 0; i < count; i++) {
132
- coders.push(new AnonymousCoder(this.coder));
104
+ finish() {
105
+ if (this.finished)
106
+ return;
107
+ this.finished = true;
108
+ const { state, suffix, pos, blockLen } = this;
109
+ state[pos] ^= suffix;
110
+ if ((suffix & 128) !== 0 && pos === blockLen - 1)
111
+ this.keccak();
112
+ state[blockLen - 1] ^= 128;
113
+ this.keccak();
114
+ }
115
+ writeInto(out) {
116
+ exists(this, false);
117
+ bytes(out);
118
+ this.finish();
119
+ const bufferOut = this.state;
120
+ const { blockLen } = this;
121
+ for (let pos = 0, len = out.length; pos < len; ) {
122
+ if (this.posOut >= blockLen)
123
+ this.keccak();
124
+ const take = Math.min(blockLen - this.posOut, len - pos);
125
+ out.set(bufferOut.subarray(this.posOut, this.posOut + take), pos);
126
+ this.posOut += take;
127
+ pos += take;
133
128
  }
134
- return unpack(reader, coders);
129
+ return out;
130
+ }
131
+ xofInto(out) {
132
+ if (!this.enableXOF)
133
+ throw new Error("XOF is not possible for this instance");
134
+ return this.writeInto(out);
135
+ }
136
+ xof(bytes2) {
137
+ number(bytes2);
138
+ return this.xofInto(new Uint8Array(bytes2));
139
+ }
140
+ digestInto(out) {
141
+ output(out, this);
142
+ if (this.finished)
143
+ throw new Error("digest() was already called");
144
+ this.writeInto(out);
145
+ this.destroy();
146
+ return out;
147
+ }
148
+ digest() {
149
+ return this.digestInto(new Uint8Array(this.outputLen));
150
+ }
151
+ destroy() {
152
+ this.destroyed = true;
153
+ this.state.fill(0);
154
+ }
155
+ _cloneInto(to) {
156
+ const { blockLen, suffix, outputLen, rounds, enableXOF } = this;
157
+ to || (to = new Keccak(blockLen, suffix, outputLen, enableXOF, rounds));
158
+ to.state32.set(this.state32);
159
+ to.pos = this.pos;
160
+ to.posOut = this.posOut;
161
+ to.finished = this.finished;
162
+ to.rounds = rounds;
163
+ to.suffix = suffix;
164
+ to.outputLen = outputLen;
165
+ to.enableXOF = enableXOF;
166
+ to.destroyed = this.destroyed;
167
+ return to;
135
168
  }
136
169
  }
170
+ const gen = (suffix, blockLen, outputLen) => wrapConstructor(() => new Keccak(blockLen, suffix, outputLen));
171
+ const keccak_256 = /* @__PURE__ */ gen(1, 136, 256 / 8);
137
172
  export {
138
- ArrayCoder,
139
- pack,
140
- unpack
173
+ Keccak,
174
+ keccakP,
175
+ keccak_256
141
176
  };
142
177
  //# sourceMappingURL=standards-sdk.es43.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"standards-sdk.es43.js","sources":["../../node_modules/ethers/lib.esm/abi/coders/array.js"],"sourcesContent":["import { defineProperties, isError, assert, assertArgument, assertArgumentCount } from \"../../utils/index.js\";\nimport { Typed } from \"../typed.js\";\nimport { Coder, Result, WordSize, Writer } from \"./abstract-coder.js\";\nimport { AnonymousCoder } from \"./anonymous.js\";\n/**\n * @_ignore\n */\nexport function pack(writer, coders, values) {\n let arrayValues = [];\n if (Array.isArray(values)) {\n arrayValues = values;\n }\n else if (values && typeof (values) === \"object\") {\n let unique = {};\n arrayValues = coders.map((coder) => {\n const name = coder.localName;\n assert(name, \"cannot encode object for signature with missing names\", \"INVALID_ARGUMENT\", { argument: \"values\", info: { coder }, value: values });\n assert(!unique[name], \"cannot encode object for signature with duplicate names\", \"INVALID_ARGUMENT\", { argument: \"values\", info: { coder }, value: values });\n unique[name] = true;\n return values[name];\n });\n }\n else {\n assertArgument(false, \"invalid tuple value\", \"tuple\", values);\n }\n assertArgument(coders.length === arrayValues.length, \"types/value length mismatch\", \"tuple\", values);\n let staticWriter = new Writer();\n let dynamicWriter = new Writer();\n let updateFuncs = [];\n coders.forEach((coder, index) => {\n let value = arrayValues[index];\n if (coder.dynamic) {\n // Get current dynamic offset (for the future pointer)\n let dynamicOffset = dynamicWriter.length;\n // Encode the dynamic value into the dynamicWriter\n coder.encode(dynamicWriter, value);\n // Prepare to populate the correct offset once we are done\n let updateFunc = staticWriter.writeUpdatableValue();\n updateFuncs.push((baseOffset) => {\n updateFunc(baseOffset + dynamicOffset);\n });\n }\n else {\n coder.encode(staticWriter, value);\n }\n });\n // Backfill all the dynamic offsets, now that we know the static length\n updateFuncs.forEach((func) => { func(staticWriter.length); });\n let length = writer.appendWriter(staticWriter);\n length += writer.appendWriter(dynamicWriter);\n return length;\n}\n/**\n * @_ignore\n */\nexport function unpack(reader, coders) {\n let values = [];\n let keys = [];\n // A reader anchored to this base\n let baseReader = reader.subReader(0);\n coders.forEach((coder) => {\n let value = null;\n if (coder.dynamic) {\n let offset = reader.readIndex();\n let offsetReader = baseReader.subReader(offset);\n try {\n value = coder.decode(offsetReader);\n }\n catch (error) {\n // Cannot recover from this\n if (isError(error, \"BUFFER_OVERRUN\")) {\n throw error;\n }\n value = error;\n value.baseType = coder.name;\n value.name = coder.localName;\n value.type = coder.type;\n }\n }\n else {\n try {\n value = coder.decode(reader);\n }\n catch (error) {\n // Cannot recover from this\n if (isError(error, \"BUFFER_OVERRUN\")) {\n throw error;\n }\n value = error;\n value.baseType = coder.name;\n value.name = coder.localName;\n value.type = coder.type;\n }\n }\n if (value == undefined) {\n throw new Error(\"investigate\");\n }\n values.push(value);\n keys.push(coder.localName || null);\n });\n return Result.fromItems(values, keys);\n}\n/**\n * @_ignore\n */\nexport class ArrayCoder extends Coder {\n coder;\n length;\n constructor(coder, length, localName) {\n const type = (coder.type + \"[\" + (length >= 0 ? length : \"\") + \"]\");\n const dynamic = (length === -1 || coder.dynamic);\n super(\"array\", type, localName, dynamic);\n defineProperties(this, { coder, length });\n }\n defaultValue() {\n // Verifies the child coder is valid (even if the array is dynamic or 0-length)\n const defaultChild = this.coder.defaultValue();\n const result = [];\n for (let i = 0; i < this.length; i++) {\n result.push(defaultChild);\n }\n return result;\n }\n encode(writer, _value) {\n const value = Typed.dereference(_value, \"array\");\n if (!Array.isArray(value)) {\n this._throwError(\"expected array value\", value);\n }\n let count = this.length;\n if (count === -1) {\n count = value.length;\n writer.writeValue(value.length);\n }\n assertArgumentCount(value.length, count, \"coder array\" + (this.localName ? (\" \" + this.localName) : \"\"));\n let coders = [];\n for (let i = 0; i < value.length; i++) {\n coders.push(this.coder);\n }\n return pack(writer, coders, value);\n }\n decode(reader) {\n let count = this.length;\n if (count === -1) {\n count = reader.readIndex();\n // Check that there is *roughly* enough data to ensure\n // stray random data is not being read as a length. Each\n // slot requires at least 32 bytes for their value (or 32\n // bytes as a link to the data). This could use a much\n // tighter bound, but we are erroring on the side of safety.\n assert(count * WordSize <= reader.dataLength, \"insufficient data length\", \"BUFFER_OVERRUN\", { buffer: reader.bytes, offset: count * WordSize, length: reader.dataLength });\n }\n let coders = [];\n for (let i = 0; i < count; i++) {\n coders.push(new AnonymousCoder(this.coder));\n }\n return unpack(reader, coders);\n }\n}\n//# sourceMappingURL=array.js.map"],"names":[],"mappings":"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","x_google_ignoreList":[0]}
1
+ {"version":3,"file":"standards-sdk.es43.js","sources":["../../node_modules/@noble/hashes/esm/sha3.js"],"sourcesContent":["import { bytes, exists, number, output } from './_assert.js';\nimport { rotlBH, rotlBL, rotlSH, rotlSL, split } from './_u64.js';\nimport { Hash, u32, toBytes, wrapConstructor, wrapXOFConstructorWithOpts, } from './utils.js';\n// SHA3 (keccak) is based on a new design: basically, the internal state is bigger than output size.\n// It's called a sponge function.\n// Various per round constants calculations\nconst [SHA3_PI, SHA3_ROTL, _SHA3_IOTA] = [[], [], []];\nconst _0n = /* @__PURE__ */ BigInt(0);\nconst _1n = /* @__PURE__ */ BigInt(1);\nconst _2n = /* @__PURE__ */ BigInt(2);\nconst _7n = /* @__PURE__ */ BigInt(7);\nconst _256n = /* @__PURE__ */ BigInt(256);\nconst _0x71n = /* @__PURE__ */ BigInt(0x71);\nfor (let round = 0, R = _1n, x = 1, y = 0; round < 24; round++) {\n // Pi\n [x, y] = [y, (2 * x + 3 * y) % 5];\n SHA3_PI.push(2 * (5 * y + x));\n // Rotational\n SHA3_ROTL.push((((round + 1) * (round + 2)) / 2) % 64);\n // Iota\n let t = _0n;\n for (let j = 0; j < 7; j++) {\n R = ((R << _1n) ^ ((R >> _7n) * _0x71n)) % _256n;\n if (R & _2n)\n t ^= _1n << ((_1n << /* @__PURE__ */ BigInt(j)) - _1n);\n }\n _SHA3_IOTA.push(t);\n}\nconst [SHA3_IOTA_H, SHA3_IOTA_L] = /* @__PURE__ */ split(_SHA3_IOTA, true);\n// Left rotation (without 0, 32, 64)\nconst rotlH = (h, l, s) => (s > 32 ? rotlBH(h, l, s) : rotlSH(h, l, s));\nconst rotlL = (h, l, s) => (s > 32 ? rotlBL(h, l, s) : rotlSL(h, l, s));\n// Same as keccakf1600, but allows to skip some rounds\nexport function keccakP(s, rounds = 24) {\n const B = new Uint32Array(5 * 2);\n // NOTE: all indices are x2 since we store state as u32 instead of u64 (bigints to slow in js)\n for (let round = 24 - rounds; round < 24; round++) {\n // Theta θ\n for (let x = 0; x < 10; x++)\n B[x] = s[x] ^ s[x + 10] ^ s[x + 20] ^ s[x + 30] ^ s[x + 40];\n for (let x = 0; x < 10; x += 2) {\n const idx1 = (x + 8) % 10;\n const idx0 = (x + 2) % 10;\n const B0 = B[idx0];\n const B1 = B[idx0 + 1];\n const Th = rotlH(B0, B1, 1) ^ B[idx1];\n const Tl = rotlL(B0, B1, 1) ^ B[idx1 + 1];\n for (let y = 0; y < 50; y += 10) {\n s[x + y] ^= Th;\n s[x + y + 1] ^= Tl;\n }\n }\n // Rho (ρ) and Pi (π)\n let curH = s[2];\n let curL = s[3];\n for (let t = 0; t < 24; t++) {\n const shift = SHA3_ROTL[t];\n const Th = rotlH(curH, curL, shift);\n const Tl = rotlL(curH, curL, shift);\n const PI = SHA3_PI[t];\n curH = s[PI];\n curL = s[PI + 1];\n s[PI] = Th;\n s[PI + 1] = Tl;\n }\n // Chi (χ)\n for (let y = 0; y < 50; y += 10) {\n for (let x = 0; x < 10; x++)\n B[x] = s[y + x];\n for (let x = 0; x < 10; x++)\n s[y + x] ^= ~B[(x + 2) % 10] & B[(x + 4) % 10];\n }\n // Iota (ι)\n s[0] ^= SHA3_IOTA_H[round];\n s[1] ^= SHA3_IOTA_L[round];\n }\n B.fill(0);\n}\nexport class Keccak extends Hash {\n // NOTE: we accept arguments in bytes instead of bits here.\n constructor(blockLen, suffix, outputLen, enableXOF = false, rounds = 24) {\n super();\n this.blockLen = blockLen;\n this.suffix = suffix;\n this.outputLen = outputLen;\n this.enableXOF = enableXOF;\n this.rounds = rounds;\n this.pos = 0;\n this.posOut = 0;\n this.finished = false;\n this.destroyed = false;\n // Can be passed from user as dkLen\n number(outputLen);\n // 1600 = 5x5 matrix of 64bit. 1600 bits === 200 bytes\n if (0 >= this.blockLen || this.blockLen >= 200)\n throw new Error('Sha3 supports only keccak-f1600 function');\n this.state = new Uint8Array(200);\n this.state32 = u32(this.state);\n }\n keccak() {\n keccakP(this.state32, this.rounds);\n this.posOut = 0;\n this.pos = 0;\n }\n update(data) {\n exists(this);\n const { blockLen, state } = this;\n data = toBytes(data);\n const len = data.length;\n for (let pos = 0; pos < len;) {\n const take = Math.min(blockLen - this.pos, len - pos);\n for (let i = 0; i < take; i++)\n state[this.pos++] ^= data[pos++];\n if (this.pos === blockLen)\n this.keccak();\n }\n return this;\n }\n finish() {\n if (this.finished)\n return;\n this.finished = true;\n const { state, suffix, pos, blockLen } = this;\n // Do the padding\n state[pos] ^= suffix;\n if ((suffix & 0x80) !== 0 && pos === blockLen - 1)\n this.keccak();\n state[blockLen - 1] ^= 0x80;\n this.keccak();\n }\n writeInto(out) {\n exists(this, false);\n bytes(out);\n this.finish();\n const bufferOut = this.state;\n const { blockLen } = this;\n for (let pos = 0, len = out.length; pos < len;) {\n if (this.posOut >= blockLen)\n this.keccak();\n const take = Math.min(blockLen - this.posOut, len - pos);\n out.set(bufferOut.subarray(this.posOut, this.posOut + take), pos);\n this.posOut += take;\n pos += take;\n }\n return out;\n }\n xofInto(out) {\n // Sha3/Keccak usage with XOF is probably mistake, only SHAKE instances can do XOF\n if (!this.enableXOF)\n throw new Error('XOF is not possible for this instance');\n return this.writeInto(out);\n }\n xof(bytes) {\n number(bytes);\n return this.xofInto(new Uint8Array(bytes));\n }\n digestInto(out) {\n output(out, this);\n if (this.finished)\n throw new Error('digest() was already called');\n this.writeInto(out);\n this.destroy();\n return out;\n }\n digest() {\n return this.digestInto(new Uint8Array(this.outputLen));\n }\n destroy() {\n this.destroyed = true;\n this.state.fill(0);\n }\n _cloneInto(to) {\n const { blockLen, suffix, outputLen, rounds, enableXOF } = this;\n to || (to = new Keccak(blockLen, suffix, outputLen, enableXOF, rounds));\n to.state32.set(this.state32);\n to.pos = this.pos;\n to.posOut = this.posOut;\n to.finished = this.finished;\n to.rounds = rounds;\n // Suffix can change in cSHAKE\n to.suffix = suffix;\n to.outputLen = outputLen;\n to.enableXOF = enableXOF;\n to.destroyed = this.destroyed;\n return to;\n }\n}\nconst gen = (suffix, blockLen, outputLen) => wrapConstructor(() => new Keccak(blockLen, suffix, outputLen));\nexport const sha3_224 = /* @__PURE__ */ gen(0x06, 144, 224 / 8);\n/**\n * SHA3-256 hash function\n * @param message - that would be hashed\n */\nexport const sha3_256 = /* @__PURE__ */ gen(0x06, 136, 256 / 8);\nexport const sha3_384 = /* @__PURE__ */ gen(0x06, 104, 384 / 8);\nexport const sha3_512 = /* @__PURE__ */ gen(0x06, 72, 512 / 8);\nexport const keccak_224 = /* @__PURE__ */ gen(0x01, 144, 224 / 8);\n/**\n * keccak-256 hash function. Different from SHA3-256.\n * @param message - that would be hashed\n */\nexport const keccak_256 = /* @__PURE__ */ gen(0x01, 136, 256 / 8);\nexport const keccak_384 = /* @__PURE__ */ gen(0x01, 104, 384 / 8);\nexport const keccak_512 = /* @__PURE__ */ gen(0x01, 72, 512 / 8);\nconst genShake = (suffix, blockLen, outputLen) => wrapXOFConstructorWithOpts((opts = {}) => new Keccak(blockLen, suffix, opts.dkLen === undefined ? outputLen : opts.dkLen, true));\nexport const shake128 = /* @__PURE__ */ genShake(0x1f, 168, 128 / 8);\nexport const shake256 = /* @__PURE__ */ genShake(0x1f, 136, 256 / 8);\n//# sourceMappingURL=sha3.js.map"],"names":["bytes"],"mappings":"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","x_google_ignoreList":[0]}
@@ -1,21 +1,9 @@
1
- import { Typed } from "./standards-sdk.es55.js";
2
- import { Coder } from "./standards-sdk.es41.js";
3
- class BooleanCoder extends Coder {
4
- constructor(localName) {
5
- super("bool", "bool", localName, false);
6
- }
7
- defaultValue() {
8
- return false;
9
- }
10
- encode(writer, _value) {
11
- const value = Typed.dereference(_value, "bool");
12
- return writer.writeValue(value ? 1 : 0);
13
- }
14
- decode(reader) {
15
- return !!reader.readValue();
16
- }
1
+ import { keccak256 } from "./standards-sdk.es40.js";
2
+ import { toUtf8Bytes } from "./standards-sdk.es45.js";
3
+ function id(value) {
4
+ return keccak256(toUtf8Bytes(value));
17
5
  }
18
6
  export {
19
- BooleanCoder
7
+ id
20
8
  };
21
9
  //# sourceMappingURL=standards-sdk.es44.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"standards-sdk.es44.js","sources":["../../node_modules/ethers/lib.esm/abi/coders/boolean.js"],"sourcesContent":["import { Typed } from \"../typed.js\";\nimport { Coder } from \"./abstract-coder.js\";\n/**\n * @_ignore\n */\nexport class BooleanCoder extends Coder {\n constructor(localName) {\n super(\"bool\", \"bool\", localName, false);\n }\n defaultValue() {\n return false;\n }\n encode(writer, _value) {\n const value = Typed.dereference(_value, \"bool\");\n return writer.writeValue(value ? 1 : 0);\n }\n decode(reader) {\n return !!reader.readValue();\n }\n}\n//# sourceMappingURL=boolean.js.map"],"names":[],"mappings":";;AAKO,MAAM,qBAAqB,MAAM;AAAA,EACpC,YAAY,WAAW;AACnB,UAAM,QAAQ,QAAQ,WAAW,KAAK;AAAA,EAC9C;AAAA,EACI,eAAe;AACX,WAAO;AAAA,EACf;AAAA,EACI,OAAO,QAAQ,QAAQ;AACnB,UAAM,QAAQ,MAAM,YAAY,QAAQ,MAAM;AAC9C,WAAO,OAAO,WAAW,QAAQ,IAAI,CAAC;AAAA,EAC9C;AAAA,EACI,OAAO,QAAQ;AACX,WAAO,CAAC,CAAC,OAAO,UAAW;AAAA,EACnC;AACA;","x_google_ignoreList":[0]}
1
+ {"version":3,"file":"standards-sdk.es44.js","sources":["../../node_modules/ethers/lib.esm/hash/id.js"],"sourcesContent":["import { keccak256 } from \"../crypto/index.js\";\nimport { toUtf8Bytes } from \"../utils/index.js\";\n/**\n * A simple hashing function which operates on UTF-8 strings to\n * compute an 32-byte identifier.\n *\n * This simply computes the [UTF-8 bytes](toUtf8Bytes) and computes\n * the [[keccak256]].\n *\n * @example:\n * id(\"hello world\")\n * //_result:\n */\nexport function id(value) {\n return keccak256(toUtf8Bytes(value));\n}\n//# sourceMappingURL=id.js.map"],"names":[],"mappings":";;AAaO,SAAS,GAAG,OAAO;AACtB,SAAO,UAAU,YAAY,KAAK,CAAC;AACvC;","x_google_ignoreList":[0]}