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,547 @@
1
+ import { makeProposalRef } from "./authenticatedContent";
2
+ import { extensionsEqual, extensionsSupportedByCapabilities } from "./extension";
3
+ import { createConfirmationTag } from "./framedContent";
4
+ import { ratchetTreeFromExtension, verifyGroupInfoConfirmationTag, verifyGroupInfoSignature } from "./groupInfo";
5
+ import { makeKeyPackageRef, verifyKeyPackage } from "./keyPackage";
6
+ import { deriveKeySchedule, initializeKeySchedule } from "./keySchedule";
7
+ import { encodePskId } from "./presharedkey";
8
+ import { addLeafNode, findBlankLeafNodeIndexOrExtend, findLeafIndex, getHpkePublicKey, removeLeafNode, updateLeafNode, } from "./ratchetTree";
9
+ import { createSecretTree } from "./secretTree";
10
+ import { createConfirmedHash, createInterimHash } from "./transcriptHash";
11
+ import { treeHashRoot } from "./treeHash";
12
+ import { directPath, isLeaf, leafToNodeIndex, leafWidth, nodeToLeafIndex } from "./treemath";
13
+ import { firstCommonAncestor } from "./updatePath";
14
+ import { bytesToBase64 } from "./util/byteArray";
15
+ import { constantTimeEqual } from "./util/constantTimeCompare";
16
+ import { decryptGroupInfo, decryptGroupSecrets } from "./welcome";
17
+ import { pathToRoot } from "./pathSecrets";
18
+ import { mergePrivateKeyPaths, toPrivateKeyPath } from "./privateKeyPath";
19
+ import { addUnappliedProposal } from "./unappliedProposals";
20
+ import { accumulatePskSecret } from "./pskIndex";
21
+ import { getSenderLeafNodeIndex } from "./sender";
22
+ import { addToMap } from "./util/addToMap";
23
+ import { CryptoVerificationError, CodecError, InternalError, UsageError, ValidationError } from "./mlsError";
24
+ import { verifyLeafNodeSignature, verifyLeafNodeSignatureKeyPackage, } from "./leafNode";
25
+ import { protocolVersions } from "./protocolVersion";
26
+ import { decodeRequiredCapabilities } from "./requiredCapabilities";
27
+ import { verifyParentHashes } from "./parentHash";
28
+ import { defaultClientConfig } from "./clientConfig";
29
+ import { decodeExternalSender } from "./externalSender";
30
+ import { arraysEqual } from "./util/array";
31
+ export function checkCanSendApplicationMessages(state) {
32
+ if (Object.keys(state.unappliedProposals).length !== 0)
33
+ throw new UsageError("Cannot send application message with unapplied proposals");
34
+ checkCanSendHandshakeMessages(state);
35
+ }
36
+ export function checkCanSendHandshakeMessages(state) {
37
+ if (state.groupActiveState.kind === "suspendedPendingReinit")
38
+ throw new UsageError("Cannot send messages while Group is suspended pending reinit");
39
+ else if (state.groupActiveState.kind === "removedFromGroup")
40
+ throw new UsageError("Cannot send messages after being removed from group");
41
+ }
42
+ const emptyProposals = {
43
+ add: [],
44
+ update: [],
45
+ remove: [],
46
+ psk: [],
47
+ reinit: [],
48
+ external_init: [],
49
+ group_context_extensions: [],
50
+ };
51
+ function flattenExtensions(groupContextExtensions) {
52
+ return groupContextExtensions.reduce((acc, { proposal }) => {
53
+ return [...acc, ...proposal.groupContextExtensions.extensions];
54
+ }, []);
55
+ }
56
+ async function validateProposals(p, committerLeafIndex, groupContext, config, authService, tree) {
57
+ const containsUpdateByCommitter = p.update.some((o) => o.senderLeafIndex !== undefined && o.senderLeafIndex === committerLeafIndex);
58
+ if (containsUpdateByCommitter)
59
+ return new ValidationError("Commit cannot contain an update proposal sent by committer");
60
+ const containsRemoveOfCommitter = p.remove.some((o) => o.proposal.remove.removed === committerLeafIndex);
61
+ if (containsRemoveOfCommitter)
62
+ return new ValidationError("Commit cannot contain a remove proposal removing committer");
63
+ const multipleUpdateRemoveForSameLeaf = p.update.some(({ senderLeafIndex: a }, indexA) => p.update.some(({ senderLeafIndex: b }, indexB) => a === b && indexA !== indexB) ||
64
+ p.remove.some((r) => r.proposal.remove.removed === a)) ||
65
+ p.remove.some((a, indexA) => p.remove.some((b, indexB) => b.proposal.remove.removed === a.proposal.remove.removed && indexA !== indexB) ||
66
+ p.update.some(({ senderLeafIndex }) => a.proposal.remove.removed === senderLeafIndex));
67
+ if (multipleUpdateRemoveForSameLeaf)
68
+ return new ValidationError("Commit cannot contain multiple update and/or remove proposals that apply to the same leaf");
69
+ const multipleAddsContainSameKeypackage = p.add.some(({ proposal: a }, indexA) => p.add.some(({ proposal: b }, indexB) => config.compareKeyPackages(a.add.keyPackage, b.add.keyPackage) && indexA !== indexB));
70
+ if (multipleAddsContainSameKeypackage)
71
+ return new ValidationError("Commit cannot contain multiple Add proposals that contain KeyPackages that represent the same client");
72
+ // checks if there is an Add proposal with a KeyPackage that matches a client already in the group
73
+ // unless there is a Remove proposal in the list removing the matching client from the group.
74
+ const addsContainExistingKeypackage = p.add.some(({ proposal }) => tree.some((node, nodeIndex) => node !== undefined &&
75
+ node.nodeType === "leaf" &&
76
+ config.compareKeyPackageToLeafNode(proposal.add.keyPackage, node.leaf) &&
77
+ p.remove.every((r) => r.proposal.remove.removed !== nodeToLeafIndex(nodeIndex))));
78
+ if (addsContainExistingKeypackage)
79
+ return new ValidationError("Commit cannot contain an Add proposal for someone already in the group");
80
+ const everyLeafSupportsGroupExtensions = p.add.every(({ proposal }) => extensionsSupportedByCapabilities(groupContext.extensions, proposal.add.keyPackage.leafNode.capabilities));
81
+ if (!everyLeafSupportsGroupExtensions)
82
+ return new ValidationError("Added leaf node that doesn't support extension in GroupContext");
83
+ const multiplePskWithSamePskId = p.psk.some((a, indexA) => p.psk.some((b, indexB) => constantTimeEqual(encodePskId(a.proposal.psk.preSharedKeyId), encodePskId(b.proposal.psk.preSharedKeyId)) &&
84
+ indexA !== indexB));
85
+ if (multiplePskWithSamePskId)
86
+ return new ValidationError("Commit cannot contain PreSharedKey proposals that reference the same PreSharedKeyID");
87
+ const multipleGroupContextExtensions = p.group_context_extensions.length > 1;
88
+ if (multipleGroupContextExtensions)
89
+ return new ValidationError("Commit cannot contain multiple GroupContextExtensions proposals");
90
+ const allExtensions = flattenExtensions(p.group_context_extensions);
91
+ const requiredCapabilities = allExtensions.find((e) => e.extensionType === "required_capabilities");
92
+ if (requiredCapabilities !== undefined) {
93
+ const caps = decodeRequiredCapabilities(requiredCapabilities.extensionData, 0);
94
+ if (caps === undefined)
95
+ return new CodecError("Could not decode required_capabilities");
96
+ const everyLeafSupportsCapabilities = tree
97
+ .filter((n) => n !== undefined && n.nodeType === "leaf")
98
+ .every((l) => capabiltiesAreSupported(caps[0], l.leaf.capabilities));
99
+ if (!everyLeafSupportsCapabilities)
100
+ return new ValidationError("Not all members support required capabilities");
101
+ const allAdditionsSupportCapabilities = p.add.every((a) => capabiltiesAreSupported(caps[0], a.proposal.add.keyPackage.leafNode.capabilities));
102
+ if (!allAdditionsSupportCapabilities)
103
+ return new ValidationError("Commit contains add proposals of member without required capabilities");
104
+ }
105
+ return await validateExternalSenders(allExtensions, authService);
106
+ }
107
+ async function validateExternalSenders(extensions, authService) {
108
+ const externalSenders = extensions.filter((e) => e.extensionType === "external_senders");
109
+ for (const externalSender of externalSenders) {
110
+ const decoded = decodeExternalSender(externalSender.extensionData, 0);
111
+ if (decoded === undefined)
112
+ return new CodecError("Could not decode external_senders");
113
+ const validCredential = await authService.validateCredential(decoded[0].credential, decoded[0].signaturePublicKey);
114
+ if (!validCredential)
115
+ return new ValidationError("Could not validate external credential");
116
+ }
117
+ }
118
+ function capabiltiesAreSupported(caps, cs) {
119
+ return (caps.credentialTypes.every((c) => cs.credentials.includes(c)) &&
120
+ caps.extensionTypes.every((e) => cs.extensions.includes(e)) &&
121
+ caps.proposalTypes.every((p) => cs.proposals.includes(p)));
122
+ }
123
+ export async function validateRatchetTree(tree, groupContext, config, authService, treeHash, cs) {
124
+ const treeIsStructurallySound = tree.every((n, index) => isLeaf(index) ? n === undefined || n.nodeType === "leaf" : n === undefined || n.nodeType === "parent");
125
+ if (!treeIsStructurallySound)
126
+ return new ValidationError("Received Ratchet Tree is not structurally sound");
127
+ const parentHashesVerified = await verifyParentHashes(tree, cs.hash);
128
+ if (!parentHashesVerified)
129
+ return new CryptoVerificationError("Unable to verify parent hash");
130
+ if (!constantTimeEqual(treeHash, await treeHashRoot(tree, cs.hash)))
131
+ return new ValidationError("Unable to verify tree hash");
132
+ //validate all parent nodes
133
+ for (const [parentIndex, n] of tree.entries()) {
134
+ if (n?.nodeType === "parent") {
135
+ // verify unmerged leaves
136
+ for (const unmergedLeaf of n.parent.unmergedLeaves) {
137
+ const dp = directPath(leafToNodeIndex(unmergedLeaf), leafWidth(tree.length));
138
+ const nodeIndex = leafToNodeIndex(unmergedLeaf);
139
+ if (tree[nodeIndex]?.nodeType !== "leaf" && !dp.includes(parentIndex))
140
+ return new ValidationError("Unmerged leaf did not represent a non-blank descendant leaf node");
141
+ for (const parentIdx of dp) {
142
+ const dpNode = tree[parentIdx];
143
+ if (dpNode !== undefined) {
144
+ if (dpNode.nodeType !== "parent")
145
+ return new InternalError("Expected parent node");
146
+ if (!arraysEqual(dpNode.parent.unmergedLeaves, n.parent.unmergedLeaves))
147
+ return new ValidationError("non-blank intermediate node must list leaf node in its unmerged_leaves");
148
+ }
149
+ }
150
+ }
151
+ }
152
+ }
153
+ const duplicateHpkeKeys = hasDuplicateUint8Arrays(tree.map((n) => (n !== undefined ? getHpkePublicKey(n) : undefined)));
154
+ if (duplicateHpkeKeys)
155
+ return new ValidationError("Multiple public keys with the same value");
156
+ // validate all leaf nodes
157
+ for (const [index, n] of tree.entries()) {
158
+ if (n?.nodeType === "leaf") {
159
+ const err = n.leaf.leafNodeSource === "key_package"
160
+ ? await validateLeafNodeKeyPackage(n.leaf, groupContext, tree, false, config, authService, nodeToLeafIndex(index), cs.signature)
161
+ : await validateLeafNodeUpdateOrCommit(n.leaf, nodeToLeafIndex(index), groupContext, tree, authService, cs.signature);
162
+ if (err !== undefined)
163
+ return err;
164
+ }
165
+ }
166
+ }
167
+ function hasDuplicateUint8Arrays(byteArrays) {
168
+ const seen = new Set();
169
+ for (const data of byteArrays) {
170
+ if (data === undefined)
171
+ continue;
172
+ const key = bytesToBase64(data);
173
+ if (seen.has(key)) {
174
+ return true;
175
+ }
176
+ seen.add(key);
177
+ }
178
+ return false;
179
+ }
180
+ export async function validateLeafNodeUpdateOrCommit(leafNode, leafIndex, groupContext, tree, authService, s) {
181
+ const signatureValid = await verifyLeafNodeSignature(leafNode, groupContext.groupId, leafIndex, s);
182
+ if (!signatureValid)
183
+ return new CryptoVerificationError("Could not verify leaf node signature");
184
+ const commonError = await validateLeafNodeCommon(leafNode, groupContext, tree, authService, leafIndex);
185
+ if (commonError !== undefined)
186
+ return commonError;
187
+ }
188
+ export function throwIfDefined(err) {
189
+ if (err !== undefined)
190
+ throw err;
191
+ }
192
+ async function validateLeafNodeCommon(leafNode, groupContext, tree, authService, leafIndex) {
193
+ const credentialValid = await authService.validateCredential(leafNode.credential, leafNode.signaturePublicKey);
194
+ if (!credentialValid)
195
+ return new ValidationError("Could not validate credential");
196
+ const requiredCapabilities = groupContext.extensions.find((e) => e.extensionType === "required_capabilities");
197
+ if (requiredCapabilities !== undefined) {
198
+ const caps = decodeRequiredCapabilities(requiredCapabilities.extensionData, 0);
199
+ if (caps === undefined)
200
+ return new CodecError("Could not decode required_capabilities");
201
+ const leafSupportsCapabilities = capabiltiesAreSupported(caps[0], leafNode.capabilities);
202
+ if (!leafSupportsCapabilities)
203
+ return new ValidationError("LeafNode does not support required capabilities");
204
+ }
205
+ const credentialUnsupported = tree.some((node) => node !== undefined &&
206
+ node.nodeType === "leaf" &&
207
+ !node.leaf.capabilities.credentials.includes(leafNode.credential.credentialType));
208
+ if (credentialUnsupported)
209
+ return new ValidationError("LeafNode has credential that is not supported by member of the group");
210
+ const extensionsSupported = extensionsSupportedByCapabilities(leafNode.extensions, leafNode.capabilities);
211
+ if (!extensionsSupported)
212
+ return new ValidationError("LeafNode contains extension not listed in capabilities");
213
+ const keysAreNotUnique = tree.some((node, nodeIndex) => node !== undefined &&
214
+ node.nodeType === "leaf" &&
215
+ (constantTimeEqual(node.leaf.hpkePublicKey, leafNode.hpkePublicKey) ||
216
+ constantTimeEqual(node.leaf.signaturePublicKey, leafNode.signaturePublicKey)) &&
217
+ leafIndex !== nodeToLeafIndex(nodeIndex));
218
+ if (keysAreNotUnique)
219
+ return new ValidationError("hpke and signature keys not unique");
220
+ }
221
+ async function validateLeafNodeKeyPackage(leafNode, groupContext, tree, sentByClient, config, authService, leafIndex, s) {
222
+ const signatureValid = await verifyLeafNodeSignatureKeyPackage(leafNode, s);
223
+ if (!signatureValid)
224
+ return new CryptoVerificationError("Could not verify leaf node signature");
225
+ //verify lifetime
226
+ if (sentByClient || config.validateLifetimeOnReceive) {
227
+ if (leafNode.leafNodeSource === "key_package") {
228
+ const currentTime = BigInt(Math.floor(Date.now() / 1000));
229
+ if (leafNode.lifetime.notBefore > currentTime || leafNode.lifetime.notAfter < currentTime)
230
+ return new ValidationError("Current time not within Lifetime");
231
+ }
232
+ }
233
+ const commonError = await validateLeafNodeCommon(leafNode, groupContext, tree, authService, leafIndex);
234
+ if (commonError !== undefined)
235
+ return commonError;
236
+ }
237
+ async function validateKeyPackage(kp, groupContext, tree, sentByClient, config, authService, s) {
238
+ if (kp.cipherSuite !== groupContext.cipherSuite)
239
+ return new ValidationError("Invalid CipherSuite");
240
+ if (kp.version !== groupContext.version)
241
+ return new ValidationError("Invalid mls version");
242
+ const leafNodeError = await validateLeafNodeKeyPackage(kp.leafNode, groupContext, tree, sentByClient, config, authService, undefined, s);
243
+ if (leafNodeError !== undefined)
244
+ return leafNodeError;
245
+ const signatureValid = await verifyKeyPackage(kp, s);
246
+ if (!signatureValid)
247
+ return new CryptoVerificationError("Invalid keypackage signature");
248
+ if (constantTimeEqual(kp.initKey, kp.leafNode.hpkePublicKey))
249
+ return new ValidationError("Cannot have identicial init and encryption keys");
250
+ }
251
+ function validateReinit(allProposals, reinit, gc) {
252
+ if (allProposals.length !== 1)
253
+ return new ValidationError("Reinit proposal needs to be commited by itself");
254
+ if (protocolVersions[reinit.version] < protocolVersions[gc.version])
255
+ return new ValidationError("A ReInit proposal cannot use a version less than the version for the current group");
256
+ }
257
+ function validateExternalInit(grouped) {
258
+ if (grouped.external_init.length > 1)
259
+ return new ValidationError("Cannot contain more than one external_init proposal");
260
+ if (grouped.remove.length > 1)
261
+ return new ValidationError("Cannot contain more than one remove proposal");
262
+ if (grouped.add.length > 0 ||
263
+ grouped.group_context_extensions.length > 0 ||
264
+ grouped.reinit.length > 0 ||
265
+ grouped.update.length > 0)
266
+ return new ValidationError("Invalid proposals");
267
+ }
268
+ function validateRemove(remove, tree) {
269
+ if (tree[leafToNodeIndex(remove.removed)] === undefined)
270
+ return new ValidationError("Tried to remove empty leaf node");
271
+ }
272
+ export async function applyProposals(state, proposals, committerLeafIndex, pskSearch, sentByClient, cs) {
273
+ const allProposals = proposals.reduce((acc, cur) => {
274
+ if (cur.proposalOrRefType === "proposal")
275
+ return [...acc, { proposal: cur.proposal, senderLeafIndex: committerLeafIndex }];
276
+ const p = state.unappliedProposals[bytesToBase64(cur.reference)];
277
+ if (p === undefined)
278
+ throw new ValidationError("Could not find proposal with supplied reference");
279
+ return [...acc, p];
280
+ }, []);
281
+ const grouped = allProposals.reduce((acc, cur) => {
282
+ //this skips any custom proposals
283
+ if (typeof cur.proposal.proposalType === "number")
284
+ return acc;
285
+ const proposal = acc[cur.proposal.proposalType] ?? [];
286
+ return { ...acc, [cur.proposal.proposalType]: [...proposal, cur] };
287
+ }, emptyProposals);
288
+ const zeroes = new Uint8Array(cs.kdf.size);
289
+ const isExternalInit = grouped.external_init.length > 0;
290
+ if (!isExternalInit) {
291
+ if (grouped.reinit.length > 0) {
292
+ const reinit = grouped.reinit.at(0).proposal.reinit;
293
+ throwIfDefined(validateReinit(allProposals, reinit, state.groupContext));
294
+ return {
295
+ tree: state.ratchetTree,
296
+ pskSecret: zeroes,
297
+ pskIds: [],
298
+ needsUpdatePath: false,
299
+ additionalResult: {
300
+ kind: "reinit",
301
+ reinit,
302
+ },
303
+ selfRemoved: false,
304
+ allProposals,
305
+ };
306
+ }
307
+ throwIfDefined(await validateProposals(grouped, committerLeafIndex, state.groupContext, state.clientConfig.keyPackageEqualityConfig, state.clientConfig.authService, state.ratchetTree));
308
+ const newExtensions = flattenExtensions(grouped.group_context_extensions);
309
+ const [mutatedTree, addedLeafNodes] = await applyTreeMutations(state.ratchetTree, grouped, state.groupContext, sentByClient, state.clientConfig.authService, state.clientConfig.lifetimeConfig, cs.signature);
310
+ const [updatedPskSecret, pskIds] = await accumulatePskSecret(grouped.psk.map((p) => p.proposal.psk.preSharedKeyId), pskSearch, cs, zeroes);
311
+ const selfRemoved = mutatedTree[leafToNodeIndex(state.privatePath.leafIndex)] === undefined;
312
+ const needsUpdatePath = allProposals.length === 0 || Object.values(grouped.update).length > 1 || Object.values(grouped.remove).length > 1;
313
+ return {
314
+ tree: mutatedTree,
315
+ pskSecret: updatedPskSecret,
316
+ additionalResult: {
317
+ kind: "memberCommit",
318
+ addedLeafNodes,
319
+ extensions: newExtensions,
320
+ },
321
+ pskIds,
322
+ needsUpdatePath,
323
+ selfRemoved,
324
+ allProposals,
325
+ };
326
+ }
327
+ else {
328
+ throwIfDefined(validateExternalInit(grouped));
329
+ const treeAfterRemove = grouped.remove.reduce((acc, { proposal }) => {
330
+ return removeLeafNode(acc, proposal.remove.removed);
331
+ }, state.ratchetTree);
332
+ const zeroes = new Uint8Array(cs.kdf.size);
333
+ const [updatedPskSecret, pskIds] = await accumulatePskSecret(grouped.psk.map((p) => p.proposal.psk.preSharedKeyId), pskSearch, cs, zeroes);
334
+ const initProposal = grouped.external_init.at(0);
335
+ const externalKeyPair = await cs.hpke.deriveKeyPair(state.keySchedule.externalSecret);
336
+ const externalInitSecret = await importSecret(await cs.hpke.exportPrivateKey(externalKeyPair.privateKey), initProposal.proposal.externalInit.kemOutput, cs);
337
+ return {
338
+ needsUpdatePath: true,
339
+ tree: treeAfterRemove,
340
+ pskSecret: updatedPskSecret,
341
+ pskIds,
342
+ additionalResult: {
343
+ kind: "externalCommit",
344
+ externalInitSecret,
345
+ newMemberLeafIndex: nodeToLeafIndex(findBlankLeafNodeIndexOrExtend(treeAfterRemove)),
346
+ },
347
+ selfRemoved: false,
348
+ allProposals,
349
+ };
350
+ }
351
+ }
352
+ export function makePskIndex(state, externalPsks) {
353
+ return {
354
+ findPsk(preSharedKeyId) {
355
+ if (preSharedKeyId.psktype === "external") {
356
+ return externalPsks[bytesToBase64(preSharedKeyId.pskId)];
357
+ }
358
+ if (state !== undefined && constantTimeEqual(preSharedKeyId.pskGroupId, state.groupContext.groupId)) {
359
+ if (preSharedKeyId.pskEpoch === state.groupContext.epoch)
360
+ return state.keySchedule.resumptionPsk;
361
+ else
362
+ return state.historicalReceiverData.get(preSharedKeyId.pskEpoch)?.resumptionPsk;
363
+ }
364
+ },
365
+ };
366
+ }
367
+ export async function nextEpochContext(groupContext, wireformat, content, signature, updatedTreeHash, confirmationTag, h) {
368
+ const interimTranscriptHash = await createInterimHash(groupContext.confirmedTranscriptHash, confirmationTag, h);
369
+ const newConfirmedHash = await createConfirmedHash(interimTranscriptHash, { wireformat, content, signature }, h);
370
+ return {
371
+ ...groupContext,
372
+ epoch: groupContext.epoch + 1n,
373
+ treeHash: updatedTreeHash,
374
+ confirmedTranscriptHash: newConfirmedHash,
375
+ };
376
+ }
377
+ export async function joinGroup(welcome, keyPackage, privateKeys, pskSearch, cs, ratchetTree, resumingFromState, clientConfig = defaultClientConfig) {
378
+ const keyPackageRef = await makeKeyPackageRef(keyPackage, cs.hash);
379
+ const privKey = await cs.hpke.importPrivateKey(privateKeys.initPrivateKey);
380
+ const groupSecrets = await decryptGroupSecrets(privKey, keyPackageRef, welcome, cs.hpke);
381
+ if (groupSecrets === undefined)
382
+ throw new CodecError("Could not decode group secrets");
383
+ const zeroes = new Uint8Array(cs.kdf.size);
384
+ const [pskSecret, pskIds] = await accumulatePskSecret(groupSecrets.psks, pskSearch, cs, zeroes);
385
+ const gi = await decryptGroupInfo(welcome, groupSecrets.joinerSecret, pskSecret, cs);
386
+ if (gi === undefined)
387
+ throw new CodecError("Could not decode group info");
388
+ const resumptionPsk = pskIds.find((id) => id.psktype === "resumption");
389
+ if (resumptionPsk !== undefined) {
390
+ if (resumingFromState === undefined)
391
+ throw new ValidationError("No prior state passed for resumption");
392
+ if (resumptionPsk.pskEpoch !== resumingFromState.groupContext.epoch)
393
+ throw new ValidationError("Epoch mismatch");
394
+ if (!constantTimeEqual(resumptionPsk.pskGroupId, resumingFromState.groupContext.groupId))
395
+ throw new ValidationError("old groupId mismatch");
396
+ if (gi.groupContext.epoch !== 1n)
397
+ throw new ValidationError("Resumption must be started at epoch 1");
398
+ if (resumptionPsk.usage === "reinit") {
399
+ if (resumingFromState.groupActiveState.kind !== "suspendedPendingReinit")
400
+ throw new ValidationError("Found reinit psk but no old suspended clientState");
401
+ if (!constantTimeEqual(resumingFromState.groupActiveState.reinit.groupId, gi.groupContext.groupId))
402
+ throw new ValidationError("new groupId mismatch");
403
+ if (resumingFromState.groupActiveState.reinit.version !== gi.groupContext.version)
404
+ throw new ValidationError("Version mismatch");
405
+ if (resumingFromState.groupActiveState.reinit.cipherSuite !== gi.groupContext.cipherSuite)
406
+ throw new ValidationError("Ciphersuite mismatch");
407
+ if (!extensionsEqual(resumingFromState.groupActiveState.reinit.extensions, gi.groupContext.extensions))
408
+ throw new ValidationError("Extensions mismatch");
409
+ }
410
+ }
411
+ const allExtensionsSupported = extensionsSupportedByCapabilities(gi.groupContext.extensions, keyPackage.leafNode.capabilities);
412
+ if (!allExtensionsSupported)
413
+ throw new UsageError("client does not support every extension in the GroupContext");
414
+ const tree = ratchetTreeFromExtension(gi) ?? ratchetTree;
415
+ if (tree === undefined)
416
+ throw new UsageError("No RatchetTree passed and no ratchet_tree extension");
417
+ const signerNode = tree[leafToNodeIndex(gi.signer)];
418
+ if (signerNode === undefined) {
419
+ throw new ValidationError("Could not find signer leafNode");
420
+ }
421
+ if (signerNode.nodeType === "parent")
422
+ throw new ValidationError("Expected non blank leaf node");
423
+ const credentialVerified = await clientConfig.authService.validateCredential(signerNode.leaf.credential, signerNode.leaf.signaturePublicKey);
424
+ if (!credentialVerified)
425
+ throw new ValidationError("Could not validate credential");
426
+ const groupInfoSignatureVerified = verifyGroupInfoSignature(gi, signerNode.leaf.signaturePublicKey, cs.signature);
427
+ if (!groupInfoSignatureVerified)
428
+ throw new CryptoVerificationError("Could not verify groupInfo signature");
429
+ if (gi.groupContext.cipherSuite !== keyPackage.cipherSuite)
430
+ throw new ValidationError("cipher suite in the GroupInfo does not match the cipher_suite in the KeyPackage");
431
+ throwIfDefined(await validateRatchetTree(tree, gi.groupContext, clientConfig.lifetimeConfig, clientConfig.authService, gi.groupContext.treeHash, cs));
432
+ const newLeaf = findLeafIndex(tree, keyPackage.leafNode);
433
+ if (newLeaf === undefined)
434
+ throw new ValidationError("Could not find own leaf when processing welcome");
435
+ const privateKeyPath = {
436
+ leafIndex: newLeaf,
437
+ privateKeys: { [leafToNodeIndex(newLeaf)]: privateKeys.hpkePrivateKey },
438
+ };
439
+ const ancestorNodeIndex = firstCommonAncestor(tree, newLeaf, gi.signer);
440
+ const updatedPkp = groupSecrets.pathSecret === undefined
441
+ ? privateKeyPath
442
+ : mergePrivateKeyPaths(await toPrivateKeyPath(await pathToRoot(tree, ancestorNodeIndex, groupSecrets.pathSecret, cs.kdf), newLeaf, cs), privateKeyPath);
443
+ const keySchedule = await deriveKeySchedule(groupSecrets.joinerSecret, pskSecret, gi.groupContext, cs.kdf);
444
+ const confirmationTagVerified = await verifyGroupInfoConfirmationTag(gi, groupSecrets.joinerSecret, pskSecret, cs);
445
+ if (!confirmationTagVerified)
446
+ throw new CryptoVerificationError("Could not verify confirmation tag");
447
+ const secretTree = await createSecretTree(leafWidth(tree.length), keySchedule.encryptionSecret, cs.kdf);
448
+ return {
449
+ groupContext: gi.groupContext,
450
+ ratchetTree: tree,
451
+ privatePath: updatedPkp,
452
+ signaturePrivateKey: privateKeys.signaturePrivateKey,
453
+ confirmationTag: gi.confirmationTag,
454
+ unappliedProposals: {},
455
+ keySchedule,
456
+ secretTree,
457
+ historicalReceiverData: new Map(),
458
+ groupActiveState: { kind: "active" },
459
+ clientConfig,
460
+ };
461
+ }
462
+ export async function createGroup(groupId, keyPackage, privateKeyPackage, extensions, cs, clientConfig = defaultClientConfig) {
463
+ const ratchetTree = [{ nodeType: "leaf", leaf: keyPackage.leafNode }];
464
+ const privatePath = {
465
+ leafIndex: 0,
466
+ privateKeys: { [0]: privateKeyPackage.hpkePrivateKey },
467
+ };
468
+ const confirmedTranscriptHash = new Uint8Array();
469
+ const groupContext = {
470
+ version: "mls10",
471
+ cipherSuite: cs.name,
472
+ epoch: 0n,
473
+ treeHash: await treeHashRoot(ratchetTree, cs.hash),
474
+ groupId,
475
+ extensions,
476
+ confirmedTranscriptHash,
477
+ };
478
+ throwIfDefined(await validateExternalSenders(extensions, clientConfig.authService));
479
+ const epochSecret = cs.rng.randomBytes(cs.kdf.size);
480
+ const keySchedule = await initializeKeySchedule(epochSecret, cs.kdf);
481
+ const confirmationTag = await createConfirmationTag(keySchedule.confirmationKey, confirmedTranscriptHash, cs.hash);
482
+ const secretTree = await createSecretTree(1, keySchedule.encryptionSecret, cs.kdf);
483
+ return {
484
+ ratchetTree,
485
+ keySchedule,
486
+ secretTree,
487
+ privatePath,
488
+ signaturePrivateKey: privateKeyPackage.signaturePrivateKey,
489
+ unappliedProposals: {},
490
+ historicalReceiverData: new Map(),
491
+ groupContext,
492
+ confirmationTag,
493
+ groupActiveState: { kind: "active" },
494
+ clientConfig,
495
+ };
496
+ }
497
+ export async function exportSecret(publicKey, cs) {
498
+ return cs.hpke.exportSecret(await cs.hpke.importPublicKey(publicKey), new TextEncoder().encode("MLS 1.0 external init secret"), cs.kdf.size, new Uint8Array());
499
+ }
500
+ async function importSecret(privateKey, kemOutput, cs) {
501
+ return cs.hpke.importSecret(await cs.hpke.importPrivateKey(privateKey), new TextEncoder().encode("MLS 1.0 external init secret"), kemOutput, cs.kdf.size, new Uint8Array());
502
+ }
503
+ async function applyTreeMutations(ratchetTree, grouped, gc, sentByClient, authService, lifetimeConfig, s) {
504
+ const treeAfterUpdate = await grouped.update.reduce(async (acc, { senderLeafIndex, proposal }) => {
505
+ if (senderLeafIndex === undefined)
506
+ throw new InternalError("No sender index found for update proposal");
507
+ throwIfDefined(await validateLeafNodeUpdateOrCommit(proposal.update.leafNode, senderLeafIndex, gc, ratchetTree, authService, s));
508
+ return updateLeafNode(await acc, proposal.update.leafNode, senderLeafIndex);
509
+ }, Promise.resolve(ratchetTree));
510
+ const treeAfterRemove = grouped.remove.reduce((acc, { proposal }) => {
511
+ throwIfDefined(validateRemove(proposal.remove, ratchetTree));
512
+ return removeLeafNode(acc, proposal.remove.removed);
513
+ }, treeAfterUpdate);
514
+ const [treeAfterAdd, addedLeafNodes] = await grouped.add.reduce(async (acc, { proposal }) => {
515
+ throwIfDefined(await validateKeyPackage(proposal.add.keyPackage, gc, ratchetTree, sentByClient, lifetimeConfig, authService, s));
516
+ const [tree, ws] = await acc;
517
+ const [updatedTree, leafNodeIndex] = addLeafNode(tree, proposal.add.keyPackage.leafNode);
518
+ return [updatedTree, [...ws, [nodeToLeafIndex(leafNodeIndex), proposal.add.keyPackage]]];
519
+ }, Promise.resolve([treeAfterRemove, []]));
520
+ return [treeAfterAdd, addedLeafNodes];
521
+ }
522
+ export async function processProposal(state, content, proposal, h) {
523
+ const ref = await makeProposalRef(content, h);
524
+ return {
525
+ ...state,
526
+ unappliedProposals: addUnappliedProposal(ref, state.unappliedProposals, proposal, getSenderLeafNodeIndex(content.content.sender)),
527
+ };
528
+ }
529
+ export function addHistoricalReceiverData(state) {
530
+ const withNew = addToMap(state.historicalReceiverData, state.groupContext.epoch, {
531
+ secretTree: state.secretTree,
532
+ ratchetTree: state.ratchetTree,
533
+ senderDataSecret: state.keySchedule.senderDataSecret,
534
+ groupContext: state.groupContext,
535
+ resumptionPsk: state.keySchedule.resumptionPsk,
536
+ });
537
+ const epochs = [...withNew.keys()];
538
+ const result = epochs.length >= state.clientConfig.keyRetentionConfig.retainKeysForEpochs
539
+ ? removeOldHistoricalReceiverData(withNew, state.clientConfig.keyRetentionConfig.retainKeysForEpochs)
540
+ : withNew;
541
+ return result;
542
+ }
543
+ function removeOldHistoricalReceiverData(historicalReceiverData, max) {
544
+ const sortedEpochs = [...historicalReceiverData.keys()].sort((a, b) => (a < b ? -1 : 1));
545
+ return new Map(sortedEpochs.slice(-max).map((epoch) => [epoch, historicalReceiverData.get(epoch)]));
546
+ }
547
+ //# sourceMappingURL=clientState.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"clientState.js","sourceRoot":"","sources":["../../src/clientState.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,10 @@
1
+ import { Decoder } from "./tlsDecoder";
2
+ import { Encoder } from "./tlsEncoder";
3
+ export declare const encodeUint8: Encoder<number>;
4
+ export declare const decodeUint8: Decoder<number>;
5
+ export declare const encodeUint16: Encoder<number>;
6
+ export declare const decodeUint16: Decoder<number>;
7
+ export declare const encodeUint32: Encoder<number>;
8
+ export declare const decodeUint32: Decoder<number>;
9
+ export declare const encodeUint64: Encoder<bigint>;
10
+ export declare const decodeUint64: Decoder<bigint>;