ts-mls 1.0.2

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 (583) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +196 -0
  3. package/dist/src/IncomingMessageAction.d.ts +10 -0
  4. package/dist/src/IncomingMessageAction.js +2 -0
  5. package/dist/src/IncomingMessageAction.js.map +1 -0
  6. package/dist/src/authenticatedContent.d.ts +32 -0
  7. package/dist/src/authenticatedContent.js +26 -0
  8. package/dist/src/authenticatedContent.js.map +1 -0
  9. package/dist/src/authenticationService.d.ts +7 -0
  10. package/dist/src/authenticationService.js +6 -0
  11. package/dist/src/authenticationService.js.map +1 -0
  12. package/dist/src/capabilities.d.ts +14 -0
  13. package/dist/src/capabilities.js +28 -0
  14. package/dist/src/capabilities.js.map +1 -0
  15. package/dist/src/clientConfig.d.ts +21 -0
  16. package/dist/src/clientConfig.js +13 -0
  17. package/dist/src/clientConfig.js.map +1 -0
  18. package/dist/src/clientState.d.ts +122 -0
  19. package/dist/src/clientState.js +547 -0
  20. package/dist/src/clientState.js.map +1 -0
  21. package/dist/src/codec/number.d.ts +10 -0
  22. package/dist/src/codec/number.js +56 -0
  23. package/dist/src/codec/number.js.map +1 -0
  24. package/dist/src/codec/optional.d.ts +4 -0
  25. package/dist/src/codec/optional.js +20 -0
  26. package/dist/src/codec/optional.js.map +1 -0
  27. package/dist/src/codec/tlsDecoder.d.ts +14 -0
  28. package/dist/src/codec/tlsDecoder.js +78 -0
  29. package/dist/src/codec/tlsDecoder.js.map +1 -0
  30. package/dist/src/codec/tlsEncoder.d.ts +9 -0
  31. package/dist/src/codec/tlsEncoder.js +23 -0
  32. package/dist/src/codec/tlsEncoder.js.map +1 -0
  33. package/dist/src/codec/variableLength.d.ts +11 -0
  34. package/dist/src/codec/variableLength.js +95 -0
  35. package/dist/src/codec/variableLength.js.map +1 -0
  36. package/dist/src/commit.d.ts +10 -0
  37. package/dist/src/commit.js +9 -0
  38. package/dist/src/commit.js.map +1 -0
  39. package/dist/src/contentType.d.ts +12 -0
  40. package/dist/src/contentType.js +12 -0
  41. package/dist/src/contentType.js.map +1 -0
  42. package/dist/src/createCommit.d.ts +32 -0
  43. package/dist/src/createCommit.js +250 -0
  44. package/dist/src/createCommit.js.map +1 -0
  45. package/dist/src/createMessage.d.ts +24 -0
  46. package/dist/src/createMessage.js +32 -0
  47. package/dist/src/createMessage.js.map +1 -0
  48. package/dist/src/credential.d.ts +21 -0
  49. package/dist/src/credential.js +31 -0
  50. package/dist/src/credential.js.map +1 -0
  51. package/dist/src/credentialType.d.ts +11 -0
  52. package/dist/src/credentialType.js +11 -0
  53. package/dist/src/credentialType.js.map +1 -0
  54. package/dist/src/crypto/aead.d.ts +8 -0
  55. package/dist/src/crypto/aead.js +69 -0
  56. package/dist/src/crypto/aead.js.map +1 -0
  57. package/dist/src/crypto/ciphersuite.d.ts +51 -0
  58. package/dist/src/crypto/ciphersuite.js +245 -0
  59. package/dist/src/crypto/ciphersuite.js.map +1 -0
  60. package/dist/src/crypto/hash.d.ts +8 -0
  61. package/dist/src/crypto/hash.js +32 -0
  62. package/dist/src/crypto/hash.js.map +1 -0
  63. package/dist/src/crypto/hpke.d.ts +51 -0
  64. package/dist/src/crypto/hpke.js +109 -0
  65. package/dist/src/crypto/hpke.js.map +1 -0
  66. package/dist/src/crypto/kdf.d.ts +12 -0
  67. package/dist/src/crypto/kdf.js +42 -0
  68. package/dist/src/crypto/kdf.js.map +1 -0
  69. package/dist/src/crypto/kem.d.ts +3 -0
  70. package/dist/src/crypto/kem.js +49 -0
  71. package/dist/src/crypto/kem.js.map +1 -0
  72. package/dist/src/crypto/rng.d.ts +4 -0
  73. package/dist/src/crypto/rng.js +6 -0
  74. package/dist/src/crypto/rng.js.map +1 -0
  75. package/dist/src/crypto/signature.d.ts +12 -0
  76. package/dist/src/crypto/signature.js +127 -0
  77. package/dist/src/crypto/signature.js.map +1 -0
  78. package/dist/src/customCredential.d.ts +2 -0
  79. package/dist/src/customCredential.js +11 -0
  80. package/dist/src/customCredential.js.map +1 -0
  81. package/dist/src/defaultCapabilities.d.ts +2 -0
  82. package/dist/src/defaultCapabilities.js +12 -0
  83. package/dist/src/defaultCapabilities.js.map +1 -0
  84. package/dist/src/defaultExtensionType.d.ts +13 -0
  85. package/dist/src/defaultExtensionType.js +14 -0
  86. package/dist/src/defaultExtensionType.js.map +1 -0
  87. package/dist/src/defaultProposalType.d.ts +15 -0
  88. package/dist/src/defaultProposalType.js +16 -0
  89. package/dist/src/defaultProposalType.js.map +1 -0
  90. package/dist/src/extension.d.ts +18 -0
  91. package/dist/src/extension.js +30 -0
  92. package/dist/src/extension.js.map +1 -0
  93. package/dist/src/externalProposal.d.ts +7 -0
  94. package/dist/src/externalProposal.js +40 -0
  95. package/dist/src/externalProposal.js.map +1 -0
  96. package/dist/src/externalSender.d.ts +9 -0
  97. package/dist/src/externalSender.js +7 -0
  98. package/dist/src/externalSender.js.map +1 -0
  99. package/dist/src/framedContent.d.ts +113 -0
  100. package/dist/src/framedContent.js +131 -0
  101. package/dist/src/framedContent.js.map +1 -0
  102. package/dist/src/grease.d.ts +16 -0
  103. package/dist/src/grease.js +29 -0
  104. package/dist/src/grease.js.map +1 -0
  105. package/dist/src/groupContext.d.ts +19 -0
  106. package/dist/src/groupContext.js +44 -0
  107. package/dist/src/groupContext.js.map +1 -0
  108. package/dist/src/groupInfo.d.ts +26 -0
  109. package/dist/src/groupInfo.js +47 -0
  110. package/dist/src/groupInfo.js.map +1 -0
  111. package/dist/src/groupSecrets.d.ts +10 -0
  112. package/dist/src/groupSecrets.js +8 -0
  113. package/dist/src/groupSecrets.js.map +1 -0
  114. package/dist/src/hpkeCiphertext.d.ts +8 -0
  115. package/dist/src/hpkeCiphertext.js +6 -0
  116. package/dist/src/hpkeCiphertext.js.map +1 -0
  117. package/dist/src/index.d.ts +32 -0
  118. package/dist/src/index.js +24 -0
  119. package/dist/src/index.js.map +1 -0
  120. package/dist/src/keyPackage.d.ts +38 -0
  121. package/dist/src/keyPackage.js +72 -0
  122. package/dist/src/keyPackage.js.map +1 -0
  123. package/dist/src/keyPackageEqualityConfig.d.ts +7 -0
  124. package/dist/src/keyPackageEqualityConfig.js +10 -0
  125. package/dist/src/keyPackageEqualityConfig.js.map +1 -0
  126. package/dist/src/keyRetentionConfig.d.ts +6 -0
  127. package/dist/src/keyRetentionConfig.js +6 -0
  128. package/dist/src/keyRetentionConfig.js.map +1 -0
  129. package/dist/src/keySchedule.d.ts +24 -0
  130. package/dist/src/keySchedule.js +43 -0
  131. package/dist/src/keySchedule.js.map +1 -0
  132. package/dist/src/leafNode.d.ts +78 -0
  133. package/dist/src/leafNode.js +87 -0
  134. package/dist/src/leafNode.js.map +1 -0
  135. package/dist/src/leafNodeSource.d.ts +12 -0
  136. package/dist/src/leafNodeSource.js +12 -0
  137. package/dist/src/leafNodeSource.js.map +1 -0
  138. package/dist/src/lifetime.d.ts +9 -0
  139. package/dist/src/lifetime.js +13 -0
  140. package/dist/src/lifetime.js.map +1 -0
  141. package/dist/src/lifetimeConfig.d.ts +5 -0
  142. package/dist/src/lifetimeConfig.js +5 -0
  143. package/dist/src/lifetimeConfig.js.map +1 -0
  144. package/dist/src/message.d.ts +42 -0
  145. package/dist/src/message.js +45 -0
  146. package/dist/src/message.js.map +1 -0
  147. package/dist/src/messageProtection.d.ts +36 -0
  148. package/dist/src/messageProtection.js +128 -0
  149. package/dist/src/messageProtection.js.map +1 -0
  150. package/dist/src/messageProtectionPublic.d.ts +17 -0
  151. package/dist/src/messageProtectionPublic.js +99 -0
  152. package/dist/src/messageProtectionPublic.js.map +1 -0
  153. package/dist/src/mlsError.d.ts +24 -0
  154. package/dist/src/mlsError.js +49 -0
  155. package/dist/src/mlsError.js.map +1 -0
  156. package/dist/src/nodeType.d.ts +11 -0
  157. package/dist/src/nodeType.js +11 -0
  158. package/dist/src/nodeType.js.map +1 -0
  159. package/dist/src/paddingConfig.d.ts +9 -0
  160. package/dist/src/paddingConfig.js +8 -0
  161. package/dist/src/paddingConfig.js.map +1 -0
  162. package/dist/src/parentHash.d.ts +16 -0
  163. package/dist/src/parentHash.js +103 -0
  164. package/dist/src/parentHash.js.map +1 -0
  165. package/dist/src/parentNode.d.ts +9 -0
  166. package/dist/src/parentNode.js +11 -0
  167. package/dist/src/parentNode.js.map +1 -0
  168. package/dist/src/pathSecrets.d.ts +10 -0
  169. package/dist/src/pathSecrets.js +31 -0
  170. package/dist/src/pathSecrets.js.map +1 -0
  171. package/dist/src/presharedkey.d.ts +51 -0
  172. package/dist/src/presharedkey.js +59 -0
  173. package/dist/src/presharedkey.js.map +1 -0
  174. package/dist/src/privateKeyPath.d.ts +12 -0
  175. package/dist/src/privateKeyPath.js +21 -0
  176. package/dist/src/privateKeyPath.js.map +1 -0
  177. package/dist/src/privateMessage.d.ts +41 -0
  178. package/dist/src/privateMessage.js +114 -0
  179. package/dist/src/privateMessage.js.map +1 -0
  180. package/dist/src/processMessages.d.ts +26 -0
  181. package/dist/src/processMessages.js +196 -0
  182. package/dist/src/processMessages.js.map +1 -0
  183. package/dist/src/proposal.d.ts +97 -0
  184. package/dist/src/proposal.js +91 -0
  185. package/dist/src/proposal.js.map +1 -0
  186. package/dist/src/proposalOrRefType.d.ts +25 -0
  187. package/dist/src/proposalOrRefType.js +31 -0
  188. package/dist/src/proposalOrRefType.js.map +1 -0
  189. package/dist/src/protocolVersion.d.ts +9 -0
  190. package/dist/src/protocolVersion.js +10 -0
  191. package/dist/src/protocolVersion.js.map +1 -0
  192. package/dist/src/pskIndex.d.ts +7 -0
  193. package/dist/src/pskIndex.js +18 -0
  194. package/dist/src/pskIndex.js.map +1 -0
  195. package/dist/src/publicMessage.d.ts +29 -0
  196. package/dist/src/publicMessage.js +71 -0
  197. package/dist/src/publicMessage.js.map +1 -0
  198. package/dist/src/ratchetTree.d.ts +46 -0
  199. package/dist/src/ratchetTree.js +254 -0
  200. package/dist/src/ratchetTree.js.map +1 -0
  201. package/dist/src/requiredCapabilities.d.ts +10 -0
  202. package/dist/src/requiredCapabilities.js +8 -0
  203. package/dist/src/requiredCapabilities.js.map +1 -0
  204. package/dist/src/resumption.d.ts +18 -0
  205. package/dist/src/resumption.js +74 -0
  206. package/dist/src/resumption.js.map +1 -0
  207. package/dist/src/secretTree.d.ts +29 -0
  208. package/dist/src/secretTree.js +137 -0
  209. package/dist/src/secretTree.js.map +1 -0
  210. package/dist/src/sender.d.ts +56 -0
  211. package/dist/src/sender.js +81 -0
  212. package/dist/src/sender.js.map +1 -0
  213. package/dist/src/transcriptHash.d.ts +14 -0
  214. package/dist/src/transcriptHash.js +23 -0
  215. package/dist/src/transcriptHash.js.map +1 -0
  216. package/dist/src/treeHash.d.ts +27 -0
  217. package/dist/src/treeHash.js +70 -0
  218. package/dist/src/treeHash.js.map +1 -0
  219. package/dist/src/treemath.d.ts +14 -0
  220. package/dist/src/treemath.js +87 -0
  221. package/dist/src/treemath.js.map +1 -0
  222. package/dist/src/unappliedProposals.d.ts +7 -0
  223. package/dist/src/unappliedProposals.js +9 -0
  224. package/dist/src/unappliedProposals.js.map +1 -0
  225. package/dist/src/updatePath.d.ts +34 -0
  226. package/dist/src/updatePath.js +163 -0
  227. package/dist/src/updatePath.js.map +1 -0
  228. package/dist/src/util/addToMap.d.ts +1 -0
  229. package/dist/src/util/addToMap.js +6 -0
  230. package/dist/src/util/addToMap.js.map +1 -0
  231. package/dist/src/util/array.d.ts +2 -0
  232. package/dist/src/util/array.js +9 -0
  233. package/dist/src/util/array.js.map +1 -0
  234. package/dist/src/util/byteArray.d.ts +3 -0
  235. package/dist/src/util/byteArray.js +27 -0
  236. package/dist/src/util/byteArray.js.map +1 -0
  237. package/dist/src/util/constantTimeCompare.d.ts +1 -0
  238. package/dist/src/util/constantTimeCompare.js +10 -0
  239. package/dist/src/util/constantTimeCompare.js.map +1 -0
  240. package/dist/src/util/enumHelpers.d.ts +4 -0
  241. package/dist/src/util/enumHelpers.js +28 -0
  242. package/dist/src/util/enumHelpers.js.map +1 -0
  243. package/dist/src/util/repeat.d.ts +1 -0
  244. package/dist/src/util/repeat.js +8 -0
  245. package/dist/src/util/repeat.js.map +1 -0
  246. package/dist/src/welcome.d.ts +29 -0
  247. package/dist/src/welcome.js +46 -0
  248. package/dist/src/welcome.js.map +1 -0
  249. package/dist/src/wireformat.d.ts +13 -0
  250. package/dist/src/wireformat.js +14 -0
  251. package/dist/src/wireformat.js.map +1 -0
  252. package/dist/test/base64.test.d.ts +1 -0
  253. package/dist/test/base64.test.js +87 -0
  254. package/dist/test/base64.test.js.map +1 -0
  255. package/dist/test/codec/authenticatedContent.test.d.ts +1 -0
  256. package/dist/test/codec/authenticatedContent.test.js +38 -0
  257. package/dist/test/codec/authenticatedContent.test.js.map +1 -0
  258. package/dist/test/codec/capabilities.test.d.ts +1 -0
  259. package/dist/test/codec/capabilities.test.js +26 -0
  260. package/dist/test/codec/capabilities.test.js.map +1 -0
  261. package/dist/test/codec/commit.test.d.ts +1 -0
  262. package/dist/test/codec/commit.test.js +15 -0
  263. package/dist/test/codec/commit.test.js.map +1 -0
  264. package/dist/test/codec/composite.test.d.ts +1 -0
  265. package/dist/test/codec/composite.test.js +61 -0
  266. package/dist/test/codec/composite.test.js.map +1 -0
  267. package/dist/test/codec/contentType.test.d.ts +1 -0
  268. package/dist/test/codec/contentType.test.js +12 -0
  269. package/dist/test/codec/contentType.test.js.map +1 -0
  270. package/dist/test/codec/credential.test.d.ts +1 -0
  271. package/dist/test/codec/credential.test.js +17 -0
  272. package/dist/test/codec/credential.test.js.map +1 -0
  273. package/dist/test/codec/credentialType.test.d.ts +1 -0
  274. package/dist/test/codec/credentialType.test.js +12 -0
  275. package/dist/test/codec/credentialType.test.js.map +1 -0
  276. package/dist/test/codec/encryptedGroupSecrets.test.d.ts +1 -0
  277. package/dist/test/codec/encryptedGroupSecrets.test.js +18 -0
  278. package/dist/test/codec/encryptedGroupSecrets.test.js.map +1 -0
  279. package/dist/test/codec/extension.test.d.ts +1 -0
  280. package/dist/test/codec/extension.test.js +20 -0
  281. package/dist/test/codec/extension.test.js.map +1 -0
  282. package/dist/test/codec/extensionType.test.d.ts +1 -0
  283. package/dist/test/codec/extensionType.test.js +12 -0
  284. package/dist/test/codec/extensionType.test.js.map +1 -0
  285. package/dist/test/codec/externalSender.test.d.ts +1 -0
  286. package/dist/test/codec/externalSender.test.js +20 -0
  287. package/dist/test/codec/externalSender.test.js.map +1 -0
  288. package/dist/test/codec/framedContent.test.d.ts +1 -0
  289. package/dist/test/codec/framedContent.test.js +26 -0
  290. package/dist/test/codec/framedContent.test.js.map +1 -0
  291. package/dist/test/codec/groupContext.test.d.ts +1 -0
  292. package/dist/test/codec/groupContext.test.js +30 -0
  293. package/dist/test/codec/groupContext.test.js.map +1 -0
  294. package/dist/test/codec/groupInfo.test.d.ts +1 -0
  295. package/dist/test/codec/groupInfo.test.js +45 -0
  296. package/dist/test/codec/groupInfo.test.js.map +1 -0
  297. package/dist/test/codec/groupSecrets.test.d.ts +1 -0
  298. package/dist/test/codec/groupSecrets.test.js +16 -0
  299. package/dist/test/codec/groupSecrets.test.js.map +1 -0
  300. package/dist/test/codec/hpkeCiphertext.test.d.ts +1 -0
  301. package/dist/test/codec/hpkeCiphertext.test.js +13 -0
  302. package/dist/test/codec/hpkeCiphertext.test.js.map +1 -0
  303. package/dist/test/codec/keyPackage.test.d.ts +1 -0
  304. package/dist/test/codec/keyPackage.test.js +58 -0
  305. package/dist/test/codec/keyPackage.test.js.map +1 -0
  306. package/dist/test/codec/keyPackageTBS.test.d.ts +1 -0
  307. package/dist/test/codec/keyPackageTBS.test.js +59 -0
  308. package/dist/test/codec/keyPackageTBS.test.js.map +1 -0
  309. package/dist/test/codec/leafNode.test.d.ts +1 -0
  310. package/dist/test/codec/leafNode.test.js +43 -0
  311. package/dist/test/codec/leafNode.test.js.map +1 -0
  312. package/dist/test/codec/leafNodeData.test.d.ts +1 -0
  313. package/dist/test/codec/leafNodeData.test.js +36 -0
  314. package/dist/test/codec/leafNodeData.test.js.map +1 -0
  315. package/dist/test/codec/leafNodeSource.test.d.ts +1 -0
  316. package/dist/test/codec/leafNodeSource.test.js +15 -0
  317. package/dist/test/codec/leafNodeSource.test.js.map +1 -0
  318. package/dist/test/codec/lifetime.test.d.ts +1 -0
  319. package/dist/test/codec/lifetime.test.js +12 -0
  320. package/dist/test/codec/lifetime.test.js.map +1 -0
  321. package/dist/test/codec/message.test.d.ts +1 -0
  322. package/dist/test/codec/message.test.js +100 -0
  323. package/dist/test/codec/message.test.js.map +1 -0
  324. package/dist/test/codec/nodeType.test.d.ts +1 -0
  325. package/dist/test/codec/nodeType.test.js +12 -0
  326. package/dist/test/codec/nodeType.test.js.map +1 -0
  327. package/dist/test/codec/number.test.d.ts +1 -0
  328. package/dist/test/codec/number.test.js +74 -0
  329. package/dist/test/codec/number.test.js.map +1 -0
  330. package/dist/test/codec/optional.test.d.ts +1 -0
  331. package/dist/test/codec/optional.test.js +42 -0
  332. package/dist/test/codec/optional.test.js.map +1 -0
  333. package/dist/test/codec/padding.test.d.ts +1 -0
  334. package/dist/test/codec/padding.test.js +40 -0
  335. package/dist/test/codec/padding.test.js.map +1 -0
  336. package/dist/test/codec/parentHash.test.d.ts +1 -0
  337. package/dist/test/codec/parentHash.test.js +13 -0
  338. package/dist/test/codec/parentHash.test.js.map +1 -0
  339. package/dist/test/codec/parentNode.test.d.ts +1 -0
  340. package/dist/test/codec/parentNode.test.js +22 -0
  341. package/dist/test/codec/parentNode.test.js.map +1 -0
  342. package/dist/test/codec/presharedkey.test.d.ts +1 -0
  343. package/dist/test/codec/presharedkey.test.js +35 -0
  344. package/dist/test/codec/presharedkey.test.js.map +1 -0
  345. package/dist/test/codec/privateContentAAD.test.d.ts +1 -0
  346. package/dist/test/codec/privateContentAAD.test.js +30 -0
  347. package/dist/test/codec/privateContentAAD.test.js.map +1 -0
  348. package/dist/test/codec/privateMessage.test.d.ts +1 -0
  349. package/dist/test/codec/privateMessage.test.js +36 -0
  350. package/dist/test/codec/privateMessage.test.js.map +1 -0
  351. package/dist/test/codec/proposal.test.d.ts +1 -0
  352. package/dist/test/codec/proposal.test.js +44 -0
  353. package/dist/test/codec/proposal.test.js.map +1 -0
  354. package/dist/test/codec/proposalOrRef.test.d.ts +1 -0
  355. package/dist/test/codec/proposalOrRef.test.js +12 -0
  356. package/dist/test/codec/proposalOrRef.test.js.map +1 -0
  357. package/dist/test/codec/proposalOrRefType.test.d.ts +1 -0
  358. package/dist/test/codec/proposalOrRefType.test.js +12 -0
  359. package/dist/test/codec/proposalOrRefType.test.js.map +1 -0
  360. package/dist/test/codec/proposalType.test.d.ts +1 -0
  361. package/dist/test/codec/proposalType.test.js +12 -0
  362. package/dist/test/codec/proposalType.test.js.map +1 -0
  363. package/dist/test/codec/protocolVersion.test.d.ts +1 -0
  364. package/dist/test/codec/protocolVersion.test.js +9 -0
  365. package/dist/test/codec/protocolVersion.test.js.map +1 -0
  366. package/dist/test/codec/pskId.test.d.ts +1 -0
  367. package/dist/test/codec/pskId.test.js +18 -0
  368. package/dist/test/codec/pskId.test.js.map +1 -0
  369. package/dist/test/codec/pskInfo.test.d.ts +1 -0
  370. package/dist/test/codec/pskInfo.test.js +12 -0
  371. package/dist/test/codec/pskInfo.test.js.map +1 -0
  372. package/dist/test/codec/pskLabel.test.d.ts +1 -0
  373. package/dist/test/codec/pskLabel.test.js +26 -0
  374. package/dist/test/codec/pskLabel.test.js.map +1 -0
  375. package/dist/test/codec/pskType.test.d.ts +1 -0
  376. package/dist/test/codec/pskType.test.js +12 -0
  377. package/dist/test/codec/pskType.test.js.map +1 -0
  378. package/dist/test/codec/publicMessage.test.d.ts +1 -0
  379. package/dist/test/codec/publicMessage.test.js +39 -0
  380. package/dist/test/codec/publicMessage.test.js.map +1 -0
  381. package/dist/test/codec/ratchetTree.test.d.ts +1 -0
  382. package/dist/test/codec/ratchetTree.test.js +83 -0
  383. package/dist/test/codec/ratchetTree.test.js.map +1 -0
  384. package/dist/test/codec/requiredCapabilities.test.d.ts +1 -0
  385. package/dist/test/codec/requiredCapabilities.test.js +30 -0
  386. package/dist/test/codec/requiredCapabilities.test.js.map +1 -0
  387. package/dist/test/codec/resumptionPSKUsage.test.d.ts +1 -0
  388. package/dist/test/codec/resumptionPSKUsage.test.js +15 -0
  389. package/dist/test/codec/resumptionPSKUsage.test.js.map +1 -0
  390. package/dist/test/codec/reuseGuard.test.d.ts +1 -0
  391. package/dist/test/codec/reuseGuard.test.js +9 -0
  392. package/dist/test/codec/reuseGuard.test.js.map +1 -0
  393. package/dist/test/codec/roundtrip.d.ts +3 -0
  394. package/dist/test/codec/roundtrip.js +8 -0
  395. package/dist/test/codec/roundtrip.js.map +1 -0
  396. package/dist/test/codec/sender.test.d.ts +1 -0
  397. package/dist/test/codec/sender.test.js +18 -0
  398. package/dist/test/codec/sender.test.js.map +1 -0
  399. package/dist/test/codec/senderData.test.d.ts +1 -0
  400. package/dist/test/codec/senderData.test.js +12 -0
  401. package/dist/test/codec/senderData.test.js.map +1 -0
  402. package/dist/test/codec/senderDataAAD.test.d.ts +1 -0
  403. package/dist/test/codec/senderDataAAD.test.js +12 -0
  404. package/dist/test/codec/senderDataAAD.test.js.map +1 -0
  405. package/dist/test/codec/senderType.test.d.ts +1 -0
  406. package/dist/test/codec/senderType.test.js +18 -0
  407. package/dist/test/codec/senderType.test.js.map +1 -0
  408. package/dist/test/codec/transcriptHash.test.d.ts +1 -0
  409. package/dist/test/codec/transcriptHash.test.js +38 -0
  410. package/dist/test/codec/transcriptHash.test.js.map +1 -0
  411. package/dist/test/codec/treeHash.test.d.ts +1 -0
  412. package/dist/test/codec/treeHash.test.js +17 -0
  413. package/dist/test/codec/treeHash.test.js.map +1 -0
  414. package/dist/test/codec/updatePath.test.d.ts +1 -0
  415. package/dist/test/codec/updatePath.test.js +81 -0
  416. package/dist/test/codec/updatePath.test.js.map +1 -0
  417. package/dist/test/codec/updatePathNode.test.d.ts +1 -0
  418. package/dist/test/codec/updatePathNode.test.js +23 -0
  419. package/dist/test/codec/updatePathNode.test.js.map +1 -0
  420. package/dist/test/codec/varLengthEncoding.test.d.ts +1 -0
  421. package/dist/test/codec/varLengthEncoding.test.js +90 -0
  422. package/dist/test/codec/varLengthEncoding.test.js.map +1 -0
  423. package/dist/test/codec/welcome.test.d.ts +1 -0
  424. package/dist/test/codec/welcome.test.js +25 -0
  425. package/dist/test/codec/welcome.test.js.map +1 -0
  426. package/dist/test/codec/wireformat.test.d.ts +1 -0
  427. package/dist/test/codec/wireformat.test.js +21 -0
  428. package/dist/test/codec/wireformat.test.js.map +1 -0
  429. package/dist/test/crypto/aead.test.d.ts +1 -0
  430. package/dist/test/crypto/aead.test.js +44 -0
  431. package/dist/test/crypto/aead.test.js.map +1 -0
  432. package/dist/test/crypto/hpke.test.d.ts +1 -0
  433. package/dist/test/crypto/hpke.test.js +58 -0
  434. package/dist/test/crypto/hpke.test.js.map +1 -0
  435. package/dist/test/crypto/keyMatch.d.ts +7 -0
  436. package/dist/test/crypto/keyMatch.js +22 -0
  437. package/dist/test/crypto/keyMatch.js.map +1 -0
  438. package/dist/test/extensionsEqual.test.d.ts +1 -0
  439. package/dist/test/extensionsEqual.test.js +51 -0
  440. package/dist/test/extensionsEqual.test.js.map +1 -0
  441. package/dist/test/groupinfo.test.d.ts +1 -0
  442. package/dist/test/groupinfo.test.js +40 -0
  443. package/dist/test/groupinfo.test.js.map +1 -0
  444. package/dist/test/scenario/common.d.ts +8 -0
  445. package/dist/test/scenario/common.js +41 -0
  446. package/dist/test/scenario/common.js.map +1 -0
  447. package/dist/test/scenario/customExtensions.test.d.ts +1 -0
  448. package/dist/test/scenario/customExtensions.test.js +56 -0
  449. package/dist/test/scenario/customExtensions.test.js.map +1 -0
  450. package/dist/test/scenario/customProposal.test.d.ts +1 -0
  451. package/dist/test/scenario/customProposal.test.js +71 -0
  452. package/dist/test/scenario/customProposal.test.js.map +1 -0
  453. package/dist/test/scenario/epochOutOfOrder.test.d.ts +1 -0
  454. package/dist/test/scenario/epochOutOfOrder.test.js +162 -0
  455. package/dist/test/scenario/epochOutOfOrder.test.js.map +1 -0
  456. package/dist/test/scenario/externalAddProposal.test.d.ts +1 -0
  457. package/dist/test/scenario/externalAddProposal.test.js +69 -0
  458. package/dist/test/scenario/externalAddProposal.test.js.map +1 -0
  459. package/dist/test/scenario/externalJoin.test.d.ts +1 -0
  460. package/dist/test/scenario/externalJoin.test.js +51 -0
  461. package/dist/test/scenario/externalJoin.test.js.map +1 -0
  462. package/dist/test/scenario/externalJoinResync.test.d.ts +1 -0
  463. package/dist/test/scenario/externalJoinResync.test.js +59 -0
  464. package/dist/test/scenario/externalJoinResync.test.js.map +1 -0
  465. package/dist/test/scenario/externalProposal.test.d.ts +1 -0
  466. package/dist/test/scenario/externalProposal.test.js +69 -0
  467. package/dist/test/scenario/externalProposal.test.js.map +1 -0
  468. package/dist/test/scenario/externalPsk.test.d.ts +1 -0
  469. package/dist/test/scenario/externalPsk.test.js +73 -0
  470. package/dist/test/scenario/externalPsk.test.js.map +1 -0
  471. package/dist/test/scenario/externalPskJoin.test.d.ts +1 -0
  472. package/dist/test/scenario/externalPskJoin.test.js +51 -0
  473. package/dist/test/scenario/externalPskJoin.test.js.map +1 -0
  474. package/dist/test/scenario/generationOutOfOrder.test.d.ts +1 -0
  475. package/dist/test/scenario/generationOutOfOrder.test.js +111 -0
  476. package/dist/test/scenario/generationOutOfOrder.test.js.map +1 -0
  477. package/dist/test/scenario/grease.test.d.ts +1 -0
  478. package/dist/test/scenario/grease.test.js +44 -0
  479. package/dist/test/scenario/grease.test.js.map +1 -0
  480. package/dist/test/scenario/largeGroupFullLifecycle.test.d.ts +1 -0
  481. package/dist/test/scenario/largeGroupFullLifecycle.test.js +127 -0
  482. package/dist/test/scenario/largeGroupFullLifecycle.test.js.map +1 -0
  483. package/dist/test/scenario/leaveProposal.test.d.ts +1 -0
  484. package/dist/test/scenario/leaveProposal.test.js +77 -0
  485. package/dist/test/scenario/leaveProposal.test.js.map +1 -0
  486. package/dist/test/scenario/multipleJoinsAtOnce.test.d.ts +1 -0
  487. package/dist/test/scenario/multipleJoinsAtOnce.test.js +48 -0
  488. package/dist/test/scenario/multipleJoinsAtOnce.test.js.map +1 -0
  489. package/dist/test/scenario/oneToOneJoin.test.d.ts +1 -0
  490. package/dist/test/scenario/oneToOneJoin.test.js +98 -0
  491. package/dist/test/scenario/oneToOneJoin.test.js.map +1 -0
  492. package/dist/test/scenario/ratchetTreeExtension.test.d.ts +1 -0
  493. package/dist/test/scenario/ratchetTreeExtension.test.js +48 -0
  494. package/dist/test/scenario/ratchetTreeExtension.test.js.map +1 -0
  495. package/dist/test/scenario/reinit.test.d.ts +1 -0
  496. package/dist/test/scenario/reinit.test.js +57 -0
  497. package/dist/test/scenario/reinit.test.js.map +1 -0
  498. package/dist/test/scenario/rejectIncomingMessage.test.d.ts +1 -0
  499. package/dist/test/scenario/rejectIncomingMessage.test.js +67 -0
  500. package/dist/test/scenario/rejectIncomingMessage.test.js.map +1 -0
  501. package/dist/test/scenario/remove.test.d.ts +1 -0
  502. package/dist/test/scenario/remove.test.js +68 -0
  503. package/dist/test/scenario/remove.test.js.map +1 -0
  504. package/dist/test/scenario/requiredCapabilites.test.d.ts +1 -0
  505. package/dist/test/scenario/requiredCapabilites.test.js +65 -0
  506. package/dist/test/scenario/requiredCapabilites.test.js.map +1 -0
  507. package/dist/test/scenario/resumption.test.d.ts +1 -0
  508. package/dist/test/scenario/resumption.test.js +43 -0
  509. package/dist/test/scenario/resumption.test.js.map +1 -0
  510. package/dist/test/scenario/threePartyJoin.test.d.ts +1 -0
  511. package/dist/test/scenario/threePartyJoin.test.js +56 -0
  512. package/dist/test/scenario/threePartyJoin.test.js.map +1 -0
  513. package/dist/test/scenario/update.test.d.ts +1 -0
  514. package/dist/test/scenario/update.test.js +50 -0
  515. package/dist/test/scenario/update.test.js.map +1 -0
  516. package/dist/test/test-vectors/cryptoBasics.test.d.ts +1 -0
  517. package/dist/test/test-vectors/cryptoBasics.test.js +60 -0
  518. package/dist/test/test-vectors/cryptoBasics.test.js.map +1 -0
  519. package/dist/test/test-vectors/deserialization.test.d.ts +1 -0
  520. package/dist/test/test-vectors/deserialization.test.js +13 -0
  521. package/dist/test/test-vectors/deserialization.test.js.map +1 -0
  522. package/dist/test/test-vectors/keySchedule.test.d.ts +1 -0
  523. package/dist/test/test-vectors/keySchedule.test.js +48 -0
  524. package/dist/test/test-vectors/keySchedule.test.js.map +1 -0
  525. package/dist/test/test-vectors/messageProtection.test.d.ts +1 -0
  526. package/dist/test/test-vectors/messageProtection.test.js +215 -0
  527. package/dist/test/test-vectors/messageProtection.test.js.map +1 -0
  528. package/dist/test/test-vectors/messages.test.d.ts +1 -0
  529. package/dist/test/test-vectors/messages.test.js +136 -0
  530. package/dist/test/test-vectors/messages.test.js.map +1 -0
  531. package/dist/test/test-vectors/passiveClientScenarios.test.d.ts +1 -0
  532. package/dist/test/test-vectors/passiveClientScenarios.test.js +86 -0
  533. package/dist/test/test-vectors/passiveClientScenarios.test.js.map +1 -0
  534. package/dist/test/test-vectors/pskSecret.test.d.ts +1 -0
  535. package/dist/test/test-vectors/pskSecret.test.js +18 -0
  536. package/dist/test/test-vectors/pskSecret.test.js.map +1 -0
  537. package/dist/test/test-vectors/secretTree.test.d.ts +1 -0
  538. package/dist/test/test-vectors/secretTree.test.js +48 -0
  539. package/dist/test/test-vectors/secretTree.test.js.map +1 -0
  540. package/dist/test/test-vectors/transcriptHashes.test.d.ts +1 -0
  541. package/dist/test/test-vectors/transcriptHashes.test.js +26 -0
  542. package/dist/test/test-vectors/transcriptHashes.test.js.map +1 -0
  543. package/dist/test/test-vectors/treeOperations.test.d.ts +1 -0
  544. package/dist/test/test-vectors/treeOperations.test.js +45 -0
  545. package/dist/test/test-vectors/treeOperations.test.js.map +1 -0
  546. package/dist/test/test-vectors/treeValidation.test.d.ts +1 -0
  547. package/dist/test/test-vectors/treeValidation.test.js +36 -0
  548. package/dist/test/test-vectors/treeValidation.test.js.map +1 -0
  549. package/dist/test/test-vectors/treekem.test.d.ts +1 -0
  550. package/dist/test/test-vectors/treekem.test.js +100 -0
  551. package/dist/test/test-vectors/treekem.test.js.map +1 -0
  552. package/dist/test/test-vectors/treemath.test.d.ts +1 -0
  553. package/dist/test/test-vectors/treemath.test.js +55 -0
  554. package/dist/test/test-vectors/treemath.test.js.map +1 -0
  555. package/dist/test/test-vectors/welcome.test.d.ts +1 -0
  556. package/dist/test/test-vectors/welcome.test.js +40 -0
  557. package/dist/test/test-vectors/welcome.test.js.map +1 -0
  558. package/dist/test/validation/proposalValidation.test.d.ts +1 -0
  559. package/dist/test/validation/proposalValidation.test.js +231 -0
  560. package/dist/test/validation/proposalValidation.test.js.map +1 -0
  561. package/dist/test/validation/ratchetTreeValidation.test.d.ts +1 -0
  562. package/dist/test/validation/ratchetTreeValidation.test.js +51 -0
  563. package/dist/test/validation/ratchetTreeValidation.test.js.map +1 -0
  564. package/dist/test/validation/resumptionValidation.test.d.ts +1 -0
  565. package/dist/test/validation/resumptionValidation.test.js +79 -0
  566. package/dist/test/validation/resumptionValidation.test.js.map +1 -0
  567. package/dist/test_vectors/crypto-basics.json +303 -0
  568. package/dist/test_vectors/deserialization.json +58 -0
  569. package/dist/test_vectors/key-schedule.json +926 -0
  570. package/dist/test_vectors/message-protection.json +142 -0
  571. package/dist/test_vectors/messages.json +5702 -0
  572. package/dist/test_vectors/passive-client-handling-commit.json +2683 -0
  573. package/dist/test_vectors/passive-client-random.json +2657 -0
  574. package/dist/test_vectors/passive-client-welcome.json +814 -0
  575. package/dist/test_vectors/psk_secret.json +2382 -0
  576. package/dist/test_vectors/secret-tree.json +4846 -0
  577. package/dist/test_vectors/transcript-hashes.json +58 -0
  578. package/dist/test_vectors/tree-math.json +8156 -0
  579. package/dist/test_vectors/tree-operations.json +47 -0
  580. package/dist/test_vectors/tree-validation.json +6204 -0
  581. package/dist/test_vectors/treekem.json +14859 -0
  582. package/dist/test_vectors/welcome.json +51 -0
  583. package/package.json +108 -0
@@ -0,0 +1,56 @@
1
+ export const encodeUint8 = (n) => {
2
+ const buffer = new ArrayBuffer(1);
3
+ const view = new DataView(buffer);
4
+ view.setUint8(0, n);
5
+ return new Uint8Array(buffer);
6
+ };
7
+ export const decodeUint8 = (b, offset) => {
8
+ const value = b.at(offset);
9
+ return value !== undefined ? [value, 1] : undefined;
10
+ };
11
+ export const encodeUint16 = (n) => {
12
+ const buffer = new ArrayBuffer(2);
13
+ const view = new DataView(buffer);
14
+ view.setUint16(0, n);
15
+ return new Uint8Array(buffer);
16
+ };
17
+ export const decodeUint16 = (b, offset) => {
18
+ const view = new DataView(b.buffer, b.byteOffset, b.byteLength);
19
+ try {
20
+ return [view.getUint16(offset), 2];
21
+ }
22
+ catch (e) {
23
+ return undefined;
24
+ }
25
+ };
26
+ export const encodeUint32 = (n) => {
27
+ const buffer = new ArrayBuffer(4);
28
+ const view = new DataView(buffer);
29
+ view.setUint32(0, n);
30
+ return new Uint8Array(buffer);
31
+ };
32
+ export const decodeUint32 = (b, offset) => {
33
+ const view = new DataView(b.buffer, b.byteOffset, b.byteLength);
34
+ try {
35
+ return [view.getUint32(offset), 4];
36
+ }
37
+ catch (e) {
38
+ return undefined;
39
+ }
40
+ };
41
+ export const encodeUint64 = (n) => {
42
+ const buffer = new ArrayBuffer(8);
43
+ const view = new DataView(buffer);
44
+ view.setBigUint64(0, n);
45
+ return new Uint8Array(buffer);
46
+ };
47
+ export const decodeUint64 = (b, offset) => {
48
+ const view = new DataView(b.buffer, b.byteOffset, b.byteLength);
49
+ try {
50
+ return [view.getBigUint64(offset), 8];
51
+ }
52
+ catch (e) {
53
+ return undefined;
54
+ }
55
+ };
56
+ //# sourceMappingURL=number.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"number.js","sourceRoot":"","sources":["../../../src/codec/number.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ import { Decoder } from "./tlsDecoder";
2
+ import { Encoder } from "./tlsEncoder";
3
+ export declare function encodeOptional<T>(encodeT: Encoder<T>): Encoder<T | undefined>;
4
+ export declare function decodeOptional<T>(decodeT: Decoder<T>): Decoder<T | undefined>;
@@ -0,0 +1,20 @@
1
+ import { decodeUint8, encodeUint8 } from "./number";
2
+ export function encodeOptional(encodeT) {
3
+ return (t) => (t ? prependPresenceOctet(encodeT(t)) : new Uint8Array([0x0]));
4
+ }
5
+ export function decodeOptional(decodeT) {
6
+ return (b, offset) => {
7
+ const presenceOctet = decodeUint8(b, offset)?.[0];
8
+ if (presenceOctet == 1) {
9
+ const result = decodeT(b, offset + 1);
10
+ return result === undefined ? undefined : [result[0], result[1] + 1];
11
+ }
12
+ else {
13
+ return [undefined, 1];
14
+ }
15
+ };
16
+ }
17
+ function prependPresenceOctet(v) {
18
+ return new Uint8Array([...encodeUint8(0x1), ...v]);
19
+ }
20
+ //# sourceMappingURL=optional.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"optional.js","sourceRoot":"","sources":["../../../src/codec/optional.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,UAAU,CAAA;AAInD,MAAM,UAAU,cAAc,CAAI,OAAmB;IACnD,OAAO,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,oBAAoB,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,UAAU,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAA;AAC9E,CAAC;AAED,MAAM,UAAU,cAAc,CAAI,OAAmB;IACnD,OAAO,CAAC,CAAC,EAAE,MAAM,EAAE,EAAE;QACnB,MAAM,aAAa,GAAG,WAAW,CAAC,CAAC,EAAE,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,CAAA;QACjD,IAAI,aAAa,IAAI,CAAC,EAAE,CAAC;YACvB,MAAM,MAAM,GAAG,OAAO,CAAC,CAAC,EAAE,MAAM,GAAG,CAAC,CAAC,CAAA;YACrC,OAAO,MAAM,KAAK,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAA;QACtE,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,SAAS,EAAE,CAAC,CAAC,CAAA;QACvB,CAAC;IACH,CAAC,CAAA;AACH,CAAC;AAED,SAAS,oBAAoB,CAAC,CAAa;IACzC,OAAO,IAAI,UAAU,CAAC,CAAC,GAAG,WAAW,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAA;AACpD,CAAC"}
@@ -0,0 +1,14 @@
1
+ export type Decoder<T> = (b: Uint8Array, offset: number) => [T, number] | undefined;
2
+ export declare function mapDecoder<T, U>(dec: Decoder<T>, f: (t: T) => U): Decoder<U>;
3
+ export declare function mapDecodersOption<T extends unknown[], R>(decoders: {
4
+ [K in keyof T]: Decoder<T[K]>;
5
+ }, f: (...args: T) => R | undefined): Decoder<R>;
6
+ export declare function mapDecoders<T extends unknown[], R>(decoders: {
7
+ [K in keyof T]: Decoder<T[K]>;
8
+ }, f: (...args: T) => R): Decoder<R>;
9
+ export declare function mapDecoderOption<T, U>(dec: Decoder<T>, f: (t: T) => U | undefined): Decoder<U>;
10
+ export declare function flatMapDecoder<T, U>(dec: Decoder<T>, f: (t: T) => Decoder<U>): Decoder<U>;
11
+ export declare function orDecoder<T, U>(decT: Decoder<T>, decU: Decoder<U>): Decoder<T | U>;
12
+ export declare function flatMapDecoderAndMap<T, U, V>(dec: Decoder<T>, f: (t: T) => Decoder<U>, g: (t: T, u: U) => V): Decoder<V>;
13
+ export declare function succeedDecoder<T>(t: T): Decoder<T>;
14
+ export declare const decodeVoid: Decoder<void>;
@@ -0,0 +1,78 @@
1
+ export function mapDecoder(dec, f) {
2
+ return (b, offset) => {
3
+ const x = dec(b, offset);
4
+ if (x !== undefined) {
5
+ const [t, l] = x;
6
+ return [f(t), l];
7
+ }
8
+ };
9
+ }
10
+ export function mapDecodersOption(decoders, f) {
11
+ return (b, offset) => {
12
+ const initial = mapDecoders(decoders, f)(b, offset);
13
+ if (initial === undefined)
14
+ return undefined;
15
+ else {
16
+ const [r, len] = initial;
17
+ return r !== undefined ? [r, len] : undefined;
18
+ }
19
+ };
20
+ }
21
+ export function mapDecoders(decoders, f) {
22
+ return (b, offset) => {
23
+ const result = decoders.reduce((acc, decoder) => {
24
+ if (!acc)
25
+ return undefined;
26
+ const decoded = decoder(b, acc.offset);
27
+ if (!decoded)
28
+ return undefined;
29
+ const [value, length] = decoded;
30
+ return {
31
+ values: [...acc.values, value],
32
+ offset: acc.offset + length,
33
+ totalLength: acc.totalLength + length,
34
+ };
35
+ }, { values: [], offset, totalLength: 0 });
36
+ if (!result)
37
+ return;
38
+ return [f(...result.values), result.totalLength];
39
+ };
40
+ }
41
+ export function mapDecoderOption(dec, f) {
42
+ return (b, offset) => {
43
+ const x = dec(b, offset);
44
+ if (x !== undefined) {
45
+ const [t, l] = x;
46
+ const u = f(t);
47
+ return u !== undefined ? [u, l] : undefined;
48
+ }
49
+ };
50
+ }
51
+ export function flatMapDecoder(dec, f) {
52
+ return flatMapDecoderAndMap(dec, f, (_t, u) => u);
53
+ }
54
+ export function orDecoder(decT, decU) {
55
+ return (b, offset) => {
56
+ const t = decT(b, offset);
57
+ return t ? t : decU(b, offset);
58
+ };
59
+ }
60
+ export function flatMapDecoderAndMap(dec, f, g) {
61
+ return (b, offset) => {
62
+ const decodedT = dec(b, offset);
63
+ if (decodedT !== undefined) {
64
+ const [t, len] = decodedT;
65
+ const decoderU = f(t);
66
+ const decodedU = decoderU(b, offset + len);
67
+ if (decodedU !== undefined) {
68
+ const [u, len2] = decodedU;
69
+ return [g(t, u), len + len2];
70
+ }
71
+ }
72
+ };
73
+ }
74
+ export function succeedDecoder(t) {
75
+ return () => [t, 0];
76
+ }
77
+ export const decodeVoid = () => [undefined, 0];
78
+ //# sourceMappingURL=tlsDecoder.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tlsDecoder.js","sourceRoot":"","sources":["../../../src/codec/tlsDecoder.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,9 @@
1
+ export type Encoder<T> = (t: T) => Uint8Array;
2
+ export declare function contramapEncoders<T extends unknown[], R>(encoders: {
3
+ [K in keyof T]: Encoder<T[K]>;
4
+ }, toTuple: (input: R) => T): Encoder<R>;
5
+ export declare function composeEncoders<T extends unknown[]>(encoders: {
6
+ [K in keyof T]: Encoder<T[K]>;
7
+ }): Encoder<T>;
8
+ export declare function contramapEncoder<T, U>(enc: Encoder<T>, f: (u: U) => Readonly<T>): Encoder<U>;
9
+ export declare function encodeVoid<T>(): Encoder<T>;
@@ -0,0 +1,23 @@
1
+ export function contramapEncoders(encoders, toTuple) {
2
+ return (value) => {
3
+ const values = toTuple(value);
4
+ const encodedParts = encoders.map((encoder, i) => encoder(values[i]));
5
+ const totalLength = encodedParts.reduce((sum, part) => sum + part.length, 0);
6
+ const result = new Uint8Array(totalLength);
7
+ encodedParts.reduce((offset, part) => {
8
+ result.set(part, offset);
9
+ return offset + part.length;
10
+ }, 0);
11
+ return result;
12
+ };
13
+ }
14
+ export function composeEncoders(encoders) {
15
+ return (values) => contramapEncoders(encoders, (t) => t)(values);
16
+ }
17
+ export function contramapEncoder(enc, f) {
18
+ return (u) => enc(f(u));
19
+ }
20
+ export function encodeVoid() {
21
+ return () => new Uint8Array();
22
+ }
23
+ //# sourceMappingURL=tlsEncoder.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tlsEncoder.js","sourceRoot":"","sources":["../../../src/codec/tlsEncoder.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,iBAAiB,CAC/B,QAA2C,EAC3C,OAAwB;IAExB,OAAO,CAAC,KAAQ,EAAE,EAAE;QAClB,MAAM,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC,CAAA;QAE7B,MAAM,YAAY,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;QACrE,MAAM,WAAW,GAAG,YAAY,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE,CAAC,GAAG,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,CAAA;QAE5E,MAAM,MAAM,GAAG,IAAI,UAAU,CAAC,WAAW,CAAC,CAAA;QAC1C,YAAY,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,IAAI,EAAE,EAAE;YACnC,MAAM,CAAC,GAAG,CAAC,IAAI,EAAE,MAAM,CAAC,CAAA;YACxB,OAAO,MAAM,GAAG,IAAI,CAAC,MAAM,CAAA;QAC7B,CAAC,EAAE,CAAC,CAAC,CAAA;QAEL,OAAO,MAAM,CAAA;IACf,CAAC,CAAA;AACH,CAAC;AAED,MAAM,UAAU,eAAe,CAAsB,QAA2C;IAC9F,OAAO,CAAC,MAAS,EAAE,EAAE,CAAC,iBAAiB,CAAC,QAAQ,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAM,CAAC,CAAC,MAAM,CAAC,CAAA;AAC1E,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAO,GAAe,EAAE,CAAwB;IAC9E,OAAO,CAAC,CAAI,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;AAC5B,CAAC;AAED,MAAM,UAAU,UAAU;IACxB,OAAO,GAAG,EAAE,CAAC,IAAI,UAAU,EAAE,CAAA;AAC/B,CAAC"}
@@ -0,0 +1,11 @@
1
+ import { Decoder } from "./tlsDecoder";
2
+ import { Encoder } from "./tlsEncoder";
3
+ export declare const encodeVarLenData: Encoder<Uint8Array>;
4
+ export declare function encodeLength(len: number): Uint8Array;
5
+ export declare function determineLength(data: Uint8Array, offset?: number): {
6
+ length: number;
7
+ lengthFieldSize: number;
8
+ };
9
+ export declare const decodeVarLenData: Decoder<Uint8Array>;
10
+ export declare function encodeVarLenType<T>(enc: Encoder<T>): Encoder<T[]>;
11
+ export declare function decodeVarLenType<T>(dec: Decoder<T>): Decoder<T[]>;
@@ -0,0 +1,95 @@
1
+ import { CodecError } from "../mlsError";
2
+ export const encodeVarLenData = (data) => {
3
+ const lenBytes = encodeLength(data.length);
4
+ const result = new Uint8Array(lenBytes.length + data.length);
5
+ result.set(lenBytes, 0);
6
+ result.set(data, lenBytes.length);
7
+ return result;
8
+ };
9
+ export function encodeLength(len) {
10
+ if (len < 64) {
11
+ // 1-byte length: 00xxxxxx
12
+ return new Uint8Array([len & 0b00111111]);
13
+ }
14
+ else if (len < 16384) {
15
+ // 2-byte length: 01xxxxxx xxxxxxxx
16
+ return new Uint8Array([((len >> 8) & 0b00111111) | 0b01000000, len & 0xff]);
17
+ }
18
+ else if (len < 0x40000000) {
19
+ // 4-byte length: 10xxxxxx xxxxxxxx xxxxxxxx xxxxxxxx
20
+ return new Uint8Array([((len >> 24) & 0b00111111) | 0b10000000, (len >> 16) & 0xff, (len >> 8) & 0xff, len & 0xff]);
21
+ }
22
+ else {
23
+ throw new CodecError("Length too large to encode (max is 2^30 - 1)");
24
+ }
25
+ }
26
+ export function determineLength(data, offset = 0) {
27
+ if (offset >= data.length) {
28
+ throw new CodecError("Offset beyond buffer");
29
+ }
30
+ const firstByte = data[offset];
31
+ const prefix = firstByte >> 6;
32
+ if (prefix === 0) {
33
+ return { length: firstByte & 0b00111111, lengthFieldSize: 1 };
34
+ }
35
+ else if (prefix === 1) {
36
+ if (offset + 2 > data.length)
37
+ throw new CodecError("Incomplete 2-byte length");
38
+ return { length: ((firstByte & 0b00111111) << 8) | data[offset + 1], lengthFieldSize: 2 };
39
+ }
40
+ else if (prefix === 2) {
41
+ if (offset + 4 > data.length)
42
+ throw new CodecError("Incomplete 4-byte length");
43
+ return {
44
+ length: ((firstByte & 0b00111111) << 24) |
45
+ (data[offset + 1] << 16) |
46
+ (data[offset + 2] << 8) |
47
+ data[offset + 3],
48
+ lengthFieldSize: 4,
49
+ };
50
+ }
51
+ else {
52
+ throw new CodecError("8-byte length not supported in this implementation");
53
+ }
54
+ }
55
+ export const decodeVarLenData = (buf, offset) => {
56
+ if (offset >= buf.length) {
57
+ throw new CodecError("Offset beyond buffer");
58
+ }
59
+ const { length, lengthFieldSize } = determineLength(buf, offset);
60
+ const totalBytes = lengthFieldSize + length;
61
+ if (offset + totalBytes > buf.length) {
62
+ throw new CodecError("Data length exceeds buffer");
63
+ }
64
+ const data = buf.subarray(offset + lengthFieldSize, offset + totalBytes);
65
+ return [data, totalBytes];
66
+ };
67
+ export function encodeVarLenType(enc) {
68
+ return (data) => {
69
+ let x = new Uint8Array();
70
+ for (const t of data) {
71
+ x = new Uint8Array([...x, ...enc(t)]);
72
+ }
73
+ return encodeVarLenData(x);
74
+ };
75
+ }
76
+ export function decodeVarLenType(dec) {
77
+ return (b, offset) => {
78
+ const d = decodeVarLenData(b, offset);
79
+ if (d === undefined)
80
+ return;
81
+ const [totalBytes, totalLength] = d;
82
+ let cursor = 0;
83
+ const result = [];
84
+ while (cursor < totalBytes.length) {
85
+ const item = dec(totalBytes, cursor);
86
+ if (item === undefined)
87
+ return undefined;
88
+ const [value, len] = item;
89
+ result.push(value);
90
+ cursor += len;
91
+ }
92
+ return [result, totalLength];
93
+ };
94
+ }
95
+ //# sourceMappingURL=variableLength.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"variableLength.js","sourceRoot":"","sources":["../../../src/codec/variableLength.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,10 @@
1
+ import { Decoder } from "./codec/tlsDecoder";
2
+ import { Encoder } from "./codec/tlsEncoder";
3
+ import { ProposalOrRef } from "./proposalOrRefType";
4
+ import { UpdatePath } from "./updatePath";
5
+ export type Commit = {
6
+ proposals: ProposalOrRef[];
7
+ path: UpdatePath | undefined;
8
+ };
9
+ export declare const encodeCommit: Encoder<Commit>;
10
+ export declare const decodeCommit: Decoder<Commit>;
@@ -0,0 +1,9 @@
1
+ import { decodeOptional, encodeOptional } from "./codec/optional";
2
+ import { mapDecoders } from "./codec/tlsDecoder";
3
+ import { contramapEncoders } from "./codec/tlsEncoder";
4
+ import { decodeVarLenType, encodeVarLenType } from "./codec/variableLength";
5
+ import { decodeProposalOrRef, encodeProposalOrRef } from "./proposalOrRefType";
6
+ import { decodeUpdatePath, encodeUpdatePath } from "./updatePath";
7
+ export const encodeCommit = contramapEncoders([encodeVarLenType(encodeProposalOrRef), encodeOptional(encodeUpdatePath)], (commit) => [commit.proposals, commit.path]);
8
+ export const decodeCommit = mapDecoders([decodeVarLenType(decodeProposalOrRef), decodeOptional(decodeUpdatePath)], (proposals, path) => ({ proposals, path }));
9
+ //# sourceMappingURL=commit.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"commit.js","sourceRoot":"","sources":["../../src/commit.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAA;AACjE,OAAO,EAAW,WAAW,EAAE,MAAM,oBAAoB,CAAA;AACzD,OAAO,EAAE,iBAAiB,EAAW,MAAM,oBAAoB,CAAA;AAC/D,OAAO,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAA;AAC3E,OAAO,EAAE,mBAAmB,EAAE,mBAAmB,EAAiB,MAAM,qBAAqB,CAAA;AAC7F,OAAO,EAAE,gBAAgB,EAAE,gBAAgB,EAAc,MAAM,cAAc,CAAA;AAI7E,MAAM,CAAC,MAAM,YAAY,GAAoB,iBAAiB,CAC5D,CAAC,gBAAgB,CAAC,mBAAmB,CAAC,EAAE,cAAc,CAAC,gBAAgB,CAAC,CAAC,EACzE,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,MAAM,CAAC,SAAS,EAAE,MAAM,CAAC,IAAI,CAAU,CACrD,CAAA;AAED,MAAM,CAAC,MAAM,YAAY,GAAoB,WAAW,CACtD,CAAC,gBAAgB,CAAC,mBAAmB,CAAC,EAAE,cAAc,CAAC,gBAAgB,CAAC,CAAC,EACzE,CAAC,SAAS,EAAE,IAAI,EAAE,EAAE,CAAC,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAC3C,CAAA"}
@@ -0,0 +1,12 @@
1
+ import { Decoder } from "./codec/tlsDecoder";
2
+ import { Encoder } from "./codec/tlsEncoder";
3
+ declare const contentTypes: {
4
+ readonly application: 1;
5
+ readonly proposal: 2;
6
+ readonly commit: 3;
7
+ };
8
+ export type ContentTypeName = keyof typeof contentTypes;
9
+ export type ContentTypeValue = (typeof contentTypes)[ContentTypeName];
10
+ export declare const encodeContentType: Encoder<ContentTypeName>;
11
+ export declare const decodeContentType: Decoder<ContentTypeName>;
12
+ export {};
@@ -0,0 +1,12 @@
1
+ import { decodeUint8, encodeUint8 } from "./codec/number";
2
+ import { mapDecoderOption } from "./codec/tlsDecoder";
3
+ import { contramapEncoder } from "./codec/tlsEncoder";
4
+ import { enumNumberToKey } from "./util/enumHelpers";
5
+ const contentTypes = {
6
+ application: 1,
7
+ proposal: 2,
8
+ commit: 3,
9
+ };
10
+ export const encodeContentType = contramapEncoder(encodeUint8, (t) => contentTypes[t]);
11
+ export const decodeContentType = mapDecoderOption(decodeUint8, enumNumberToKey(contentTypes));
12
+ //# sourceMappingURL=contentType.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"contentType.js","sourceRoot":"","sources":["../../src/contentType.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAA;AACzD,OAAO,EAAW,gBAAgB,EAAE,MAAM,oBAAoB,CAAA;AAC9D,OAAO,EAAE,gBAAgB,EAAW,MAAM,oBAAoB,CAAA;AAC9D,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAA;AAEpD,MAAM,YAAY,GAAG;IACnB,WAAW,EAAE,CAAC;IACd,QAAQ,EAAE,CAAC;IACX,MAAM,EAAE,CAAC;CACD,CAAA;AAKV,MAAM,CAAC,MAAM,iBAAiB,GAA6B,gBAAgB,CAAC,WAAW,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAA;AAEhH,MAAM,CAAC,MAAM,iBAAiB,GAA6B,gBAAgB,CAAC,WAAW,EAAE,eAAe,CAAC,YAAY,CAAC,CAAC,CAAA"}
@@ -0,0 +1,32 @@
1
+ import { ClientState } from "./clientState";
2
+ import { CiphersuiteImpl } from "./crypto/ciphersuite";
3
+ import { GroupContext } from "./groupContext";
4
+ import { GroupInfo } from "./groupInfo";
5
+ import { KeyPackage, PrivateKeyPackage } from "./keyPackage";
6
+ import { MLSMessage } from "./message";
7
+ import { PrivateKeyPath } from "./privateKeyPath";
8
+ import { Proposal } from "./proposal";
9
+ import { PskIndex } from "./pskIndex";
10
+ import { RatchetTree } from "./ratchetTree";
11
+ import { UpdatePath } from "./updatePath";
12
+ import { Welcome } from "./welcome";
13
+ import { ClientConfig } from "./clientConfig";
14
+ export type CreateCommitResult = {
15
+ newState: ClientState;
16
+ welcome: Welcome | undefined;
17
+ commit: MLSMessage;
18
+ };
19
+ export declare function createCommit(state: ClientState, pskSearch: PskIndex, publicMessage: boolean, extraProposals: Proposal[], cs: CiphersuiteImpl, ratchetTreeExtension?: boolean, authenticatedData?: Uint8Array): Promise<CreateCommitResult>;
20
+ export declare function createGroupInfo(groupContext: GroupContext, confirmationTag: Uint8Array, state: ClientState, cs: CiphersuiteImpl): Promise<GroupInfo>;
21
+ export declare function createGroupInfoWithRatchetTree(groupContext: GroupContext, confirmationTag: Uint8Array, state: ClientState, tree: RatchetTree, cs: CiphersuiteImpl): Promise<GroupInfo>;
22
+ export declare function createGroupInfoWithExternalPub(state: ClientState, cs: CiphersuiteImpl): Promise<GroupInfo>;
23
+ export declare function createGroupInfoWithExternalPubAndRatchetTree(state: ClientState, cs: CiphersuiteImpl): Promise<GroupInfo>;
24
+ export declare function applyUpdatePathSecret(tree: RatchetTree, privatePath: PrivateKeyPath, senderLeafIndex: number, gc: GroupContext, path: UpdatePath, excludeNodes: number[], cs: CiphersuiteImpl): Promise<{
25
+ nodeIndex: number;
26
+ pathSecret: Uint8Array;
27
+ }>;
28
+ export declare function joinGroupExternal(groupInfo: GroupInfo, keyPackage: KeyPackage, privateKeys: PrivateKeyPackage, resync: boolean, cs: CiphersuiteImpl, tree?: RatchetTree, clientConfig?: ClientConfig, authenticatedData?: Uint8Array): Promise<{
29
+ publicMessage: import("./publicMessage").PublicMessage;
30
+ newState: ClientState;
31
+ }>;
32
+ export declare function filterNewLeaves(resolution: number[], excludeNodes: number[]): number[];