@helios-lang/effect 0.1.14 → 0.2.0

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 (387) hide show
  1. package/dist/Cardano/CoinSelection.js +130 -0
  2. package/dist/Cardano/CoinSelection.js.map +1 -0
  3. package/dist/{Ledger → Cardano/Ledger}/Address.js +30 -20
  4. package/dist/Cardano/Ledger/Address.js.map +1 -0
  5. package/dist/{Ledger → Cardano/Ledger}/AssetClass.js +16 -11
  6. package/dist/Cardano/Ledger/AssetClass.js.map +1 -0
  7. package/dist/Cardano/Ledger/Assets.js +235 -0
  8. package/dist/Cardano/Ledger/Assets.js.map +1 -0
  9. package/dist/Cardano/Ledger/Credential.js +53 -0
  10. package/dist/Cardano/Ledger/Credential.js.map +1 -0
  11. package/dist/Cardano/Ledger/DCert.js +117 -0
  12. package/dist/Cardano/Ledger/DCert.js.map +1 -0
  13. package/dist/Cardano/Ledger/DatumHash.js +25 -0
  14. package/dist/Cardano/Ledger/DatumHash.js.map +1 -0
  15. package/dist/Cardano/Ledger/MintingPolicy.js +40 -0
  16. package/dist/Cardano/Ledger/MintingPolicy.js.map +1 -0
  17. package/dist/Cardano/Ledger/NativeScript.js +140 -0
  18. package/dist/Cardano/Ledger/NativeScript.js.map +1 -0
  19. package/dist/Cardano/Ledger/PubKey.js +22 -0
  20. package/dist/Cardano/Ledger/PubKey.js.map +1 -0
  21. package/dist/{Ledger → Cardano/Ledger}/PubKeyHash.js +5 -5
  22. package/dist/Cardano/Ledger/PubKeyHash.js.map +1 -0
  23. package/dist/Cardano/Ledger/Redeemer.js +155 -0
  24. package/dist/Cardano/Ledger/Redeemer.js.map +1 -0
  25. package/dist/Cardano/Ledger/RewardAddress.js +93 -0
  26. package/dist/Cardano/Ledger/RewardAddress.js.map +1 -0
  27. package/dist/Cardano/Ledger/Signature.js +23 -0
  28. package/dist/Cardano/Ledger/Signature.js.map +1 -0
  29. package/dist/Cardano/Ledger/Tx.js +498 -0
  30. package/dist/Cardano/Ledger/Tx.js.map +1 -0
  31. package/dist/Cardano/Ledger/TxHash.js +38 -0
  32. package/dist/Cardano/Ledger/TxHash.js.map +1 -0
  33. package/dist/Cardano/Ledger/TxOutput.js +167 -0
  34. package/dist/Cardano/Ledger/TxOutput.js.map +1 -0
  35. package/dist/{Ledger → Cardano/Ledger}/TxOutputDatum.js +44 -8
  36. package/dist/Cardano/Ledger/TxOutputDatum.js.map +1 -0
  37. package/dist/Cardano/Ledger/UTxO.js +100 -0
  38. package/dist/Cardano/Ledger/UTxO.js.map +1 -0
  39. package/dist/{Ledger → Cardano/Ledger}/UTxORef.js +28 -6
  40. package/dist/Cardano/Ledger/UTxORef.js.map +1 -0
  41. package/dist/{Ledger → Cardano/Ledger}/ValidatorHash.js +5 -5
  42. package/dist/Cardano/Ledger/ValidatorHash.js.map +1 -0
  43. package/dist/{Ledger → Cardano/Ledger}/index.js +5 -0
  44. package/dist/Cardano/Ledger/index.js.map +1 -0
  45. package/dist/Cardano/Network/IsMainnet.js.map +1 -0
  46. package/dist/{Network → Cardano/Network}/Params.js +27 -3
  47. package/dist/Cardano/Network/Params.js.map +1 -0
  48. package/dist/Cardano/Network/UTxO.js +20 -0
  49. package/dist/Cardano/Network/UTxO.js.map +1 -0
  50. package/dist/Cardano/Network/UTxOsAt.js +4 -0
  51. package/dist/Cardano/Network/UTxOsAt.js.map +1 -0
  52. package/dist/Cardano/Network/errors.js +33 -0
  53. package/dist/Cardano/Network/errors.js.map +1 -0
  54. package/dist/{Network → Cardano/Network}/index.js +1 -0
  55. package/dist/Cardano/Network/index.js.map +1 -0
  56. package/dist/Cardano/TxBuilder.js +946 -0
  57. package/dist/Cardano/TxBuilder.js.map +1 -0
  58. package/dist/Cardano/Uplc/Builtins.js +1820 -0
  59. package/dist/Cardano/Uplc/Builtins.js.map +1 -0
  60. package/dist/Cardano/Uplc/Cek.js +716 -0
  61. package/dist/Cardano/Uplc/Cek.js.map +1 -0
  62. package/dist/Cardano/Uplc/Cost.js +956 -0
  63. package/dist/Cardano/Uplc/Cost.js.map +1 -0
  64. package/dist/{Uplc → Cardano/Uplc}/Data.js +143 -22
  65. package/dist/Cardano/Uplc/Data.js.map +1 -0
  66. package/dist/Cardano/Uplc/Script.js +118 -0
  67. package/dist/Cardano/Uplc/Script.js.map +1 -0
  68. package/dist/Cardano/Uplc/ScriptContext.js +259 -0
  69. package/dist/Cardano/Uplc/ScriptContext.js.map +1 -0
  70. package/dist/Cardano/Uplc/Term.js +384 -0
  71. package/dist/Cardano/Uplc/Term.js.map +1 -0
  72. package/dist/Cardano/Uplc/Type.js +131 -0
  73. package/dist/Cardano/Uplc/Type.js.map +1 -0
  74. package/dist/Cardano/Uplc/Value.js +315 -0
  75. package/dist/Cardano/Uplc/Value.js.map +1 -0
  76. package/dist/Cardano/Uplc/index.js +7 -0
  77. package/dist/Cardano/Uplc/index.js.map +1 -0
  78. package/dist/Cardano/index.js +6 -0
  79. package/dist/Cardano/index.js.map +1 -0
  80. package/dist/{internal → Codecs}/Base32.js +2 -2
  81. package/dist/Codecs/Base32.js.map +1 -0
  82. package/dist/{Bech32.js → Codecs/Bech32.js} +2 -2
  83. package/dist/Codecs/Bech32.js.map +1 -0
  84. package/dist/Codecs/BigEndian.js.map +1 -0
  85. package/dist/Codecs/Bits.js.map +1 -0
  86. package/dist/{internal → Codecs}/Bytes.js +23 -12
  87. package/dist/Codecs/Bytes.js.map +1 -0
  88. package/dist/{Cbor.js → Codecs/Cbor.js} +559 -328
  89. package/dist/Codecs/Cbor.js.map +1 -0
  90. package/dist/{internal → Codecs}/Flat.js +16 -0
  91. package/dist/Codecs/Flat.js.map +1 -0
  92. package/dist/Codecs/Float.js.map +1 -0
  93. package/dist/Codecs/LittleEndian.js +27 -0
  94. package/dist/Codecs/LittleEndian.js.map +1 -0
  95. package/dist/Codecs/Uint64.js +89 -0
  96. package/dist/Codecs/Uint64.js.map +1 -0
  97. package/dist/{internal → Codecs}/Utf8.js +7 -2
  98. package/dist/Codecs/Utf8.js.map +1 -0
  99. package/dist/Codecs/ZigZag.js +26 -0
  100. package/dist/Codecs/ZigZag.js.map +1 -0
  101. package/dist/Codecs/index.js +8 -0
  102. package/dist/Codecs/index.js.map +1 -0
  103. package/dist/Crypto/Blake2b.js +156 -0
  104. package/dist/Crypto/Blake2b.js.map +1 -0
  105. package/dist/Crypto/Curve.js +92 -0
  106. package/dist/Crypto/Curve.js.map +1 -0
  107. package/dist/Crypto/Ed25519.js +323 -0
  108. package/dist/Crypto/Ed25519.js.map +1 -0
  109. package/dist/Crypto/EdDSA.js +222 -0
  110. package/dist/Crypto/EdDSA.js.map +1 -0
  111. package/dist/Crypto/Field.js +323 -0
  112. package/dist/Crypto/Field.js.map +1 -0
  113. package/dist/Crypto/Hmac.js +51 -0
  114. package/dist/Crypto/Hmac.js.map +1 -0
  115. package/dist/Crypto/Keccak.js +167 -0
  116. package/dist/Crypto/Keccak.js.map +1 -0
  117. package/dist/Crypto/Pbkdf2.js +45 -0
  118. package/dist/Crypto/Pbkdf2.js.map +1 -0
  119. package/dist/Crypto/Sha2_256.js +200 -0
  120. package/dist/Crypto/Sha2_256.js.map +1 -0
  121. package/dist/Crypto/Sha2_512.js +264 -0
  122. package/dist/Crypto/Sha2_512.js.map +1 -0
  123. package/dist/Crypto/Sha3_256.js +10 -0
  124. package/dist/Crypto/Sha3_256.js.map +1 -0
  125. package/dist/Crypto/errors.js +9 -0
  126. package/dist/Crypto/errors.js.map +1 -0
  127. package/dist/Crypto/index.js +12 -0
  128. package/dist/Crypto/index.js.map +1 -0
  129. package/dist/index.js +3 -5
  130. package/dist/index.js.map +1 -1
  131. package/package.json +24 -6
  132. package/tsconfig.build.json +1 -1
  133. package/tsconfig.build.tsbuildinfo +1 -1
  134. package/tsconfig.tsbuildinfo +1 -1
  135. package/types/Cardano/CoinSelection.d.ts +26 -0
  136. package/types/Cardano/CoinSelection.d.ts.map +1 -0
  137. package/types/{Ledger → Cardano/Ledger}/Address.d.ts +7 -6
  138. package/types/Cardano/Ledger/Address.d.ts.map +1 -0
  139. package/types/{Ledger → Cardano/Ledger}/AssetClass.d.ts +2 -2
  140. package/types/Cardano/Ledger/AssetClass.d.ts.map +1 -0
  141. package/types/Cardano/Ledger/Assets.d.ts +114 -0
  142. package/types/Cardano/Ledger/Assets.d.ts.map +1 -0
  143. package/types/{Ledger → Cardano/Ledger}/Credential.d.ts +10 -4
  144. package/types/Cardano/Ledger/Credential.d.ts.map +1 -0
  145. package/types/Cardano/Ledger/DCert.d.ts +40 -0
  146. package/types/Cardano/Ledger/DCert.d.ts.map +1 -0
  147. package/types/{Ledger → Cardano/Ledger}/DatumHash.d.ts +6 -5
  148. package/types/Cardano/Ledger/DatumHash.d.ts.map +1 -0
  149. package/types/{Ledger → Cardano/Ledger}/MintingPolicy.d.ts +11 -8
  150. package/types/Cardano/Ledger/MintingPolicy.d.ts.map +1 -0
  151. package/types/Cardano/Ledger/NativeScript.d.ts +105 -0
  152. package/types/Cardano/Ledger/NativeScript.d.ts.map +1 -0
  153. package/types/Cardano/Ledger/PubKey.d.ts +41 -0
  154. package/types/Cardano/Ledger/PubKey.d.ts.map +1 -0
  155. package/types/{Ledger → Cardano/Ledger}/PubKeyHash.d.ts +5 -5
  156. package/types/Cardano/Ledger/PubKeyHash.d.ts.map +1 -0
  157. package/types/Cardano/Ledger/Redeemer.d.ts +303 -0
  158. package/types/Cardano/Ledger/Redeemer.d.ts.map +1 -0
  159. package/types/Cardano/Ledger/RewardAddress.d.ts +60 -0
  160. package/types/Cardano/Ledger/RewardAddress.d.ts.map +1 -0
  161. package/types/Cardano/Ledger/Signature.d.ts +13 -0
  162. package/types/Cardano/Ledger/Signature.d.ts.map +1 -0
  163. package/types/Cardano/Ledger/Tx.d.ts +375 -0
  164. package/types/Cardano/Ledger/Tx.d.ts.map +1 -0
  165. package/types/{Ledger → Cardano/Ledger}/TxHash.d.ts +35 -5
  166. package/types/Cardano/Ledger/TxHash.d.ts.map +1 -0
  167. package/types/Cardano/Ledger/TxOutput.d.ts +438 -0
  168. package/types/Cardano/Ledger/TxOutput.d.ts.map +1 -0
  169. package/types/Cardano/Ledger/TxOutputDatum.d.ts +98 -0
  170. package/types/Cardano/Ledger/TxOutputDatum.d.ts.map +1 -0
  171. package/types/Cardano/Ledger/UTxO.d.ts +1420 -0
  172. package/types/Cardano/Ledger/UTxO.d.ts.map +1 -0
  173. package/types/Cardano/Ledger/UTxORef.d.ts +222 -0
  174. package/types/Cardano/Ledger/UTxORef.d.ts.map +1 -0
  175. package/types/{Ledger → Cardano/Ledger}/ValidatorHash.d.ts +5 -5
  176. package/types/Cardano/Ledger/ValidatorHash.d.ts.map +1 -0
  177. package/types/{Ledger → Cardano/Ledger}/index.d.ts +5 -0
  178. package/types/Cardano/Ledger/index.d.ts.map +1 -0
  179. package/types/Cardano/Network/IsMainnet.d.ts.map +1 -0
  180. package/types/{Network → Cardano/Network}/Params.d.ts +32 -4
  181. package/types/Cardano/Network/Params.d.ts.map +1 -0
  182. package/types/Cardano/Network/UTxO.d.ts +15 -0
  183. package/types/Cardano/Network/UTxO.d.ts.map +1 -0
  184. package/types/Cardano/Network/UTxOsAt.d.ts +9 -0
  185. package/types/Cardano/Network/UTxOsAt.d.ts.map +1 -0
  186. package/types/Cardano/Network/errors.d.ts +39 -0
  187. package/types/Cardano/Network/errors.d.ts.map +1 -0
  188. package/types/{Network → Cardano/Network}/index.d.ts +1 -0
  189. package/types/Cardano/Network/index.d.ts.map +1 -0
  190. package/types/Cardano/TxBuilder.d.ts +261 -0
  191. package/types/Cardano/TxBuilder.d.ts.map +1 -0
  192. package/types/Cardano/Uplc/Builtins.d.ts +163 -0
  193. package/types/Cardano/Uplc/Builtins.d.ts.map +1 -0
  194. package/types/Cardano/Uplc/Cek.d.ts +165 -0
  195. package/types/Cardano/Uplc/Cek.d.ts.map +1 -0
  196. package/types/Cardano/Uplc/Cost.d.ts +93 -0
  197. package/types/Cardano/Uplc/Cost.d.ts.map +1 -0
  198. package/types/{Uplc → Cardano/Uplc}/Data.d.ts +149 -15
  199. package/types/Cardano/Uplc/Data.d.ts.map +1 -0
  200. package/types/Cardano/Uplc/Script.d.ts +87 -0
  201. package/types/Cardano/Uplc/Script.d.ts.map +1 -0
  202. package/types/Cardano/Uplc/ScriptContext.d.ts +21 -0
  203. package/types/Cardano/Uplc/ScriptContext.d.ts.map +1 -0
  204. package/types/Cardano/Uplc/Term.d.ts +454 -0
  205. package/types/Cardano/Uplc/Term.d.ts.map +1 -0
  206. package/types/Cardano/Uplc/Type.d.ts +29 -0
  207. package/types/Cardano/Uplc/Type.d.ts.map +1 -0
  208. package/types/Cardano/Uplc/Value.d.ts +152 -0
  209. package/types/Cardano/Uplc/Value.d.ts.map +1 -0
  210. package/types/Cardano/Uplc/index.d.ts +7 -0
  211. package/types/Cardano/Uplc/index.d.ts.map +1 -0
  212. package/types/Cardano/index.d.ts +6 -0
  213. package/types/Cardano/index.d.ts.map +1 -0
  214. package/types/Codecs/Base32.d.ts.map +1 -0
  215. package/types/Codecs/Bech32.d.ts.map +1 -0
  216. package/types/Codecs/BigEndian.d.ts.map +1 -0
  217. package/types/Codecs/Bits.d.ts.map +1 -0
  218. package/types/{internal → Codecs}/Bytes.d.ts +7 -6
  219. package/types/Codecs/Bytes.d.ts.map +1 -0
  220. package/types/{Cbor.d.ts → Codecs/Cbor.d.ts} +77 -55
  221. package/types/Codecs/Cbor.d.ts.map +1 -0
  222. package/types/{internal → Codecs}/Flat.d.ts +2 -0
  223. package/types/Codecs/Flat.d.ts.map +1 -0
  224. package/types/Codecs/Float.d.ts.map +1 -0
  225. package/types/Codecs/LittleEndian.d.ts +18 -0
  226. package/types/Codecs/LittleEndian.d.ts.map +1 -0
  227. package/types/Codecs/Uint64.d.ts +16 -0
  228. package/types/Codecs/Uint64.d.ts.map +1 -0
  229. package/types/{internal → Codecs}/Utf8.d.ts +2 -2
  230. package/types/Codecs/Utf8.d.ts.map +1 -0
  231. package/types/Codecs/ZigZag.d.ts +3 -0
  232. package/types/Codecs/ZigZag.d.ts.map +1 -0
  233. package/types/Codecs/index.d.ts +8 -0
  234. package/types/Codecs/index.d.ts.map +1 -0
  235. package/types/Crypto/Blake2b.d.ts +16 -0
  236. package/types/Crypto/Blake2b.d.ts.map +1 -0
  237. package/types/Crypto/Curve.d.ts +161 -0
  238. package/types/Crypto/Curve.d.ts.map +1 -0
  239. package/types/Crypto/Ed25519.d.ts +155 -0
  240. package/types/Crypto/Ed25519.d.ts.map +1 -0
  241. package/types/Crypto/EdDSA.d.ts +159 -0
  242. package/types/Crypto/EdDSA.d.ts.map +1 -0
  243. package/types/Crypto/Field.d.ts +273 -0
  244. package/types/Crypto/Field.d.ts.map +1 -0
  245. package/types/Crypto/Hmac.d.ts +20 -0
  246. package/types/Crypto/Hmac.d.ts.map +1 -0
  247. package/types/Crypto/Keccak.d.ts +16 -0
  248. package/types/Crypto/Keccak.d.ts.map +1 -0
  249. package/types/Crypto/Pbkdf2.d.ts +15 -0
  250. package/types/Crypto/Pbkdf2.d.ts.map +1 -0
  251. package/types/Crypto/Sha2_256.d.ts +36 -0
  252. package/types/Crypto/Sha2_256.d.ts.map +1 -0
  253. package/types/Crypto/Sha2_512.d.ts +31 -0
  254. package/types/Crypto/Sha2_512.d.ts.map +1 -0
  255. package/types/Crypto/Sha3_256.d.ts +8 -0
  256. package/types/Crypto/Sha3_256.d.ts.map +1 -0
  257. package/types/Crypto/errors.d.ts +10 -0
  258. package/types/Crypto/errors.d.ts.map +1 -0
  259. package/types/Crypto/index.d.ts +12 -0
  260. package/types/Crypto/index.d.ts.map +1 -0
  261. package/types/index.d.ts +3 -5
  262. package/types/index.d.ts.map +1 -1
  263. package/dist/Address.js +0 -13
  264. package/dist/Address.js.map +0 -1
  265. package/dist/Bech32.js.map +0 -1
  266. package/dist/Cbor.js.map +0 -1
  267. package/dist/Ledger/Address.js.map +0 -1
  268. package/dist/Ledger/AssetClass.js.map +0 -1
  269. package/dist/Ledger/Assets.js +0 -120
  270. package/dist/Ledger/Assets.js.map +0 -1
  271. package/dist/Ledger/Credential.js +0 -17
  272. package/dist/Ledger/Credential.js.map +0 -1
  273. package/dist/Ledger/DatumHash.js +0 -21
  274. package/dist/Ledger/DatumHash.js.map +0 -1
  275. package/dist/Ledger/IsMainnet.js +0 -4
  276. package/dist/Ledger/IsMainnet.js.map +0 -1
  277. package/dist/Ledger/MintingPolicy.js +0 -45
  278. package/dist/Ledger/MintingPolicy.js.map +0 -1
  279. package/dist/Ledger/NetworkParams.js +0 -40
  280. package/dist/Ledger/NetworkParams.js.map +0 -1
  281. package/dist/Ledger/PubKeyHash.js.map +0 -1
  282. package/dist/Ledger/TxHash.js +0 -23
  283. package/dist/Ledger/TxHash.js.map +0 -1
  284. package/dist/Ledger/TxId.js +0 -23
  285. package/dist/Ledger/TxId.js.map +0 -1
  286. package/dist/Ledger/TxInput.js +0 -51
  287. package/dist/Ledger/TxInput.js.map +0 -1
  288. package/dist/Ledger/TxOutput.js +0 -118
  289. package/dist/Ledger/TxOutput.js.map +0 -1
  290. package/dist/Ledger/TxOutputDatum.js.map +0 -1
  291. package/dist/Ledger/TxOutputId.js +0 -55
  292. package/dist/Ledger/TxOutputId.js.map +0 -1
  293. package/dist/Ledger/UTxO.js +0 -43
  294. package/dist/Ledger/UTxO.js.map +0 -1
  295. package/dist/Ledger/UTxORef.js.map +0 -1
  296. package/dist/Ledger/ValidatorHash.js.map +0 -1
  297. package/dist/Ledger/index.js.map +0 -1
  298. package/dist/Network/IsMainnet.js.map +0 -1
  299. package/dist/Network/Params.js.map +0 -1
  300. package/dist/Network/UTxOsAt.js +0 -4
  301. package/dist/Network/UTxOsAt.js.map +0 -1
  302. package/dist/Network/errors.js +0 -16
  303. package/dist/Network/errors.js.map +0 -1
  304. package/dist/Network/index.js.map +0 -1
  305. package/dist/Uplc/Cek.js +0 -3
  306. package/dist/Uplc/Cek.js.map +0 -1
  307. package/dist/Uplc/Data.js.map +0 -1
  308. package/dist/Uplc/DataSchema.js +0 -118
  309. package/dist/Uplc/DataSchema.js.map +0 -1
  310. package/dist/Uplc/Primitive.js +0 -23
  311. package/dist/Uplc/Primitive.js.map +0 -1
  312. package/dist/Uplc/index.js +0 -3
  313. package/dist/Uplc/index.js.map +0 -1
  314. package/dist/internal/Base32.js.map +0 -1
  315. package/dist/internal/BigEndian.js.map +0 -1
  316. package/dist/internal/Bits.js.map +0 -1
  317. package/dist/internal/Bytes.js.map +0 -1
  318. package/dist/internal/Flat.js.map +0 -1
  319. package/dist/internal/Float.js.map +0 -1
  320. package/dist/internal/Utf8.js.map +0 -1
  321. package/tsconfig.check.tsbuildinfo +0 -1
  322. package/types/Address.d.ts +0 -5
  323. package/types/Address.d.ts.map +0 -1
  324. package/types/Bech32.d.ts.map +0 -1
  325. package/types/Cbor.d.ts.map +0 -1
  326. package/types/Ledger/Address.d.ts.map +0 -1
  327. package/types/Ledger/AssetClass.d.ts.map +0 -1
  328. package/types/Ledger/Assets.d.ts +0 -70
  329. package/types/Ledger/Assets.d.ts.map +0 -1
  330. package/types/Ledger/Credential.d.ts.map +0 -1
  331. package/types/Ledger/DatumHash.d.ts.map +0 -1
  332. package/types/Ledger/IsMainnet.d.ts +0 -6
  333. package/types/Ledger/IsMainnet.d.ts.map +0 -1
  334. package/types/Ledger/MintingPolicy.d.ts.map +0 -1
  335. package/types/Ledger/NetworkParams.d.ts +0 -40
  336. package/types/Ledger/NetworkParams.d.ts.map +0 -1
  337. package/types/Ledger/PubKeyHash.d.ts.map +0 -1
  338. package/types/Ledger/TxHash.d.ts.map +0 -1
  339. package/types/Ledger/TxId.d.ts +0 -70
  340. package/types/Ledger/TxId.d.ts.map +0 -1
  341. package/types/Ledger/TxInput.d.ts +0 -55
  342. package/types/Ledger/TxInput.d.ts.map +0 -1
  343. package/types/Ledger/TxOutput.d.ts +0 -63
  344. package/types/Ledger/TxOutput.d.ts.map +0 -1
  345. package/types/Ledger/TxOutputDatum.d.ts +0 -41
  346. package/types/Ledger/TxOutputDatum.d.ts.map +0 -1
  347. package/types/Ledger/TxOutputId.d.ts +0 -133
  348. package/types/Ledger/TxOutputId.d.ts.map +0 -1
  349. package/types/Ledger/UTxO.d.ts +0 -55
  350. package/types/Ledger/UTxO.d.ts.map +0 -1
  351. package/types/Ledger/UTxORef.d.ts +0 -133
  352. package/types/Ledger/UTxORef.d.ts.map +0 -1
  353. package/types/Ledger/ValidatorHash.d.ts.map +0 -1
  354. package/types/Ledger/index.d.ts.map +0 -1
  355. package/types/Network/IsMainnet.d.ts.map +0 -1
  356. package/types/Network/Params.d.ts.map +0 -1
  357. package/types/Network/UTxOsAt.d.ts +0 -9
  358. package/types/Network/UTxOsAt.d.ts.map +0 -1
  359. package/types/Network/errors.d.ts +0 -18
  360. package/types/Network/errors.d.ts.map +0 -1
  361. package/types/Network/index.d.ts.map +0 -1
  362. package/types/Uplc/Cek.d.ts +0 -72
  363. package/types/Uplc/Cek.d.ts.map +0 -1
  364. package/types/Uplc/Data.d.ts.map +0 -1
  365. package/types/Uplc/DataSchema.d.ts +0 -227
  366. package/types/Uplc/DataSchema.d.ts.map +0 -1
  367. package/types/Uplc/Primitive.d.ts +0 -26
  368. package/types/Uplc/Primitive.d.ts.map +0 -1
  369. package/types/Uplc/index.d.ts +0 -3
  370. package/types/Uplc/index.d.ts.map +0 -1
  371. package/types/internal/Base32.d.ts.map +0 -1
  372. package/types/internal/BigEndian.d.ts.map +0 -1
  373. package/types/internal/Bits.d.ts.map +0 -1
  374. package/types/internal/Bytes.d.ts.map +0 -1
  375. package/types/internal/Flat.d.ts.map +0 -1
  376. package/types/internal/Float.d.ts.map +0 -1
  377. package/types/internal/Utf8.d.ts.map +0 -1
  378. /package/dist/{Network → Cardano/Network}/IsMainnet.js +0 -0
  379. /package/dist/{internal → Codecs}/BigEndian.js +0 -0
  380. /package/dist/{internal → Codecs}/Bits.js +0 -0
  381. /package/dist/{internal → Codecs}/Float.js +0 -0
  382. /package/types/{Network → Cardano/Network}/IsMainnet.d.ts +0 -0
  383. /package/types/{internal → Codecs}/Base32.d.ts +0 -0
  384. /package/types/{Bech32.d.ts → Codecs/Bech32.d.ts} +0 -0
  385. /package/types/{internal → Codecs}/BigEndian.d.ts +0 -0
  386. /package/types/{internal → Codecs}/Bits.d.ts +0 -0
  387. /package/types/{internal → Codecs}/Float.d.ts +0 -0
@@ -0,0 +1,323 @@
1
+ /**
2
+ * Positive modulo operator
3
+ * @param x
4
+ * @param modulo
5
+ * @returns
6
+ */
7
+ export function mod(x, modulo) {
8
+ const res = x % modulo;
9
+ if (res < 0n) {
10
+ return res + modulo;
11
+ }
12
+ else {
13
+ return res;
14
+ }
15
+ }
16
+ export class ScalarField {
17
+ /**
18
+ * Every operation is modulo this number
19
+ */
20
+ modulo;
21
+ constructor(modulo) {
22
+ this.modulo = modulo;
23
+ }
24
+ get ZERO() {
25
+ return 0n;
26
+ }
27
+ get ONE() {
28
+ return 1n;
29
+ }
30
+ /**
31
+ * @param a
32
+ * @param b
33
+ * @returns
34
+ */
35
+ add(a, ...b) {
36
+ return mod(b.reduce((sum, b) => sum + b, a), this.modulo);
37
+ }
38
+ /**
39
+ * @param a
40
+ * @param n
41
+ * @returns
42
+ */
43
+ scale(a, n) {
44
+ return mod(a * n, this.modulo);
45
+ }
46
+ /**
47
+ * Implemented separately from `scale` because it has a different meaning
48
+ * @param a
49
+ * @param b
50
+ * @returns
51
+ */
52
+ multiply(a, b) {
53
+ return mod(a * b, this.modulo);
54
+ }
55
+ /**
56
+ * @param a
57
+ * @param b
58
+ * @returns
59
+ */
60
+ equals(a, b) {
61
+ return mod(a, this.modulo) === mod(b, this.modulo);
62
+ }
63
+ /**
64
+ * Invert a number on a field (i.e. calculate n^-1 so that n*n^-1 = 1)
65
+ * This is an expensive iterative procedure that is only guaranteed to converge if the modulo is a prime number
66
+ * @param n
67
+ * @returns
68
+ */
69
+ invert(n) {
70
+ let a = mod(n, this.modulo);
71
+ let b = this.modulo;
72
+ let x = 0n;
73
+ let y = 1n;
74
+ let u = 1n;
75
+ let v = 0n;
76
+ while (a !== 0n) {
77
+ const q = b / a;
78
+ const r = b % a;
79
+ const m = x - u * q;
80
+ const n = y - v * q;
81
+ b = a;
82
+ a = r;
83
+ x = u;
84
+ y = v;
85
+ u = m;
86
+ v = n;
87
+ }
88
+ return mod(x, this.modulo);
89
+ }
90
+ }
91
+ /**
92
+ * Defines additional operations on a field (which use the basic operations as building blocks)
93
+ * * isZero(a)
94
+ * * isOne(a)
95
+ * * mod(a)
96
+ * * subtract(a, b)
97
+ * * negate(a)
98
+ * * square(a)
99
+ * * cube(a)
100
+ * * divide(a, b)
101
+ * * pow(a, p)
102
+ * * halve(a)
103
+ */
104
+ export class FieldHelper {
105
+ F;
106
+ /**
107
+ * @param F
108
+ */
109
+ constructor(F) {
110
+ this.F = F;
111
+ }
112
+ get ZERO() {
113
+ return this.F.ZERO;
114
+ }
115
+ get ONE() {
116
+ return this.F.ONE;
117
+ }
118
+ /**
119
+ * @param a
120
+ * @returns
121
+ */
122
+ isZero(a) {
123
+ return this.equals(a, this.ZERO);
124
+ }
125
+ /**
126
+ * @param a
127
+ * @returns
128
+ */
129
+ isOne(a) {
130
+ return this.equals(a, this.ONE);
131
+ }
132
+ /**
133
+ * @param a
134
+ * @returns
135
+ */
136
+ mod(a) {
137
+ return this.F.scale(a, 1n);
138
+ }
139
+ /**
140
+ * @param a
141
+ * @param bs
142
+ * @returns
143
+ */
144
+ add(a, ...bs) {
145
+ return this.F.add(a, ...bs);
146
+ }
147
+ /**
148
+ * @param a
149
+ * @param b
150
+ * @returns
151
+ */
152
+ subtract(a, b) {
153
+ const F = this.F;
154
+ return F.add(a, F.scale(b, -1n));
155
+ }
156
+ /**
157
+ * @param a
158
+ * @param s
159
+ * @returns
160
+ */
161
+ scale(a, s) {
162
+ return this.F.scale(a, s);
163
+ }
164
+ /**
165
+ * @param a
166
+ * @returns
167
+ */
168
+ negate(a) {
169
+ return this.F.scale(a, -1n);
170
+ }
171
+ /**
172
+ * @param a
173
+ * @param b
174
+ * @returns
175
+ */
176
+ multiply(a, b) {
177
+ return this.F.multiply(a, b);
178
+ }
179
+ /**
180
+ * @param a
181
+ * @returns
182
+ */
183
+ square(a) {
184
+ return this.F.multiply(a, a);
185
+ }
186
+ /**
187
+ * @param a
188
+ * @returns
189
+ */
190
+ cube(a) {
191
+ return this.F.multiply(a, this.F.multiply(a, a));
192
+ }
193
+ /**
194
+ * @param a
195
+ * @param b
196
+ * @returns
197
+ */
198
+ divide(a, b) {
199
+ return this.F.multiply(a, this.F.invert(b));
200
+ }
201
+ /**
202
+ * @param a
203
+ * @returns
204
+ */
205
+ invert(a) {
206
+ return this.F.invert(a);
207
+ }
208
+ /**
209
+ * Modular exponent
210
+ * TODO: would a non-recursive version of this algorithm be faster?
211
+ * @param a
212
+ * @param p
213
+ * @returns
214
+ */
215
+ pow(a, p) {
216
+ if (p == 0n) {
217
+ return this.F.ONE;
218
+ }
219
+ else if (p == 1n) {
220
+ return a;
221
+ }
222
+ else {
223
+ let t = this.pow(a, p / 2n);
224
+ t = this.F.multiply(t, t);
225
+ if (p % 2n != 0n) {
226
+ t = this.F.multiply(t, a);
227
+ }
228
+ return t;
229
+ }
230
+ }
231
+ /**
232
+ * @param a
233
+ * @param b
234
+ * @returns
235
+ */
236
+ equals(a, b) {
237
+ return this.F.equals(a, b);
238
+ }
239
+ /**
240
+ * @param a
241
+ * @returns
242
+ */
243
+ halve(a) {
244
+ return this.divide(a, this.F.scale(this.F.ONE, 2n));
245
+ }
246
+ }
247
+ export class QuadraticField {
248
+ /**
249
+ * Field used for each component
250
+ */
251
+ F;
252
+ /**
253
+ * We can always replace u^2 by this number (e.g. for complex numbers this is -1)
254
+ */
255
+ U2;
256
+ /**
257
+ * @param F
258
+ * Applied to each part separately
259
+ * @param U2
260
+ */
261
+ constructor(F, U2) {
262
+ this.F = F;
263
+ this.U2 = U2;
264
+ }
265
+ get ZERO() {
266
+ return [this.F.ZERO, this.F.ZERO];
267
+ }
268
+ get ONE() {
269
+ return [this.F.ONE, this.F.ZERO];
270
+ }
271
+ /**
272
+ * @param a
273
+ * @param b
274
+ * @returns
275
+ */
276
+ add([ax, ay], ...b) {
277
+ const F = this.F;
278
+ return [F.add(ax, ...b.map((b) => b[0])), F.add(ay, ...b.map((b) => b[1]))];
279
+ }
280
+ /**
281
+ * @param a
282
+ * @param s
283
+ * @returns
284
+ */
285
+ scale([ax, ay], s) {
286
+ const F = this.F;
287
+ return [F.scale(ax, s), F.scale(ay, s)];
288
+ }
289
+ /**
290
+ * @param a
291
+ * @param b
292
+ * @returns
293
+ */
294
+ multiply([ax, ay], [bx, by]) {
295
+ const F = this.F;
296
+ return [
297
+ F.add(F.multiply(ax, bx), F.multiply(F.multiply(ay, by), this.U2)),
298
+ F.add(F.multiply(ay, bx), F.multiply(by, ax))
299
+ ];
300
+ }
301
+ /**
302
+ * @param a
303
+ * @param b
304
+ * @returns
305
+ */
306
+ equals([ax, ay], [bx, by]) {
307
+ const F = this.F;
308
+ return F.equals(ax, bx) && F.equals(ay, by);
309
+ }
310
+ /**
311
+ * Using the following formula we can derive the inverse of complex field element
312
+ * (ax + u*ay)*(ax - u*ay) = ax^2 - u^2*ay^2
313
+ * (ax + u*ay)^-1 = (ax - u*ay)/(ax^2 - u^2*ay^2)
314
+ * @param a
315
+ * @returns
316
+ */
317
+ invert([ax, ay]) {
318
+ const F = new FieldHelper(this.F);
319
+ const f = F.invert(F.subtract(F.square(ax), F.multiply(F.square(ay), this.U2)));
320
+ return [F.multiply(ax, f), F.multiply(ay, F.negate(f))];
321
+ }
322
+ }
323
+ //# sourceMappingURL=Field.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Field.js","sourceRoot":"","sources":["../../src/Crypto/Field.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,51 @@
1
+ import * as Bytes from "../Codecs/Bytes.js";
2
+ import * as Sha2_256 from "./Sha2_256.js";
3
+ import * as Sha2_512 from "./Sha2_512.js";
4
+ /**
5
+ * Hmac using sha2-256.
6
+ * @example
7
+ * bytesToHex(hmacSha2_256(textToBytes("key"), textToBytes("The quick brown fox jumps over the lazy dog"))) == "f7bc83f430538424b13298e6aa6fb143ef4d59a14946175997479dbc2d1a3cd8"
8
+ * @param key
9
+ * @param message
10
+ * @returns
11
+ */
12
+ export function sha2_256Sync(key, message) {
13
+ return deriveSyncInternal(Sha2_256.hashSync, 64)(Bytes.toUint8Array(key), Bytes.toUint8Array(message));
14
+ }
15
+ /**
16
+ * Hmac using sha2-512.
17
+ * @example
18
+ * bytesToHex(hmacSha2_512(textToBytes("key"), textToBytes("The quick brown fox jumps over the lazy dog"))) == "b42af09057bac1e2d41708e48a902e09b5ff7f12ab428a4fe86653c73dd248fb82f948a549f7b791a5b41915ee4d1ec3935357e4e2317250d0372afa2ebeeb3a"
19
+ * @param key
20
+ * @param message
21
+ * @returns
22
+ */
23
+ export function sha2_512Sync(key, message) {
24
+ return deriveSyncInternal(Sha2_512.hashSync, 128)(Bytes.toUint8Array(key), Bytes.toUint8Array(message));
25
+ }
26
+ /**
27
+ * Don't use this directly, use hmacSyncSha2_256 or hmacSyncSha2_512 instead
28
+ * @param algorithm
29
+ * sync hashing function
30
+ * @param b
31
+ * blockSize of algorithm
32
+ * @returns
33
+ */
34
+ const deriveSyncInternal = (algorithm, blockSize) => (key, message) => {
35
+ if (key.length > blockSize) {
36
+ key = algorithm(key);
37
+ }
38
+ else {
39
+ key = key.slice();
40
+ }
41
+ while (key.length < blockSize) {
42
+ const tmp = new Uint8Array(key.length + 1);
43
+ tmp.set(key);
44
+ tmp[key.length] = 0x00;
45
+ key = tmp;
46
+ }
47
+ const iPadded = key.map((k) => k ^ 0x36);
48
+ const oPadded = key.map((k) => k ^ 0x5c);
49
+ return algorithm(Bytes.concat(oPadded, algorithm(Bytes.concat(iPadded, message))));
50
+ };
51
+ //# sourceMappingURL=Hmac.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Hmac.js","sourceRoot":"","sources":["../../src/Crypto/Hmac.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,oBAAoB,CAAA;AAC3C,OAAO,KAAK,QAAQ,MAAM,eAAe,CAAA;AACzC,OAAO,KAAK,QAAQ,MAAM,eAAe,CAAA;AAEzC;;;;;;;GAOG;AACH,MAAM,UAAU,YAAY,CAC1B,GAAoB,EACpB,OAAwB;IAExB,OAAO,kBAAkB,CAAC,QAAQ,CAAC,QAAQ,EAAE,EAAE,CAAC,CAC9C,KAAK,CAAC,YAAY,CAAC,GAAG,CAAC,EACvB,KAAK,CAAC,YAAY,CAAC,OAAO,CAAC,CAC5B,CAAA;AACH,CAAC;AAED;;;;;;;GAOG;AACH,MAAM,UAAU,YAAY,CAC1B,GAAoB,EACpB,OAAwB;IAExB,OAAO,kBAAkB,CAAC,QAAQ,CAAC,QAAQ,EAAE,GAAG,CAAC,CAC/C,KAAK,CAAC,YAAY,CAAC,GAAG,CAAC,EACvB,KAAK,CAAC,YAAY,CAAC,OAAO,CAAC,CAC5B,CAAA;AACH,CAAC;AAED;;;;;;;GAOG;AACH,MAAM,kBAAkB,GACtB,CAAC,SAAwC,EAAE,SAAiB,EAAE,EAAE,CAChE,CAAC,GAAe,EAAE,OAAmB,EAAc,EAAE;IACnD,IAAI,GAAG,CAAC,MAAM,GAAG,SAAS,EAAE,CAAC;QAC3B,GAAG,GAAG,SAAS,CAAC,GAAG,CAAC,CAAA;IACtB,CAAC;SAAM,CAAC;QACN,GAAG,GAAG,GAAG,CAAC,KAAK,EAAE,CAAA;IACnB,CAAC;IAED,OAAO,GAAG,CAAC,MAAM,GAAG,SAAS,EAAE,CAAC;QAC9B,MAAM,GAAG,GAAG,IAAI,UAAU,CAAC,GAAG,CAAC,MAAM,GAAG,CAAC,CAAC,CAAA;QAC1C,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;QACZ,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,IAAI,CAAA;QACtB,GAAG,GAAG,GAAG,CAAA;IACX,CAAC;IAED,MAAM,OAAO,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC,CAAA;IACxC,MAAM,OAAO,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC,CAAA;IAExC,OAAO,SAAS,CACd,KAAK,CAAC,MAAM,CAAC,OAAO,EAAE,SAAS,CAAC,KAAK,CAAC,MAAM,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,CACjE,CAAA;AACH,CAAC,CAAA"}
@@ -0,0 +1,167 @@
1
+ import * as Bytes from "../Codecs/Bytes.js";
2
+ import * as Uint64 from "../Codecs/Uint64.js";
3
+ /**
4
+ * Keccak is a family of hashing functions, of which Sha3 is the most well-known
5
+ *
6
+ * Keccak_256 refers to the older implementation, using 0x01 as a padByte (Sha3 uses 0x06 as a padyte)
7
+ */
8
+ /**
9
+ * @param bytes
10
+ * List of uint8 numbers
11
+ * @param padByte
12
+ * 0x06 for sha3 or 0x01 for keccak
13
+ * @returns
14
+ * List of uint8 numbers.
15
+ */
16
+ export function hashSync(bs, padByte = 0x01) {
17
+ /**
18
+ * Sha3 uses only bit-wise operations, so 64-bit operations can easily be replicated using 2 32-bit operations instead.
19
+ */
20
+ const bytes = pad(Bytes.toArray(bs), padByte);
21
+ /**
22
+ * Initialize the state
23
+ */
24
+ const state = new Array(WIDTH / 8).fill(Uint64.Zero);
25
+ for (let chunkStart = 0; chunkStart < bytes.length; chunkStart += RATE) {
26
+ // extend the chunk to become length WIDTH
27
+ const chunk = bytes
28
+ .slice(chunkStart, chunkStart + RATE)
29
+ .concat(new Array(CAP).fill(0));
30
+ // element-wise xor with 'state'
31
+ for (let i = 0; i < WIDTH; i += 8) {
32
+ state[i / 8] = Uint64.xor(state[i / 8], Uint64.fromBytes(chunk.slice(i, i + 8)));
33
+ // beware: a uint32 is stored as little endian, but a pair of uint32s that form a uin64 are stored in big endian format!
34
+ }
35
+ // apply block permutations
36
+ permute(state);
37
+ }
38
+ let hash = [];
39
+ for (let i = 0; i < 4; i++) {
40
+ hash = hash.concat(Uint64.toBytes(state[i]));
41
+ }
42
+ return new Uint8Array(hash);
43
+ }
44
+ /**
45
+ * State width (1600 bits, )
46
+ */
47
+ const WIDTH = 200;
48
+ /**
49
+ * Rate (1088 bits, 136 bytes)
50
+ */
51
+ const RATE = 136;
52
+ /**
53
+ * Capacity
54
+ */
55
+ const CAP = /* @__PURE__ */ (() => WIDTH - RATE)();
56
+ /**
57
+ * 24 numbers used in the sha3 permute function
58
+ */
59
+ const OFFSETS = [
60
+ 6, 12, 18, 24, 3, 9, 10, 16, 22, 1, 7, 13, 19, 20, 4, 5, 11, 17, 23, 2, 8, 14,
61
+ 15, 21
62
+ ];
63
+ /**
64
+ * 24 numbers used in the sha3 permute function
65
+ */
66
+ const SHIFTS = [
67
+ -12, -11, 21, 14, 28, 20, 3, -13, -29, 1, 6, 25, 8, 18, 27, -4, 10, 15, -24,
68
+ -30, -23, -7, -9, 2
69
+ ];
70
+ /**
71
+ * Round constants used in the sha3 permute function
72
+ */
73
+ const RC = [
74
+ { high: 0x00000000, low: 0x00000001 },
75
+ { high: 0x00000000, low: 0x00008082 },
76
+ { high: 0x80000000, low: 0x0000808a },
77
+ { high: 0x80000000, low: 0x80008000 },
78
+ { high: 0x00000000, low: 0x0000808b },
79
+ { high: 0x00000000, low: 0x80000001 },
80
+ { high: 0x80000000, low: 0x80008081 },
81
+ { high: 0x80000000, low: 0x00008009 },
82
+ { high: 0x00000000, low: 0x0000008a },
83
+ { high: 0x00000000, low: 0x00000088 },
84
+ { high: 0x00000000, low: 0x80008009 },
85
+ { high: 0x00000000, low: 0x8000000a },
86
+ { high: 0x00000000, low: 0x8000808b },
87
+ { high: 0x80000000, low: 0x0000008b },
88
+ { high: 0x80000000, low: 0x00008089 },
89
+ { high: 0x80000000, low: 0x00008003 },
90
+ { high: 0x80000000, low: 0x00008002 },
91
+ { high: 0x80000000, low: 0x00000080 },
92
+ { high: 0x00000000, low: 0x0000800a },
93
+ { high: 0x80000000, low: 0x8000000a },
94
+ { high: 0x80000000, low: 0x80008081 },
95
+ { high: 0x80000000, low: 0x00008080 },
96
+ { high: 0x00000000, low: 0x80000001 },
97
+ { high: 0x80000000, low: 0x80008008 }
98
+ ];
99
+ /**
100
+ * Apply 1000...1 padding until size is multiple of r.
101
+ * If already multiple of r then add a whole block of padding.
102
+ * @param src
103
+ * List of uint8 numbers
104
+ * @param {number} padByte 0x06 for sha3, 0x01 for keccak
105
+ * @returns {number[]} - list of uint8 numbers
106
+ */
107
+ function pad(src, padByte) {
108
+ const dst = src.slice();
109
+ let nZeroes = RATE - 2 - (dst.length % RATE);
110
+ if (nZeroes < -1) {
111
+ nZeroes += RATE - 2;
112
+ }
113
+ if (nZeroes == -1) {
114
+ dst.push(0x80 + padByte);
115
+ }
116
+ else {
117
+ dst.push(padByte);
118
+ for (let i = 0; i < nZeroes; i++) {
119
+ dst.push(0);
120
+ }
121
+ dst.push(0x80);
122
+ }
123
+ if (dst.length % RATE != 0) {
124
+ throw new Error("bad padding");
125
+ }
126
+ return dst;
127
+ }
128
+ /**
129
+ * Change `s` in-place
130
+ * @param s
131
+ */
132
+ function permute(s) {
133
+ const c = new Array(5);
134
+ const b = new Array(25);
135
+ for (let round = 0; round < 24; round++) {
136
+ for (let i = 0; i < 5; i++) {
137
+ c[i] = Uint64.xor(Uint64.xor(Uint64.xor(Uint64.xor(s[i], s[i + 5]), s[i + 10]), s[i + 15]), s[i + 20]);
138
+ }
139
+ for (let i = 0; i < 5; i++) {
140
+ const i1 = (i + 1) % 5;
141
+ const i2 = (i + 4) % 5;
142
+ const tmp = Uint64.xor(c[i2], Uint64.rotr(c[i1], 63));
143
+ for (let j = 0; j < 5; j++) {
144
+ s[i + 5 * j] = Uint64.xor(s[i + 5 * j], tmp);
145
+ }
146
+ }
147
+ b[0] = s[0];
148
+ for (let i = 1; i < 25; i++) {
149
+ const offset = OFFSETS[i - 1];
150
+ const left = Math.abs(SHIFTS[i - 1]);
151
+ const right = 32 - left;
152
+ if (SHIFTS[i - 1] < 0) {
153
+ b[i] = Uint64.rotr(s[offset], right);
154
+ }
155
+ else {
156
+ b[i] = Uint64.rotr(s[offset], right + 32);
157
+ }
158
+ }
159
+ for (let i = 0; i < 5; i++) {
160
+ for (let j = 0; j < 5; j++) {
161
+ s[i * 5 + j] = Uint64.xor(b[i * 5 + j], Uint64.and(Uint64.not(b[i * 5 + ((j + 1) % 5)]), b[i * 5 + ((j + 2) % 5)]));
162
+ }
163
+ }
164
+ s[0] = Uint64.xor(s[0], RC[round]);
165
+ }
166
+ }
167
+ //# sourceMappingURL=Keccak.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Keccak.js","sourceRoot":"","sources":["../../src/Crypto/Keccak.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,45 @@
1
+ import * as BigEndian from "../Codecs/BigEndian.js";
2
+ import * as Bytes from "../Codecs/Bytes.js";
3
+ /**
4
+ * Password-Based Key Derivation Function 2.
5
+ * @example
6
+ * bytesToHex(pbkdf2(hmacSha2_256, textToBytes("password"), textToBytes("salt"), 1, 20)) == "120fb6cffcf8b32c43e7225256c4f837a86548c9"
7
+ * @example
8
+ * bytesToHex(pbkdf2(hmacSha2_512, textToBytes("password"), textToBytes("salt"), 2, 20)) == "e1d9c16aa681708a45f5c7c4e215ceb66e011a2e"
9
+ * @param prf
10
+ * @param password
11
+ * @param salt
12
+ * @param nIters
13
+ * @param keyLen
14
+ * @returns
15
+ */
16
+ export function deriveSync(prf, password, salt, nIters, keyLen) {
17
+ let dk = new Uint8Array([]);
18
+ let i = 1n;
19
+ while (dk.length < keyLen) {
20
+ const bi = BigEndian.encode(i);
21
+ while (bi.length < 4) {
22
+ bi.unshift(0);
23
+ }
24
+ let U = prf(password, Bytes.concat(salt, bi));
25
+ let T = U;
26
+ for (let j = 1; j < nIters; j++) {
27
+ U = prf(password, U);
28
+ T = xor(T, U);
29
+ }
30
+ dk = Bytes.concat(dk, T);
31
+ i += 1n;
32
+ }
33
+ if (dk.length > keyLen) {
34
+ dk = dk.slice(0, keyLen);
35
+ }
36
+ return dk;
37
+ }
38
+ function xor(a, b) {
39
+ const c = new Uint8Array(a.length);
40
+ for (let i = 0; i < a.length; i++) {
41
+ c[i] = a[i] ^ b[i];
42
+ }
43
+ return c;
44
+ }
45
+ //# sourceMappingURL=Pbkdf2.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Pbkdf2.js","sourceRoot":"","sources":["../../src/Crypto/Pbkdf2.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,SAAS,MAAM,wBAAwB,CAAA;AACnD,OAAO,KAAK,KAAK,MAAM,oBAAoB,CAAA;AAE3C;;;;;;;;;;;;GAYG;AACH,MAAM,UAAU,UAAU,CACxB,GAAqD,EACrD,QAAoB,EACpB,IAAgB,EAChB,MAAc,EACd,MAAc;IAEd,IAAI,EAAE,GAAe,IAAI,UAAU,CAAC,EAAE,CAAC,CAAA;IAEvC,IAAI,CAAC,GAAG,EAAE,CAAA;IACV,OAAO,EAAE,CAAC,MAAM,GAAG,MAAM,EAAE,CAAC;QAC1B,MAAM,EAAE,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,CAAA;QAC9B,OAAO,EAAE,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACrB,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,CAAA;QACf,CAAC;QAED,IAAI,CAAC,GAAG,GAAG,CAAC,QAAQ,EAAE,KAAK,CAAC,MAAM,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,CAAA;QAC7C,IAAI,CAAC,GAAG,CAAC,CAAA;QAET,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YAChC,CAAC,GAAG,GAAG,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAA;YACpB,CAAC,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAA;QACf,CAAC;QAED,EAAE,GAAG,KAAK,CAAC,MAAM,CAAC,EAAE,EAAE,CAAC,CAAC,CAAA;QAExB,CAAC,IAAI,EAAE,CAAA;IACT,CAAC;IAED,IAAI,EAAE,CAAC,MAAM,GAAG,MAAM,EAAE,CAAC;QACvB,EAAE,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,CAAC,CAAA;IAC1B,CAAC;IAED,OAAO,EAAE,CAAA;AACX,CAAC;AAED,SAAS,GAAG,CAAC,CAAa,EAAE,CAAa;IACvC,MAAM,CAAC,GAAG,IAAI,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,CAAA;IAElC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;QAClC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAA;IACpB,CAAC;IAED,OAAO,CAAC,CAAA;AACV,CAAC"}