@oqs/liboqs-js 0.15.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 (317) hide show
  1. package/LICENSE.md +50 -0
  2. package/README.md +829 -0
  3. package/bin/cli.js +16 -0
  4. package/dist/classic-mceliece-348864.deno.js +0 -0
  5. package/dist/classic-mceliece-348864.min.js +0 -0
  6. package/dist/classic-mceliece-348864f.deno.js +0 -0
  7. package/dist/classic-mceliece-348864f.min.js +0 -0
  8. package/dist/classic-mceliece-460896.deno.js +0 -0
  9. package/dist/classic-mceliece-460896.min.js +0 -0
  10. package/dist/classic-mceliece-460896f.deno.js +0 -0
  11. package/dist/classic-mceliece-460896f.min.js +0 -0
  12. package/dist/classic-mceliece-6688128.deno.js +0 -0
  13. package/dist/classic-mceliece-6688128.min.js +0 -0
  14. package/dist/classic-mceliece-6688128f.deno.js +0 -0
  15. package/dist/classic-mceliece-6688128f.min.js +0 -0
  16. package/dist/classic-mceliece-6960119.deno.js +0 -0
  17. package/dist/classic-mceliece-6960119.min.js +0 -0
  18. package/dist/classic-mceliece-6960119f.deno.js +0 -0
  19. package/dist/classic-mceliece-6960119f.min.js +0 -0
  20. package/dist/classic-mceliece-8192128.deno.js +0 -0
  21. package/dist/classic-mceliece-8192128.min.js +0 -0
  22. package/dist/classic-mceliece-8192128f.deno.js +0 -0
  23. package/dist/classic-mceliece-8192128f.min.js +0 -0
  24. package/dist/cross-rsdp-128-balanced.deno.js +0 -0
  25. package/dist/cross-rsdp-128-balanced.min.js +0 -0
  26. package/dist/cross-rsdp-128-fast.deno.js +0 -0
  27. package/dist/cross-rsdp-128-fast.min.js +0 -0
  28. package/dist/cross-rsdp-128-small.deno.js +0 -0
  29. package/dist/cross-rsdp-128-small.min.js +0 -0
  30. package/dist/cross-rsdp-192-balanced.deno.js +0 -0
  31. package/dist/cross-rsdp-192-balanced.min.js +0 -0
  32. package/dist/cross-rsdp-192-fast.deno.js +0 -0
  33. package/dist/cross-rsdp-192-fast.min.js +0 -0
  34. package/dist/cross-rsdp-192-small.deno.js +0 -0
  35. package/dist/cross-rsdp-192-small.min.js +0 -0
  36. package/dist/cross-rsdp-256-balanced.deno.js +0 -0
  37. package/dist/cross-rsdp-256-balanced.min.js +0 -0
  38. package/dist/cross-rsdp-256-fast.deno.js +0 -0
  39. package/dist/cross-rsdp-256-fast.min.js +0 -0
  40. package/dist/cross-rsdp-256-small.deno.js +0 -0
  41. package/dist/cross-rsdp-256-small.min.js +0 -0
  42. package/dist/cross-rsdpg-128-balanced.deno.js +0 -0
  43. package/dist/cross-rsdpg-128-balanced.min.js +0 -0
  44. package/dist/cross-rsdpg-128-fast.deno.js +0 -0
  45. package/dist/cross-rsdpg-128-fast.min.js +0 -0
  46. package/dist/cross-rsdpg-128-small.deno.js +0 -0
  47. package/dist/cross-rsdpg-128-small.min.js +0 -0
  48. package/dist/cross-rsdpg-192-balanced.deno.js +0 -0
  49. package/dist/cross-rsdpg-192-balanced.min.js +0 -0
  50. package/dist/cross-rsdpg-192-fast.deno.js +0 -0
  51. package/dist/cross-rsdpg-192-fast.min.js +0 -0
  52. package/dist/cross-rsdpg-192-small.deno.js +0 -0
  53. package/dist/cross-rsdpg-192-small.min.js +0 -0
  54. package/dist/cross-rsdpg-256-balanced.deno.js +0 -0
  55. package/dist/cross-rsdpg-256-balanced.min.js +0 -0
  56. package/dist/cross-rsdpg-256-fast.deno.js +0 -0
  57. package/dist/cross-rsdpg-256-fast.min.js +0 -0
  58. package/dist/cross-rsdpg-256-small.deno.js +0 -0
  59. package/dist/cross-rsdpg-256-small.min.js +0 -0
  60. package/dist/falcon-1024.deno.js +0 -0
  61. package/dist/falcon-1024.min.js +0 -0
  62. package/dist/falcon-512.deno.js +0 -0
  63. package/dist/falcon-512.min.js +0 -0
  64. package/dist/falcon-padded-1024.deno.js +0 -0
  65. package/dist/falcon-padded-1024.min.js +0 -0
  66. package/dist/falcon-padded-512.deno.js +0 -0
  67. package/dist/falcon-padded-512.min.js +0 -0
  68. package/dist/frodokem-1344-aes.deno.js +0 -0
  69. package/dist/frodokem-1344-aes.min.js +0 -0
  70. package/dist/frodokem-1344-shake.deno.js +0 -0
  71. package/dist/frodokem-1344-shake.min.js +0 -0
  72. package/dist/frodokem-640-aes.deno.js +0 -0
  73. package/dist/frodokem-640-aes.min.js +0 -0
  74. package/dist/frodokem-640-shake.deno.js +0 -0
  75. package/dist/frodokem-640-shake.min.js +0 -0
  76. package/dist/frodokem-976-aes.deno.js +0 -0
  77. package/dist/frodokem-976-aes.min.js +0 -0
  78. package/dist/frodokem-976-shake.deno.js +0 -0
  79. package/dist/frodokem-976-shake.min.js +0 -0
  80. package/dist/hqc-128.deno.js +0 -0
  81. package/dist/hqc-128.min.js +0 -0
  82. package/dist/hqc-192.deno.js +0 -0
  83. package/dist/hqc-192.min.js +0 -0
  84. package/dist/hqc-256.deno.js +0 -0
  85. package/dist/hqc-256.min.js +0 -0
  86. package/dist/kyber-1024.deno.js +0 -0
  87. package/dist/kyber-1024.min.js +0 -0
  88. package/dist/kyber-512.deno.js +0 -0
  89. package/dist/kyber-512.min.js +0 -0
  90. package/dist/kyber-768.deno.js +0 -0
  91. package/dist/kyber-768.min.js +0 -0
  92. package/dist/mayo-1.deno.js +0 -0
  93. package/dist/mayo-1.min.js +0 -0
  94. package/dist/mayo-2.deno.js +0 -0
  95. package/dist/mayo-2.min.js +0 -0
  96. package/dist/mayo-3.deno.js +0 -0
  97. package/dist/mayo-3.min.js +0 -0
  98. package/dist/mayo-5.deno.js +0 -0
  99. package/dist/mayo-5.min.js +0 -0
  100. package/dist/ml-dsa-44.deno.js +0 -0
  101. package/dist/ml-dsa-44.min.js +0 -0
  102. package/dist/ml-dsa-65.deno.js +0 -0
  103. package/dist/ml-dsa-65.min.js +0 -0
  104. package/dist/ml-dsa-87.deno.js +0 -0
  105. package/dist/ml-dsa-87.min.js +0 -0
  106. package/dist/ml-kem-1024.deno.js +0 -0
  107. package/dist/ml-kem-1024.min.js +0 -0
  108. package/dist/ml-kem-512.deno.js +0 -0
  109. package/dist/ml-kem-512.min.js +0 -0
  110. package/dist/ml-kem-768.deno.js +0 -0
  111. package/dist/ml-kem-768.min.js +0 -0
  112. package/dist/ntru-hps-2048-509.deno.js +0 -0
  113. package/dist/ntru-hps-2048-509.min.js +0 -0
  114. package/dist/ntru-hps-2048-677.deno.js +0 -0
  115. package/dist/ntru-hps-2048-677.min.js +0 -0
  116. package/dist/ntru-hps-4096-1229.deno.js +0 -0
  117. package/dist/ntru-hps-4096-1229.min.js +0 -0
  118. package/dist/ntru-hps-4096-821.deno.js +0 -0
  119. package/dist/ntru-hps-4096-821.min.js +0 -0
  120. package/dist/ntru-hrss-1373.deno.js +0 -0
  121. package/dist/ntru-hrss-1373.min.js +0 -0
  122. package/dist/ntru-hrss-701.deno.js +0 -0
  123. package/dist/ntru-hrss-701.min.js +0 -0
  124. package/dist/ov-iii-pkc-skc.deno.js +0 -0
  125. package/dist/ov-iii-pkc-skc.min.js +0 -0
  126. package/dist/ov-iii-pkc.deno.js +0 -0
  127. package/dist/ov-iii-pkc.min.js +0 -0
  128. package/dist/ov-iii.deno.js +0 -0
  129. package/dist/ov-iii.min.js +0 -0
  130. package/dist/ov-ip-pkc-skc.deno.js +0 -0
  131. package/dist/ov-ip-pkc-skc.min.js +0 -0
  132. package/dist/ov-ip-pkc.deno.js +0 -0
  133. package/dist/ov-ip-pkc.min.js +0 -0
  134. package/dist/ov-ip.deno.js +0 -0
  135. package/dist/ov-ip.min.js +0 -0
  136. package/dist/ov-is-pkc-skc.deno.js +0 -0
  137. package/dist/ov-is-pkc-skc.min.js +0 -0
  138. package/dist/ov-is-pkc.deno.js +0 -0
  139. package/dist/ov-is-pkc.min.js +0 -0
  140. package/dist/ov-is.deno.js +0 -0
  141. package/dist/ov-is.min.js +0 -0
  142. package/dist/ov-v-pkc-skc.deno.js +0 -0
  143. package/dist/ov-v-pkc-skc.min.js +0 -0
  144. package/dist/ov-v-pkc.deno.js +0 -0
  145. package/dist/ov-v-pkc.min.js +0 -0
  146. package/dist/ov-v.deno.js +0 -0
  147. package/dist/ov-v.min.js +0 -0
  148. package/dist/slh-dsa-sha2-128f.deno.js +0 -0
  149. package/dist/slh-dsa-sha2-128f.min.js +0 -0
  150. package/dist/slh-dsa-sha2-128s.deno.js +0 -0
  151. package/dist/slh-dsa-sha2-128s.min.js +0 -0
  152. package/dist/slh-dsa-sha2-192f.deno.js +0 -0
  153. package/dist/slh-dsa-sha2-192f.min.js +0 -0
  154. package/dist/slh-dsa-sha2-192s.deno.js +0 -0
  155. package/dist/slh-dsa-sha2-192s.min.js +0 -0
  156. package/dist/slh-dsa-sha2-256f.deno.js +0 -0
  157. package/dist/slh-dsa-sha2-256f.min.js +0 -0
  158. package/dist/slh-dsa-sha2-256s.deno.js +0 -0
  159. package/dist/slh-dsa-sha2-256s.min.js +0 -0
  160. package/dist/slh-dsa-shake-128f.deno.js +0 -0
  161. package/dist/slh-dsa-shake-128f.min.js +0 -0
  162. package/dist/slh-dsa-shake-128s.deno.js +0 -0
  163. package/dist/slh-dsa-shake-128s.min.js +0 -0
  164. package/dist/slh-dsa-shake-192f.deno.js +0 -0
  165. package/dist/slh-dsa-shake-192f.min.js +0 -0
  166. package/dist/slh-dsa-shake-192s.deno.js +0 -0
  167. package/dist/slh-dsa-shake-192s.min.js +0 -0
  168. package/dist/slh-dsa-shake-256f.deno.js +0 -0
  169. package/dist/slh-dsa-shake-256f.min.js +0 -0
  170. package/dist/slh-dsa-shake-256s.deno.js +0 -0
  171. package/dist/slh-dsa-shake-256s.min.js +0 -0
  172. package/dist/snova-24-5-4-esk.deno.js +0 -0
  173. package/dist/snova-24-5-4-esk.min.js +0 -0
  174. package/dist/snova-24-5-4-shake-esk.deno.js +0 -0
  175. package/dist/snova-24-5-4-shake-esk.min.js +0 -0
  176. package/dist/snova-24-5-4-shake.deno.js +0 -0
  177. package/dist/snova-24-5-4-shake.min.js +0 -0
  178. package/dist/snova-24-5-4.deno.js +0 -0
  179. package/dist/snova-24-5-4.min.js +0 -0
  180. package/dist/snova-24-5-5.deno.js +0 -0
  181. package/dist/snova-24-5-5.min.js +0 -0
  182. package/dist/snova-25-8-3.deno.js +0 -0
  183. package/dist/snova-25-8-3.min.js +0 -0
  184. package/dist/snova-29-6-5.deno.js +0 -0
  185. package/dist/snova-29-6-5.min.js +0 -0
  186. package/dist/snova-37-17-2.deno.js +0 -0
  187. package/dist/snova-37-17-2.min.js +0 -0
  188. package/dist/snova-37-8-4.deno.js +0 -0
  189. package/dist/snova-37-8-4.min.js +0 -0
  190. package/dist/snova-49-11-3.deno.js +0 -0
  191. package/dist/snova-49-11-3.min.js +0 -0
  192. package/dist/snova-56-25-2.deno.js +0 -0
  193. package/dist/snova-56-25-2.min.js +0 -0
  194. package/dist/snova-60-10-4.deno.js +0 -0
  195. package/dist/snova-60-10-4.min.js +0 -0
  196. package/dist/sntrup761.deno.js +0 -0
  197. package/dist/sntrup761.min.js +0 -0
  198. package/package.json +108 -0
  199. package/src/algorithms/kem/classic-mceliece/classic-mceliece-348864.js +336 -0
  200. package/src/algorithms/kem/classic-mceliece/classic-mceliece-348864f.js +336 -0
  201. package/src/algorithms/kem/classic-mceliece/classic-mceliece-460896.js +336 -0
  202. package/src/algorithms/kem/classic-mceliece/classic-mceliece-460896f.js +336 -0
  203. package/src/algorithms/kem/classic-mceliece/classic-mceliece-6688128.js +336 -0
  204. package/src/algorithms/kem/classic-mceliece/classic-mceliece-6688128f.js +336 -0
  205. package/src/algorithms/kem/classic-mceliece/classic-mceliece-6960119.js +336 -0
  206. package/src/algorithms/kem/classic-mceliece/classic-mceliece-6960119f.js +336 -0
  207. package/src/algorithms/kem/classic-mceliece/classic-mceliece-8192128.js +336 -0
  208. package/src/algorithms/kem/classic-mceliece/classic-mceliece-8192128f.js +336 -0
  209. package/src/algorithms/kem/frodokem/efrodokem-1344-aes.js +366 -0
  210. package/src/algorithms/kem/frodokem/efrodokem-1344-shake.js +366 -0
  211. package/src/algorithms/kem/frodokem/efrodokem-640-aes.js +366 -0
  212. package/src/algorithms/kem/frodokem/efrodokem-640-shake.js +366 -0
  213. package/src/algorithms/kem/frodokem/efrodokem-976-aes.js +366 -0
  214. package/src/algorithms/kem/frodokem/efrodokem-976-shake.js +366 -0
  215. package/src/algorithms/kem/frodokem/frodokem-1344-aes.js +366 -0
  216. package/src/algorithms/kem/frodokem/frodokem-1344-shake.js +366 -0
  217. package/src/algorithms/kem/frodokem/frodokem-640-aes.js +366 -0
  218. package/src/algorithms/kem/frodokem/frodokem-640-shake.js +366 -0
  219. package/src/algorithms/kem/frodokem/frodokem-976-aes.js +366 -0
  220. package/src/algorithms/kem/frodokem/frodokem-976-shake.js +366 -0
  221. package/src/algorithms/kem/hqc/hqc-128.js +366 -0
  222. package/src/algorithms/kem/hqc/hqc-192.js +366 -0
  223. package/src/algorithms/kem/hqc/hqc-256.js +366 -0
  224. package/src/algorithms/kem/kyber/kyber-1024.js +349 -0
  225. package/src/algorithms/kem/kyber/kyber-512.js +347 -0
  226. package/src/algorithms/kem/kyber/kyber-768.js +348 -0
  227. package/src/algorithms/kem/ml-kem/ml-kem-1024.js +345 -0
  228. package/src/algorithms/kem/ml-kem/ml-kem-512.js +345 -0
  229. package/src/algorithms/kem/ml-kem/ml-kem-768.js +344 -0
  230. package/src/algorithms/kem/ntru/ntru-hps-2048-509.js +366 -0
  231. package/src/algorithms/kem/ntru/ntru-hps-2048-677.js +366 -0
  232. package/src/algorithms/kem/ntru/ntru-hps-4096-1229.js +366 -0
  233. package/src/algorithms/kem/ntru/ntru-hps-4096-821.js +366 -0
  234. package/src/algorithms/kem/ntru/ntru-hrss-1373.js +366 -0
  235. package/src/algorithms/kem/ntru/ntru-hrss-701.js +366 -0
  236. package/src/algorithms/kem/ntru/sntrup761.js +367 -0
  237. package/src/algorithms/sig/cross/cross-rsdp-128-balanced.js +391 -0
  238. package/src/algorithms/sig/cross/cross-rsdp-128-fast.js +391 -0
  239. package/src/algorithms/sig/cross/cross-rsdp-128-small.js +391 -0
  240. package/src/algorithms/sig/cross/cross-rsdp-192-balanced.js +391 -0
  241. package/src/algorithms/sig/cross/cross-rsdp-192-fast.js +391 -0
  242. package/src/algorithms/sig/cross/cross-rsdp-192-small.js +391 -0
  243. package/src/algorithms/sig/cross/cross-rsdp-256-balanced.js +391 -0
  244. package/src/algorithms/sig/cross/cross-rsdp-256-fast.js +391 -0
  245. package/src/algorithms/sig/cross/cross-rsdp-256-small.js +391 -0
  246. package/src/algorithms/sig/cross/cross-rsdpg-128-balanced.js +391 -0
  247. package/src/algorithms/sig/cross/cross-rsdpg-128-fast.js +391 -0
  248. package/src/algorithms/sig/cross/cross-rsdpg-128-small.js +391 -0
  249. package/src/algorithms/sig/cross/cross-rsdpg-192-balanced.js +391 -0
  250. package/src/algorithms/sig/cross/cross-rsdpg-192-fast.js +391 -0
  251. package/src/algorithms/sig/cross/cross-rsdpg-192-small.js +391 -0
  252. package/src/algorithms/sig/cross/cross-rsdpg-256-balanced.js +391 -0
  253. package/src/algorithms/sig/cross/cross-rsdpg-256-fast.js +391 -0
  254. package/src/algorithms/sig/cross/cross-rsdpg-256-small.js +391 -0
  255. package/src/algorithms/sig/falcon/falcon-1024.js +378 -0
  256. package/src/algorithms/sig/falcon/falcon-512.js +379 -0
  257. package/src/algorithms/sig/falcon/falcon-padded-1024.js +380 -0
  258. package/src/algorithms/sig/falcon/falcon-padded-512.js +380 -0
  259. package/src/algorithms/sig/mayo/mayo-1.js +390 -0
  260. package/src/algorithms/sig/mayo/mayo-2.js +390 -0
  261. package/src/algorithms/sig/mayo/mayo-3.js +390 -0
  262. package/src/algorithms/sig/mayo/mayo-5.js +390 -0
  263. package/src/algorithms/sig/ml-dsa/ml-dsa-44.js +338 -0
  264. package/src/algorithms/sig/ml-dsa/ml-dsa-65.js +338 -0
  265. package/src/algorithms/sig/ml-dsa/ml-dsa-87.js +338 -0
  266. package/src/algorithms/sig/slh-dsa/slh-dsa-sha2-128f.js +367 -0
  267. package/src/algorithms/sig/slh-dsa/slh-dsa-sha2-128s.js +367 -0
  268. package/src/algorithms/sig/slh-dsa/slh-dsa-sha2-192f.js +367 -0
  269. package/src/algorithms/sig/slh-dsa/slh-dsa-sha2-192s.js +367 -0
  270. package/src/algorithms/sig/slh-dsa/slh-dsa-sha2-256f.js +367 -0
  271. package/src/algorithms/sig/slh-dsa/slh-dsa-sha2-256s.js +367 -0
  272. package/src/algorithms/sig/slh-dsa/slh-dsa-shake-128f.js +367 -0
  273. package/src/algorithms/sig/slh-dsa/slh-dsa-shake-128s.js +367 -0
  274. package/src/algorithms/sig/slh-dsa/slh-dsa-shake-192f.js +367 -0
  275. package/src/algorithms/sig/slh-dsa/slh-dsa-shake-192s.js +367 -0
  276. package/src/algorithms/sig/slh-dsa/slh-dsa-shake-256f.js +367 -0
  277. package/src/algorithms/sig/slh-dsa/slh-dsa-shake-256s.js +367 -0
  278. package/src/algorithms/sig/snova/snova-24-5-4-esk.js +391 -0
  279. package/src/algorithms/sig/snova/snova-24-5-4-shake-esk.js +391 -0
  280. package/src/algorithms/sig/snova/snova-24-5-4-shake.js +391 -0
  281. package/src/algorithms/sig/snova/snova-24-5-4.js +391 -0
  282. package/src/algorithms/sig/snova/snova-24-5-5.js +391 -0
  283. package/src/algorithms/sig/snova/snova-25-8-3.js +391 -0
  284. package/src/algorithms/sig/snova/snova-29-6-5.js +391 -0
  285. package/src/algorithms/sig/snova/snova-37-17-2.js +391 -0
  286. package/src/algorithms/sig/snova/snova-37-8-4.js +391 -0
  287. package/src/algorithms/sig/snova/snova-49-11-3.js +391 -0
  288. package/src/algorithms/sig/snova/snova-56-25-2.js +391 -0
  289. package/src/algorithms/sig/snova/snova-60-10-4.js +391 -0
  290. package/src/algorithms/sig/uov/ov-iii-pkc-skc.js +390 -0
  291. package/src/algorithms/sig/uov/ov-iii-pkc.js +390 -0
  292. package/src/algorithms/sig/uov/ov-iii.js +390 -0
  293. package/src/algorithms/sig/uov/ov-ip-pkc-skc.js +390 -0
  294. package/src/algorithms/sig/uov/ov-ip-pkc.js +390 -0
  295. package/src/algorithms/sig/uov/ov-ip.js +390 -0
  296. package/src/algorithms/sig/uov/ov-is-pkc-skc.js +390 -0
  297. package/src/algorithms/sig/uov/ov-is-pkc.js +390 -0
  298. package/src/algorithms/sig/uov/ov-is.js +390 -0
  299. package/src/algorithms/sig/uov/ov-v-pkc-skc.js +390 -0
  300. package/src/algorithms/sig/uov/ov-v-pkc.js +390 -0
  301. package/src/algorithms/sig/uov/ov-v.js +390 -0
  302. package/src/cli/algorithms.js +254 -0
  303. package/src/cli/commands/info.js +35 -0
  304. package/src/cli/commands/kem.js +91 -0
  305. package/src/cli/commands/list.js +30 -0
  306. package/src/cli/commands/sig.js +98 -0
  307. package/src/cli/index.js +86 -0
  308. package/src/cli/io.js +147 -0
  309. package/src/cli/parser.js +64 -0
  310. package/src/core/errors.js +75 -0
  311. package/src/core/validation.js +28 -0
  312. package/src/index.js +164 -0
  313. package/src/kem.js +60 -0
  314. package/src/sig.js +87 -0
  315. package/src/types/algorithms.d.ts +1543 -0
  316. package/src/types/errors.d.ts +60 -0
  317. package/src/types/index.d.ts +9 -0
package/package.json ADDED
@@ -0,0 +1,108 @@
1
+ {
2
+ "name": "@oqs/liboqs-js",
3
+ "version": "0.15.0",
4
+ "description": "Post-quantum cryptography for Node.js and browsers via WebAssembly bindings to liboqs",
5
+ "type": "module",
6
+ "main": "src/index.js",
7
+ "types": "src/types/index.d.ts",
8
+ "sideEffects": false,
9
+ "bin": {
10
+ "liboqs": "./bin/cli.js"
11
+ },
12
+ "exports": {
13
+ ".": {
14
+ "types": "./src/types/index.d.ts",
15
+ "import": "./src/index.js"
16
+ },
17
+ "./kem": {
18
+ "types": "./src/types/index.d.ts",
19
+ "import": "./src/kem.js"
20
+ },
21
+ "./sig": {
22
+ "types": "./src/types/index.d.ts",
23
+ "import": "./src/sig.js"
24
+ },
25
+ "./errors": {
26
+ "types": "./src/types/errors.d.ts",
27
+ "import": "./src/core/errors.js"
28
+ }
29
+ },
30
+ "files": [
31
+ "src/",
32
+ "bin/",
33
+ "dist/"
34
+ ],
35
+ "scripts": {
36
+ "build": "./build.sh",
37
+ "build:single": "./build.sh",
38
+ "docs": "typedoc",
39
+ "typecheck": "tsc --noEmit",
40
+ "test": "bun run typecheck && bun run test:node && bun run test:browser",
41
+ "test:node": "vitest run",
42
+ "test:browser": "TEST_ENV=browser vitest run",
43
+ "test:watch": "vitest",
44
+ "test:cli": "vitest run tests/cli.test.ts",
45
+ "test:kem": "vitest run tests/kem.test.ts",
46
+ "test:sig": "vitest run tests/sig.test.ts",
47
+ "clean": "./build.sh --clean"
48
+ },
49
+ "keywords": [
50
+ "post-quantum",
51
+ "cryptography",
52
+ "pqc",
53
+ "liboqs",
54
+ "wasm",
55
+ "webassembly",
56
+ "quantum-resistant",
57
+ "nist",
58
+ "kem",
59
+ "signature",
60
+ "digital-signature",
61
+ "key-encapsulation",
62
+ "ml-kem",
63
+ "ml-dsa",
64
+ "kyber",
65
+ "dilithium",
66
+ "falcon",
67
+ "slh-dsa",
68
+ "classic-mceliece",
69
+ "frodokem",
70
+ "ntru",
71
+ "hqc",
72
+ "cross",
73
+ "mayo",
74
+ "uov",
75
+ "snova",
76
+ "lattice-based",
77
+ "code-based",
78
+ "hash-based"
79
+ ],
80
+ "author": {
81
+ "name": "Open Quantum Safe",
82
+ "url": "https://github.com/open-quantum-safe"
83
+ },
84
+ "license": "MIT",
85
+ "repository": {
86
+ "type": "git",
87
+ "url": "git+https://github.com/open-quantum-safe/liboqs-js.git"
88
+ },
89
+ "bugs": {
90
+ "url": "https://github.com/open-quantum-safe/liboqs-js/issues"
91
+ },
92
+ "homepage": "https://open-quantum-safe.github.io/liboqs-js",
93
+ "publishConfig": {
94
+ "access": "public",
95
+ "registry": "https://registry.npmjs.org/"
96
+ },
97
+ "engines": {
98
+ "node": ">=22.0.0"
99
+ },
100
+ "devDependencies": {
101
+ "@types/node": "^22.0.0",
102
+ "@vitest/browser": "^3.2.4",
103
+ "playwright": "^1.55.1",
104
+ "typedoc": "^0.28.13",
105
+ "typescript": "^5.9.3",
106
+ "vitest": "^3.2.4"
107
+ }
108
+ }
@@ -0,0 +1,336 @@
1
+ /**
2
+ * @fileoverview Classic-McEliece-348864 KEM algorithm implementation
3
+ * @module algorithms/kem/classic-mceliece/classic-mceliece-348864
4
+ * @description
5
+ * Classic-McEliece-348864 is a code-based key encapsulation mechanism providing NIST security level 1.
6
+ * It is based on the McEliece cryptosystem using binary Goppa codes.
7
+ *
8
+ * Key features:
9
+ * - Code-based cryptography (Goppa codes)
10
+ * - Security Level 1 (128-bit classical, quantum-resistant)
11
+ * - Extremely conservative security margin
12
+ * - IND-CCA2 security
13
+ * - Very large public keys, small ciphertexts
14
+ *
15
+ * @see {@link https://classic.mceliece.org/} - Classic McEliece specification
16
+ */
17
+
18
+ import { LibOQSError, LibOQSInitError, LibOQSOperationError, LibOQSValidationError } from '../../../core/errors.js';
19
+ import { isUint8Array } from '../../../core/validation.js';
20
+
21
+ // Dynamic module loading for cross-runtime compatibility
22
+ async function loadModule() {
23
+ const isDeno = typeof Deno !== 'undefined';
24
+ const modulePath = isDeno
25
+ ? '../../../../dist/classic-mceliece-348864.deno.js'
26
+ : '../../../../dist/classic-mceliece-348864.min.js';
27
+
28
+ const module = await import(modulePath);
29
+ return module.default;
30
+ }
31
+
32
+ /**
33
+ * CLASSIC-MCELIECE-348864-INFO algorithm constants and metadata
34
+ * @type {{readonly name: 'Classic-McEliece-348864', readonly identifier: 'Classic-McEliece-348864', readonly type: 'kem', readonly securityLevel: 1, readonly standardized: false, readonly description: string, readonly keySize: {readonly publicKey: 261120, readonly secretKey: 6492, readonly ciphertext: 96, readonly sharedSecret: 32}}}
35
+ */
36
+ export const CLASSIC_MCELIECE_348864_INFO = {
37
+ name: 'Classic-McEliece-348864',
38
+ identifier: 'Classic-McEliece-348864',
39
+ type: 'kem',
40
+ securityLevel: 1,
41
+ standardized: false,
42
+ description: 'Classic McEliece 348864 code-based KEM (NIST Level 1, 128-bit quantum security)',
43
+ keySize: {
44
+ publicKey: 261120,
45
+ secretKey: 6492,
46
+ ciphertext: 96,
47
+ sharedSecret: 32
48
+ }
49
+ };
50
+
51
+ /**
52
+ * Load and initialize Classic-McEliece-348864 module
53
+ * @returns {Promise<ClassicMcEliece348864>} Initialized Classic-McEliece-348864 instance
54
+ * @throws {LibOQSInitError} If initialization fails
55
+ * @example
56
+ * import { createClassicMcEliece348864 } from '@oqs/liboqs-js';
57
+ * const kem = await createClassicMcEliece348864();
58
+ */
59
+ export async function createClassicMcEliece348864() {
60
+ const moduleFactory = await loadModule();
61
+ const wasmModule = await moduleFactory();
62
+ wasmModule._OQS_init();
63
+
64
+ const algoName = CLASSIC_MCELIECE_348864_INFO.identifier;
65
+ const nameLen = wasmModule.lengthBytesUTF8(algoName);
66
+ const namePtr = wasmModule._malloc(nameLen + 1);
67
+ wasmModule.stringToUTF8(algoName, namePtr, nameLen + 1);
68
+
69
+ const kemPtr = wasmModule._OQS_KEM_new(namePtr);
70
+ wasmModule._free(namePtr);
71
+
72
+ if (!kemPtr) {
73
+ throw new LibOQSInitError('Classic-McEliece-348864', 'Failed to create KEM instance');
74
+ }
75
+
76
+ return new ClassicMcEliece348864(wasmModule, kemPtr);
77
+ }
78
+
79
+ /**
80
+ * Classic-McEliece-348864 wrapper class providing high-level KEM operations
81
+ *
82
+ * This class wraps the low-level WASM module to provide a user-friendly
83
+ * interface for Classic-McEliece-348864 operations with automatic memory management
84
+ * and input validation.
85
+ *
86
+ * @class ClassicMcEliece348864
87
+ * @example
88
+ * import { createClassicMcEliece348864 } from '@oqs/liboqs-js';
89
+ *
90
+ * const kem = await createClassicMcEliece348864();
91
+ * const { publicKey, secretKey } = kem.generateKeyPair();
92
+ * const { ciphertext, sharedSecret } = kem.encapsulate(publicKey);
93
+ * kem.destroy();
94
+ */
95
+ export class ClassicMcEliece348864 {
96
+ /** @type {Object} @private */
97
+ #wasmModule;
98
+ /** @type {number} @private */
99
+ #kemPtr;
100
+ /** @type {boolean} @private */
101
+ #destroyed = false;
102
+
103
+ /**
104
+ * @param {Object} wasmModule - Emscripten WASM module
105
+ * @param {number} kemPtr - Pointer to KEM instance
106
+ * @private
107
+ */
108
+ constructor(wasmModule, kemPtr) {
109
+ this.#wasmModule = wasmModule;
110
+ this.#kemPtr = kemPtr;
111
+ }
112
+
113
+ /**
114
+ * Generate a new keypair for Classic-McEliece-348864
115
+ *
116
+ * Generates a public/private keypair using the algorithm's internal
117
+ * random number generator. The secret key must be kept confidential.
118
+ *
119
+ * @returns {publicKey: Uint8Array, secretKey: Uint8Array} Generated keypair
120
+ * @throws {LibOQSOperationError} If keypair generation fails
121
+ * @throws {LibOQSError} If instance has been destroyed
122
+ * @example
123
+ * const { publicKey, secretKey } = kem.generateKeyPair();
124
+ * // publicKey: 261120 bytes
125
+ * // secretKey: 6492 bytes (keep confidential!)
126
+ */
127
+ generateKeyPair() {
128
+ this.#checkDestroyed();
129
+
130
+ const publicKeyPtr = this.#wasmModule._malloc(CLASSIC_MCELIECE_348864_INFO.keySize.publicKey);
131
+ const secretKeyPtr = this.#wasmModule._malloc(CLASSIC_MCELIECE_348864_INFO.keySize.secretKey);
132
+
133
+ try {
134
+ const result = this.#wasmModule._OQS_KEM_keypair(this.#kemPtr, publicKeyPtr, secretKeyPtr);
135
+
136
+ if (result !== 0) {
137
+ throw new LibOQSOperationError('keypair', 'Classic-McEliece-348864', `Error code: ${result}`);
138
+ }
139
+
140
+ const publicKey = new Uint8Array(CLASSIC_MCELIECE_348864_INFO.keySize.publicKey);
141
+ const secretKey = new Uint8Array(CLASSIC_MCELIECE_348864_INFO.keySize.secretKey);
142
+
143
+ publicKey.set(this.#wasmModule.HEAPU8.subarray(publicKeyPtr, publicKeyPtr + CLASSIC_MCELIECE_348864_INFO.keySize.publicKey));
144
+ secretKey.set(this.#wasmModule.HEAPU8.subarray(secretKeyPtr, secretKeyPtr + CLASSIC_MCELIECE_348864_INFO.keySize.secretKey));
145
+
146
+ return { publicKey, secretKey };
147
+
148
+ } finally {
149
+ this.#wasmModule._free(publicKeyPtr);
150
+ this.#wasmModule._free(secretKeyPtr);
151
+ }
152
+ }
153
+
154
+ /**
155
+ * Encapsulate a shared secret using a public key
156
+ *
157
+ * Generates a random shared secret and encapsulates it using the
158
+ * provided public key. The shared secret can be used for symmetric
159
+ * encryption.
160
+ *
161
+ * @param {Uint8Array} publicKey - Recipient's public key (261120 bytes)
162
+ * @returns {ciphertext: Uint8Array, sharedSecret: Uint8Array} Encapsulation result
163
+ * @throws {LibOQSValidationError} If public key is invalid
164
+ * @throws {LibOQSOperationError} If encapsulation fails
165
+ * @throws {LibOQSError} If instance has been destroyed
166
+ * @example
167
+ * const { ciphertext, sharedSecret } = kem.encapsulate(recipientPublicKey);
168
+ * // ciphertext: 96 bytes (send to recipient)
169
+ * // sharedSecret: 32 bytes (use for symmetric encryption)
170
+ */
171
+ encapsulate(publicKey) {
172
+ this.#checkDestroyed();
173
+ this.#validatePublicKey(publicKey);
174
+
175
+ const publicKeyPtr = this.#wasmModule._malloc(CLASSIC_MCELIECE_348864_INFO.keySize.publicKey);
176
+ const ciphertextPtr = this.#wasmModule._malloc(CLASSIC_MCELIECE_348864_INFO.keySize.ciphertext);
177
+ const sharedSecretPtr = this.#wasmModule._malloc(CLASSIC_MCELIECE_348864_INFO.keySize.sharedSecret);
178
+
179
+ try {
180
+ this.#wasmModule.HEAPU8.set(publicKey, publicKeyPtr);
181
+
182
+ const result = this.#wasmModule._OQS_KEM_encaps(
183
+ this.#kemPtr,
184
+ ciphertextPtr,
185
+ sharedSecretPtr,
186
+ publicKeyPtr
187
+ );
188
+
189
+ if (result !== 0) {
190
+ throw new LibOQSOperationError('encaps', 'Classic-McEliece-348864', `Error code: ${result}`);
191
+ }
192
+
193
+ const ciphertext = new Uint8Array(CLASSIC_MCELIECE_348864_INFO.keySize.ciphertext);
194
+ const sharedSecret = new Uint8Array(CLASSIC_MCELIECE_348864_INFO.keySize.sharedSecret);
195
+
196
+ ciphertext.set(this.#wasmModule.HEAPU8.subarray(ciphertextPtr, ciphertextPtr + CLASSIC_MCELIECE_348864_INFO.keySize.ciphertext));
197
+ sharedSecret.set(this.#wasmModule.HEAPU8.subarray(sharedSecretPtr, sharedSecretPtr + CLASSIC_MCELIECE_348864_INFO.keySize.sharedSecret));
198
+
199
+ return { ciphertext, sharedSecret };
200
+
201
+ } finally {
202
+ this.#wasmModule._free(publicKeyPtr);
203
+ this.#wasmModule._free(ciphertextPtr);
204
+ this.#wasmModule._free(sharedSecretPtr);
205
+ }
206
+ }
207
+
208
+ /**
209
+ * Decapsulate a shared secret using a secret key
210
+ *
211
+ * Recovers the shared secret from a ciphertext using the secret key.
212
+ * The recovered shared secret will match the one generated during
213
+ * encapsulation.
214
+ *
215
+ * @param {Uint8Array} ciphertext - Ciphertext received (96 bytes)
216
+ * @param {Uint8Array} secretKey - Recipient's secret key (6492 bytes)
217
+ * @returns {Uint8Array} Recovered shared secret (32 bytes)
218
+ * @throws {LibOQSValidationError} If inputs are invalid
219
+ * @throws {LibOQSOperationError} If decapsulation fails
220
+ * @throws {LibOQSError} If instance has been destroyed
221
+ * @example
222
+ * const sharedSecret = kem.decapsulate(ciphertext, mySecretKey);
223
+ * // sharedSecret: 32 bytes (matches sender's shared secret)
224
+ */
225
+ decapsulate(ciphertext, secretKey) {
226
+ this.#checkDestroyed();
227
+ this.#validateCiphertext(ciphertext);
228
+ this.#validateSecretKey(secretKey);
229
+
230
+ const ciphertextPtr = this.#wasmModule._malloc(CLASSIC_MCELIECE_348864_INFO.keySize.ciphertext);
231
+ const secretKeyPtr = this.#wasmModule._malloc(CLASSIC_MCELIECE_348864_INFO.keySize.secretKey);
232
+ const sharedSecretPtr = this.#wasmModule._malloc(CLASSIC_MCELIECE_348864_INFO.keySize.sharedSecret);
233
+
234
+ try {
235
+ this.#wasmModule.HEAPU8.set(ciphertext, ciphertextPtr);
236
+ this.#wasmModule.HEAPU8.set(secretKey, secretKeyPtr);
237
+
238
+ const result = this.#wasmModule._OQS_KEM_decaps(
239
+ this.#kemPtr,
240
+ sharedSecretPtr,
241
+ ciphertextPtr,
242
+ secretKeyPtr
243
+ );
244
+
245
+ if (result !== 0) {
246
+ throw new LibOQSOperationError('decaps', 'Classic-McEliece-348864', `Error code: ${result}`);
247
+ }
248
+
249
+ const sharedSecret = new Uint8Array(CLASSIC_MCELIECE_348864_INFO.keySize.sharedSecret);
250
+ sharedSecret.set(this.#wasmModule.HEAPU8.subarray(sharedSecretPtr, sharedSecretPtr + CLASSIC_MCELIECE_348864_INFO.keySize.sharedSecret));
251
+
252
+ return sharedSecret;
253
+
254
+ } finally {
255
+ this.#wasmModule._free(ciphertextPtr);
256
+ this.#wasmModule._free(secretKeyPtr);
257
+ this.#wasmModule._free(sharedSecretPtr);
258
+ }
259
+ }
260
+
261
+ /**
262
+ * Clean up resources and free WASM memory
263
+ *
264
+ * This method should be called when you're done using the instance
265
+ * to free WASM memory. After calling destroy(), the instance cannot
266
+ * be used for further operations.
267
+ *
268
+ * @example
269
+ * const kem = await createClassicMcEliece348864();
270
+ * // ... use kem ...
271
+ * kem.destroy();
272
+ */
273
+ destroy() {
274
+ if (!this.#destroyed) {
275
+ if (this.#kemPtr) {
276
+ this.#wasmModule._OQS_KEM_free(this.#kemPtr);
277
+ this.#kemPtr = null;
278
+ }
279
+ this.#destroyed = true;
280
+ }
281
+ }
282
+
283
+ /**
284
+ * Enables automatic cleanup via `using` declarations
285
+ * @example
286
+ * using instance = await create...();
287
+ * // automatically cleaned up at end of scope
288
+ */
289
+ [Symbol.dispose]() {
290
+ this.destroy();
291
+ }
292
+
293
+ /**
294
+ * Get algorithm information and constants
295
+ * @returns {typeof CLASSIC_MCELIECE_348864_INFO} Algorithm metadata (copy of CLASSIC_MCELIECE_348864_INFO)
296
+ * @example
297
+ * const info = kem.info;
298
+ * console.log(info.keySize.publicKey); // 261120
299
+ */
300
+ get info() {
301
+ return CLASSIC_MCELIECE_348864_INFO;
302
+ }
303
+
304
+ #checkDestroyed() {
305
+ if (this.#destroyed) {
306
+ throw new LibOQSError('Instance has been destroyed', 'Classic-McEliece-348864');
307
+ }
308
+ }
309
+
310
+ #validatePublicKey(publicKey) {
311
+ if (!isUint8Array(publicKey) || publicKey.length !== CLASSIC_MCELIECE_348864_INFO.keySize.publicKey) {
312
+ throw new LibOQSValidationError(
313
+ `Invalid public key: expected ${CLASSIC_MCELIECE_348864_INFO.keySize.publicKey} bytes, got ${publicKey?.length ?? 'null'}`,
314
+ 'Classic-McEliece-348864'
315
+ );
316
+ }
317
+ }
318
+
319
+ #validateSecretKey(secretKey) {
320
+ if (!isUint8Array(secretKey) || secretKey.length !== CLASSIC_MCELIECE_348864_INFO.keySize.secretKey) {
321
+ throw new LibOQSValidationError(
322
+ `Invalid secret key: expected ${CLASSIC_MCELIECE_348864_INFO.keySize.secretKey} bytes, got ${secretKey?.length ?? 'null'}`,
323
+ 'Classic-McEliece-348864'
324
+ );
325
+ }
326
+ }
327
+
328
+ #validateCiphertext(ciphertext) {
329
+ if (!isUint8Array(ciphertext) || ciphertext.length !== CLASSIC_MCELIECE_348864_INFO.keySize.ciphertext) {
330
+ throw new LibOQSValidationError(
331
+ `Invalid ciphertext: expected ${CLASSIC_MCELIECE_348864_INFO.keySize.ciphertext} bytes, got ${ciphertext?.length ?? 'null'}`,
332
+ 'Classic-McEliece-348864'
333
+ );
334
+ }
335
+ }
336
+ }