@kodelyth/matrix 2026.5.39 → 2026.5.42

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 (321) hide show
  1. package/CHANGELOG.md +321 -0
  2. package/SPEC-SUPPORT.md +116 -0
  3. package/api.ts +38 -0
  4. package/auth-presence.ts +56 -0
  5. package/channel-plugin-api.ts +3 -0
  6. package/cli-metadata.ts +11 -0
  7. package/contract-api.ts +17 -0
  8. package/dist/account-selection-Y50DNJ2l.js +158 -0
  9. package/dist/active-client-CmFdvPdO.js +20 -0
  10. package/dist/api.js +12 -0
  11. package/dist/approval-handler.runtime-BIi4fL0R.js +377 -0
  12. package/dist/approval-ids-BGHK7PnZ.js +7 -0
  13. package/dist/approval-reaction-auth-CL0-nCNV.js +27 -0
  14. package/dist/approval-reactions-nDm2x-K5.js +162 -0
  15. package/dist/async-lock-SsmtFXtt.js +19 -0
  16. package/dist/auth-presence.js +26 -0
  17. package/dist/backup-health-3BHbHxyd.js +60 -0
  18. package/dist/channel-C0kCyTNB.js +1380 -0
  19. package/dist/channel-plugin-api.js +2 -0
  20. package/dist/channel.runtime-CdrdEN-0.js +250 -0
  21. package/dist/cli-FtY6Nuzw.js +1338 -0
  22. package/dist/cli-metadata-Dkwua7CB.js +22 -0
  23. package/dist/cli-metadata.js +2 -0
  24. package/dist/client-BnohYygh.js +25 -0
  25. package/dist/client-PhrTwuC4.js +30 -0
  26. package/dist/client-bootstrap-Mcj8ChJ5.js +114 -0
  27. package/dist/config-paths-DVvt6vM3.js +114 -0
  28. package/dist/config-schema-BMGOlhdI.js +308 -0
  29. package/dist/config-secret-input.runtime-Dv_4Br_f.js +2 -0
  30. package/dist/contract-api.js +8 -0
  31. package/dist/create-client-J0htTaRj.js +64 -0
  32. package/dist/credentials-B7GsBbgQ.js +56 -0
  33. package/dist/credentials-read-8fE4qoWs.js +112 -0
  34. package/dist/credentials-write.runtime-BibplB4Y.js +17 -0
  35. package/dist/crypto-node.runtime-D9qxgRPa.js +12 -0
  36. package/dist/crypto-runtime-1pKW4O2F.js +1214 -0
  37. package/dist/deps-DVpDS81G.js +208 -0
  38. package/dist/device-health-Ct2wDSPG.js +16 -0
  39. package/dist/directory-live-i3T8uORc.js +150 -0
  40. package/dist/doctor-contract-BLzYHl_9.js +246 -0
  41. package/dist/doctor-contract-api.js +2 -0
  42. package/dist/doctor-diR5gE7D.js +153 -0
  43. package/dist/draft-stream-HpPJ_VJt.js +143 -0
  44. package/dist/encryption-guidance-BNEgckrZ.js +15 -0
  45. package/dist/env-auth-UFiTGkDM.js +63 -0
  46. package/dist/env-vars-EQKQv-FE.js +63 -0
  47. package/dist/errors-BETj3zr9.js +17 -0
  48. package/dist/exec-approval-resolver-BxPorU_t.js +15 -0
  49. package/dist/helper-api.js +4 -0
  50. package/dist/http-client-DoQgbQsU.js +331 -0
  51. package/dist/index.js +46 -0
  52. package/dist/legacy-crypto-inspector-zK0hDCbt.js +41 -0
  53. package/dist/legacy-crypto-restore-DSFIXuDo.js +85 -0
  54. package/dist/logging-Df7aPD1z.js +99 -0
  55. package/dist/matrix-migration.runtime-BNoT1Prt.js +525 -0
  56. package/dist/media-text-ZhGA8Pcs.js +146 -0
  57. package/dist/messages-CRA9WGg0.js +140 -0
  58. package/dist/migration-snapshot-backup-BR-xD7Ew.js +69 -0
  59. package/dist/migration-snapshot.runtime-BLcy_Nvw.js +2 -0
  60. package/dist/monitor-DQm7_13y.js +4331 -0
  61. package/dist/plugin-entry.handlers.runtime.js +51 -0
  62. package/dist/probe.runtime-CjJS53Kz.js +3 -0
  63. package/dist/profile-update-DqkPgZ1P.js +68 -0
  64. package/dist/reaction-common-CmVLzP-u.js +71 -0
  65. package/dist/reaction-events-D0nUJuZV.js +121 -0
  66. package/dist/record-shared-DGvSFn5M.js +2 -0
  67. package/dist/resolve-targets-ChECUzD2.js +140 -0
  68. package/dist/resolver.runtime-hdY3n0GO.js +5 -0
  69. package/dist/rolldown-runtime-DUslC3ob.js +14 -0
  70. package/dist/route-xRKj_ESW.js +161 -0
  71. package/dist/runtime-B-Fyrmxo.js +8 -0
  72. package/dist/runtime-api-BYXXkxq2.js +24 -0
  73. package/dist/runtime-api.js +25 -0
  74. package/dist/runtime-heavy-api.js +3 -0
  75. package/dist/runtime-lwTSy9Yt.js +6 -0
  76. package/dist/runtime-setter-api.js +2 -0
  77. package/dist/sdk-Jhq7mLtD.js +1704 -0
  78. package/dist/secret-contract-DEMcDsjl.js +120 -0
  79. package/dist/secret-contract-api.js +2 -0
  80. package/dist/send-CJunc6QM.js +1517 -0
  81. package/dist/setup-bootstrap-rJ0qZWPe.js +62 -0
  82. package/dist/setup-core-BEYoXF3J.js +677 -0
  83. package/dist/setup-entry.js +19 -0
  84. package/dist/setup-plugin-api.js +43 -0
  85. package/dist/setup-surface-c28ON6jq.js +537 -0
  86. package/dist/shared-D6MFMnpG.js +642 -0
  87. package/dist/startup-abort-B2J3MU_h.js +109 -0
  88. package/dist/startup-verification-CkD4Cwce.js +132 -0
  89. package/dist/storage-nyO0DOFE.js +281 -0
  90. package/dist/storage-paths-BTAketfg.js +52 -0
  91. package/dist/subagent-hooks-api-Dr_xnMRG.js +170 -0
  92. package/dist/subagent-hooks-api.js +2 -0
  93. package/dist/sync-state-Bx0gPaGA.js +12 -0
  94. package/dist/target-ids-Bsazo8si.js +77 -0
  95. package/dist/test-api.js +4 -0
  96. package/dist/thread-binding-api-IGU0-L70.js +17 -0
  97. package/dist/thread-binding-api.js +2 -0
  98. package/dist/thread-bindings-FjAZmDUP.js +352 -0
  99. package/dist/thread-bindings-runtime.js +2 -0
  100. package/dist/thread-bindings-shared-fvfP7jVs.js +97 -0
  101. package/dist/timeout-abort-signal-DpSHDHhR.js +2 -0
  102. package/dist/tool-actions.runtime-Cbo7YcYZ.js +532 -0
  103. package/dist/url-validation-DlrXNjAE.js +36 -0
  104. package/dist/verification-7tDPRpJU.js +345 -0
  105. package/doctor-contract-api.ts +1 -0
  106. package/helper-api.ts +3 -0
  107. package/index.ts +55 -0
  108. package/klaw.plugin.json +3 -891
  109. package/package.json +4 -4
  110. package/plugin-entry.handlers.runtime.ts +1 -0
  111. package/runtime-api.ts +72 -0
  112. package/runtime-heavy-api.ts +1 -0
  113. package/runtime-setter-api.ts +3 -0
  114. package/secret-contract-api.ts +5 -0
  115. package/setup-entry.ts +17 -0
  116. package/setup-plugin-api.ts +3 -0
  117. package/src/account-selection.ts +223 -0
  118. package/src/actions.ts +346 -0
  119. package/src/approval-auth.ts +25 -0
  120. package/src/approval-handler.runtime.ts +592 -0
  121. package/src/approval-ids.ts +6 -0
  122. package/src/approval-native.ts +345 -0
  123. package/src/approval-reaction-auth.ts +45 -0
  124. package/src/approval-reactions.ts +313 -0
  125. package/src/auth-precedence.ts +61 -0
  126. package/src/channel-account-paths.ts +97 -0
  127. package/src/channel.runtime.ts +17 -0
  128. package/src/channel.setup.ts +48 -0
  129. package/src/channel.ts +667 -0
  130. package/src/cli-metadata.ts +19 -0
  131. package/src/cli.ts +2298 -0
  132. package/src/config-adapter.ts +41 -0
  133. package/src/config-schema.ts +159 -0
  134. package/src/config-ui-hints.ts +56 -0
  135. package/src/directory-live.ts +238 -0
  136. package/src/doctor-contract.ts +287 -0
  137. package/src/doctor.ts +262 -0
  138. package/src/env-vars.ts +92 -0
  139. package/src/exec-approval-resolver.ts +23 -0
  140. package/src/exec-approvals.ts +287 -0
  141. package/src/group-mentions.ts +41 -0
  142. package/src/legacy-crypto-inspector-availability.ts +60 -0
  143. package/src/legacy-crypto.ts +531 -0
  144. package/src/legacy-state.ts +156 -0
  145. package/src/matrix/account-config.ts +175 -0
  146. package/src/matrix/accounts.ts +194 -0
  147. package/src/matrix/actions/client.ts +31 -0
  148. package/src/matrix/actions/devices.ts +34 -0
  149. package/src/matrix/actions/limits.ts +6 -0
  150. package/src/matrix/actions/messages.ts +129 -0
  151. package/src/matrix/actions/pins.ts +63 -0
  152. package/src/matrix/actions/polls.ts +109 -0
  153. package/src/matrix/actions/profile.ts +37 -0
  154. package/src/matrix/actions/reactions.ts +59 -0
  155. package/src/matrix/actions/room.ts +71 -0
  156. package/src/matrix/actions/summary.ts +88 -0
  157. package/src/matrix/actions/types.ts +63 -0
  158. package/src/matrix/actions/verification.ts +589 -0
  159. package/src/matrix/actions.ts +37 -0
  160. package/src/matrix/active-client.ts +26 -0
  161. package/src/matrix/async-lock.ts +18 -0
  162. package/src/matrix/backup-health.ts +124 -0
  163. package/src/matrix/client/config-runtime-api.ts +9 -0
  164. package/src/matrix/client/config-secret-input.runtime.ts +1 -0
  165. package/src/matrix/client/config.ts +853 -0
  166. package/src/matrix/client/create-client.ts +105 -0
  167. package/src/matrix/client/env-auth.ts +95 -0
  168. package/src/matrix/client/file-sync-store.ts +289 -0
  169. package/src/matrix/client/logging.ts +140 -0
  170. package/src/matrix/client/migration-snapshot.runtime.ts +1 -0
  171. package/src/matrix/client/private-network-host.ts +1 -0
  172. package/src/matrix/client/runtime.ts +4 -0
  173. package/src/matrix/client/shared.ts +316 -0
  174. package/src/matrix/client/storage.ts +543 -0
  175. package/src/matrix/client/types.ts +50 -0
  176. package/src/matrix/client/url-validation.ts +73 -0
  177. package/src/matrix/client-bootstrap.ts +173 -0
  178. package/src/matrix/client.ts +23 -0
  179. package/src/matrix/config-paths.ts +31 -0
  180. package/src/matrix/config-update.ts +292 -0
  181. package/src/matrix/credentials-read.ts +208 -0
  182. package/src/matrix/credentials-write.runtime.ts +35 -0
  183. package/src/matrix/credentials.ts +95 -0
  184. package/src/matrix/deps.ts +309 -0
  185. package/src/matrix/device-health.ts +29 -0
  186. package/src/matrix/direct-management.ts +349 -0
  187. package/src/matrix/direct-room.ts +128 -0
  188. package/src/matrix/draft-stream.ts +225 -0
  189. package/src/matrix/encryption-guidance.ts +24 -0
  190. package/src/matrix/errors.ts +21 -0
  191. package/src/matrix/format.ts +426 -0
  192. package/src/matrix/legacy-crypto-inspector.ts +95 -0
  193. package/src/matrix/media-errors.ts +20 -0
  194. package/src/matrix/media-text.ts +162 -0
  195. package/src/matrix/monitor/access-state.ts +145 -0
  196. package/src/matrix/monitor/ack-config.ts +27 -0
  197. package/src/matrix/monitor/allowlist.ts +89 -0
  198. package/src/matrix/monitor/auto-join.ts +86 -0
  199. package/src/matrix/monitor/config.ts +569 -0
  200. package/src/matrix/monitor/context-summary.ts +43 -0
  201. package/src/matrix/monitor/direct.ts +296 -0
  202. package/src/matrix/monitor/events.ts +397 -0
  203. package/src/matrix/monitor/handler.ts +2266 -0
  204. package/src/matrix/monitor/inbound-dedupe.ts +267 -0
  205. package/src/matrix/monitor/index.ts +540 -0
  206. package/src/matrix/monitor/legacy-crypto-restore.ts +139 -0
  207. package/src/matrix/monitor/location.ts +108 -0
  208. package/src/matrix/monitor/media.ts +119 -0
  209. package/src/matrix/monitor/mentions.ts +256 -0
  210. package/src/matrix/monitor/reaction-events.ts +197 -0
  211. package/src/matrix/monitor/recent-invite.ts +30 -0
  212. package/src/matrix/monitor/replies.ts +136 -0
  213. package/src/matrix/monitor/reply-context.ts +92 -0
  214. package/src/matrix/monitor/room-history.ts +301 -0
  215. package/src/matrix/monitor/room-info.ts +126 -0
  216. package/src/matrix/monitor/rooms.ts +52 -0
  217. package/src/matrix/monitor/route.ts +179 -0
  218. package/src/matrix/monitor/runtime-api.ts +28 -0
  219. package/src/matrix/monitor/startup-verification.ts +237 -0
  220. package/src/matrix/monitor/startup.ts +218 -0
  221. package/src/matrix/monitor/status.ts +120 -0
  222. package/src/matrix/monitor/sync-lifecycle.ts +91 -0
  223. package/src/matrix/monitor/task-runner.ts +38 -0
  224. package/src/matrix/monitor/test-events.ts +21 -0
  225. package/src/matrix/monitor/thread-context.ts +108 -0
  226. package/src/matrix/monitor/threads.ts +85 -0
  227. package/src/matrix/monitor/types.ts +30 -0
  228. package/src/matrix/monitor/verification-events.ts +643 -0
  229. package/src/matrix/monitor/verification-utils.ts +46 -0
  230. package/src/matrix/outbound-media-runtime.ts +1 -0
  231. package/src/matrix/poll-summary.ts +110 -0
  232. package/src/matrix/poll-types.ts +429 -0
  233. package/src/matrix/probe.runtime.ts +4 -0
  234. package/src/matrix/probe.ts +97 -0
  235. package/src/matrix/profile.ts +184 -0
  236. package/src/matrix/reaction-common.ts +147 -0
  237. package/src/matrix/sdk/crypto-bootstrap.ts +438 -0
  238. package/src/matrix/sdk/crypto-facade.ts +242 -0
  239. package/src/matrix/sdk/crypto-node.runtime.ts +17 -0
  240. package/src/matrix/sdk/crypto-runtime.ts +14 -0
  241. package/src/matrix/sdk/decrypt-bridge.ts +410 -0
  242. package/src/matrix/sdk/event-helpers.ts +83 -0
  243. package/src/matrix/sdk/http-client.ts +87 -0
  244. package/src/matrix/sdk/idb-persistence-lock.ts +51 -0
  245. package/src/matrix/sdk/idb-persistence.ts +288 -0
  246. package/src/matrix/sdk/logger.ts +108 -0
  247. package/src/matrix/sdk/read-response-with-limit.ts +19 -0
  248. package/src/matrix/sdk/recovery-key-store.ts +453 -0
  249. package/src/matrix/sdk/timeout-abort-signal.ts +1 -0
  250. package/src/matrix/sdk/transport-runtime-api.ts +18 -0
  251. package/src/matrix/sdk/transport.ts +352 -0
  252. package/src/matrix/sdk/types.ts +245 -0
  253. package/src/matrix/sdk/verification-manager.ts +795 -0
  254. package/src/matrix/sdk/verification-status.ts +23 -0
  255. package/src/matrix/sdk.ts +2152 -0
  256. package/src/matrix/send/client.ts +93 -0
  257. package/src/matrix/send/formatting.ts +189 -0
  258. package/src/matrix/send/media.ts +244 -0
  259. package/src/matrix/send/targets.ts +104 -0
  260. package/src/matrix/send/types.ts +131 -0
  261. package/src/matrix/send.ts +660 -0
  262. package/src/matrix/session-store-metadata.ts +108 -0
  263. package/src/matrix/startup-abort.ts +44 -0
  264. package/src/matrix/subagent-hooks.ts +308 -0
  265. package/src/matrix/sync-state.ts +27 -0
  266. package/src/matrix/target-ids.ts +79 -0
  267. package/src/matrix/thread-bindings-shared.ts +206 -0
  268. package/src/matrix/thread-bindings.ts +580 -0
  269. package/src/matrix-migration.runtime.ts +9 -0
  270. package/src/migration-config.ts +243 -0
  271. package/src/migration-snapshot-backup.ts +116 -0
  272. package/src/migration-snapshot.ts +53 -0
  273. package/src/onboarding.ts +775 -0
  274. package/src/outbound.ts +248 -0
  275. package/src/plugin-entry.runtime.js +115 -0
  276. package/src/plugin-entry.runtime.ts +70 -0
  277. package/src/profile-update.ts +71 -0
  278. package/src/record-shared.ts +3 -0
  279. package/src/resolve-targets.ts +175 -0
  280. package/src/resolver.runtime.ts +5 -0
  281. package/src/resolver.ts +21 -0
  282. package/src/runtime-api.ts +106 -0
  283. package/src/runtime.ts +13 -0
  284. package/src/secret-contract.ts +174 -0
  285. package/src/session-route.ts +126 -0
  286. package/src/setup-bootstrap.ts +102 -0
  287. package/src/setup-config.ts +222 -0
  288. package/src/setup-contract.ts +90 -0
  289. package/src/setup-core.ts +146 -0
  290. package/src/setup-dm-policy.ts +15 -0
  291. package/src/setup-surface.ts +4 -0
  292. package/src/startup-maintenance.ts +114 -0
  293. package/src/storage-paths.ts +92 -0
  294. package/src/thread-binding-api.ts +23 -0
  295. package/src/tool-actions.runtime.ts +1 -0
  296. package/src/tool-actions.ts +498 -0
  297. package/src/types.ts +257 -0
  298. package/subagent-hooks-api.ts +31 -0
  299. package/test-api.ts +21 -0
  300. package/thread-binding-api.ts +4 -0
  301. package/thread-bindings-runtime.ts +4 -0
  302. package/tsconfig.json +16 -0
  303. package/api.js +0 -7
  304. package/auth-presence.js +0 -7
  305. package/channel-plugin-api.js +0 -7
  306. package/cli-metadata.js +0 -7
  307. package/contract-api.js +0 -7
  308. package/doctor-contract-api.js +0 -7
  309. package/helper-api.js +0 -7
  310. package/index.js +0 -7
  311. package/plugin-entry.handlers.runtime.js +0 -7
  312. package/runtime-api.js +0 -7
  313. package/runtime-heavy-api.js +0 -7
  314. package/runtime-setter-api.js +0 -7
  315. package/secret-contract-api.js +0 -7
  316. package/setup-entry.js +0 -7
  317. package/setup-plugin-api.js +0 -7
  318. package/subagent-hooks-api.js +0 -7
  319. package/test-api.js +0 -7
  320. package/thread-binding-api.js +0 -7
  321. package/thread-bindings-runtime.js +0 -7
@@ -0,0 +1,525 @@
1
+ import { a as resolveMatrixDefaultOrOnlyAccountId, i as resolveMatrixChannelConfig, n as requiresExplicitMatrixDefaultAccount, o as resolveMatrixAccountStringValues, r as resolveConfiguredMatrixAccountIds, t as findMatrixAccountEntry } from "./account-selection-Y50DNJ2l.js";
2
+ import { i as resolveScopedMatrixEnvConfig, n as resolveGlobalMatrixEnvConfig } from "./env-auth-UFiTGkDM.js";
3
+ import { a as resolveMatrixCredentialsPath, n as resolveMatrixAccountStorageRoot, s as resolveMatrixLegacyFlatStoragePaths } from "./storage-paths-BTAketfg.js";
4
+ import { t as formatMatrixErrorMessage } from "./errors-BETj3zr9.js";
5
+ import "./migration-snapshot-backup-BR-xD7Ew.js";
6
+ import { DEFAULT_ACCOUNT_ID, normalizeAccountId } from "klaw/plugin-sdk/account-id";
7
+ import { normalizeOptionalString } from "klaw/plugin-sdk/string-coerce-runtime";
8
+ import fs from "node:fs";
9
+ import os from "node:os";
10
+ import path from "node:path";
11
+ import { resolveStateDir } from "klaw/plugin-sdk/state-paths";
12
+ import { loadJsonFile, writeJsonFileAtomically } from "klaw/plugin-sdk/json-store";
13
+ import { fileURLToPath } from "node:url";
14
+ //#region extensions/matrix/src/migration-config.ts
15
+ function clean(value) {
16
+ return normalizeOptionalString(value) ?? "";
17
+ }
18
+ function resolveMatrixAccountConfigEntry(cfg, accountId) {
19
+ return findMatrixAccountEntry(cfg, accountId);
20
+ }
21
+ function resolveMatrixFlatStoreSelectionNote(cfg, accountId) {
22
+ if (resolveConfiguredMatrixAccountIds(cfg).length <= 1) return;
23
+ return `Legacy Matrix flat store uses one shared on-disk state, so it will be migrated into account "${accountId}".`;
24
+ }
25
+ function resolveMatrixMigrationConfigFields(params) {
26
+ const channel = resolveMatrixChannelConfig(params.cfg);
27
+ const account = resolveMatrixAccountConfigEntry(params.cfg, params.accountId);
28
+ const scopedEnv = resolveScopedMatrixEnvConfig(params.accountId, params.env);
29
+ const globalEnv = resolveGlobalMatrixEnvConfig(params.env);
30
+ const resolvedStrings = resolveMatrixAccountStringValues({
31
+ accountId: normalizeAccountId(params.accountId),
32
+ account: {
33
+ homeserver: clean(account?.homeserver),
34
+ userId: clean(account?.userId),
35
+ accessToken: clean(account?.accessToken)
36
+ },
37
+ scopedEnv,
38
+ channel: {
39
+ homeserver: clean(channel?.homeserver),
40
+ userId: clean(channel?.userId),
41
+ accessToken: clean(channel?.accessToken)
42
+ },
43
+ globalEnv
44
+ });
45
+ return {
46
+ homeserver: resolvedStrings.homeserver,
47
+ userId: resolvedStrings.userId,
48
+ accessToken: resolvedStrings.accessToken
49
+ };
50
+ }
51
+ function loadStoredMatrixCredentials(env, accountId) {
52
+ const credentialsPath = resolveMatrixCredentialsPath({
53
+ stateDir: resolveStateDir(env, os.homedir),
54
+ accountId: normalizeAccountId(accountId)
55
+ });
56
+ try {
57
+ if (!fs.existsSync(credentialsPath)) return null;
58
+ const parsed = JSON.parse(fs.readFileSync(credentialsPath, "utf8"));
59
+ if (typeof parsed.homeserver !== "string" || typeof parsed.userId !== "string" || typeof parsed.accessToken !== "string") return null;
60
+ return {
61
+ homeserver: parsed.homeserver,
62
+ userId: parsed.userId,
63
+ accessToken: parsed.accessToken,
64
+ deviceId: typeof parsed.deviceId === "string" ? parsed.deviceId : void 0
65
+ };
66
+ } catch {
67
+ return null;
68
+ }
69
+ }
70
+ function credentialsMatchResolvedIdentity(stored, identity) {
71
+ if (!stored || !identity.homeserver) return false;
72
+ if (!identity.userId) {
73
+ if (!identity.accessToken) return false;
74
+ return stored.homeserver === identity.homeserver && stored.accessToken === identity.accessToken;
75
+ }
76
+ return stored.homeserver === identity.homeserver && stored.userId === identity.userId;
77
+ }
78
+ function resolveMatrixMigrationAccountTarget(params) {
79
+ const stored = loadStoredMatrixCredentials(params.env, params.accountId);
80
+ const resolved = resolveMatrixMigrationConfigFields(params);
81
+ const matchingStored = credentialsMatchResolvedIdentity(stored, {
82
+ homeserver: resolved.homeserver,
83
+ userId: resolved.userId,
84
+ accessToken: resolved.accessToken
85
+ }) ? stored : null;
86
+ const homeserver = resolved.homeserver;
87
+ const userId = resolved.userId || matchingStored?.userId || "";
88
+ const accessToken = resolved.accessToken || matchingStored?.accessToken || "";
89
+ if (!homeserver || !userId || !accessToken) return null;
90
+ const { rootDir } = resolveMatrixAccountStorageRoot({
91
+ stateDir: resolveStateDir(params.env, os.homedir),
92
+ homeserver,
93
+ userId,
94
+ accessToken,
95
+ accountId: params.accountId
96
+ });
97
+ return {
98
+ accountId: params.accountId,
99
+ homeserver,
100
+ userId,
101
+ accessToken,
102
+ rootDir,
103
+ storedDeviceId: matchingStored?.deviceId ?? null
104
+ };
105
+ }
106
+ function resolveLegacyMatrixFlatStoreTarget(params) {
107
+ if (!resolveMatrixChannelConfig(params.cfg)) return { warning: `Legacy Matrix ${params.detectedKind} detected at ${params.detectedPath}, but channels.matrix is not configured yet. Configure Matrix, then rerun "klaw doctor --fix" or restart the gateway.` };
108
+ if (requiresExplicitMatrixDefaultAccount(params.cfg)) return { warning: `Legacy Matrix ${params.detectedKind} detected at ${params.detectedPath}, but multiple Matrix accounts are configured and channels.matrix.defaultAccount is not set. Set "channels.matrix.defaultAccount" to the intended target account before rerunning "klaw doctor --fix" or restarting the gateway.` };
109
+ const accountId = resolveMatrixDefaultOrOnlyAccountId(params.cfg);
110
+ const target = resolveMatrixMigrationAccountTarget({
111
+ cfg: params.cfg,
112
+ env: params.env,
113
+ accountId
114
+ });
115
+ if (!target) {
116
+ const targetDescription = params.detectedKind === "state" ? "the new account-scoped target" : "the account-scoped target";
117
+ return { warning: `Legacy Matrix ${params.detectedKind} detected at ${params.detectedPath}, but ${targetDescription} could not be resolved yet (need homeserver, userId, and access token for channels.matrix${accountId === DEFAULT_ACCOUNT_ID ? "" : `.accounts.${accountId}`}). Start the gateway once with a working Matrix login, or rerun "klaw doctor --fix" after cached credentials are available.` };
118
+ }
119
+ return {
120
+ ...target,
121
+ selectionNote: resolveMatrixFlatStoreSelectionNote(params.cfg, accountId)
122
+ };
123
+ }
124
+ //#endregion
125
+ //#region extensions/matrix/src/legacy-state.ts
126
+ function resolveLegacyMatrixPaths(env) {
127
+ return resolveMatrixLegacyFlatStoragePaths(resolveStateDir(env, os.homedir));
128
+ }
129
+ function resolveMatrixMigrationPlan(params) {
130
+ const legacy = resolveLegacyMatrixPaths(params.env);
131
+ if (!fs.existsSync(legacy.storagePath) && !fs.existsSync(legacy.cryptoPath)) return null;
132
+ const target = resolveLegacyMatrixFlatStoreTarget({
133
+ cfg: params.cfg,
134
+ env: params.env,
135
+ detectedPath: legacy.rootDir,
136
+ detectedKind: "state"
137
+ });
138
+ if ("warning" in target) return target;
139
+ return {
140
+ accountId: target.accountId,
141
+ legacyStoragePath: legacy.storagePath,
142
+ legacyCryptoPath: legacy.cryptoPath,
143
+ targetRootDir: target.rootDir,
144
+ targetStoragePath: path.join(target.rootDir, "bot-storage.json"),
145
+ targetCryptoPath: path.join(target.rootDir, "crypto"),
146
+ selectionNote: target.selectionNote
147
+ };
148
+ }
149
+ function detectLegacyMatrixState(params) {
150
+ return resolveMatrixMigrationPlan({
151
+ cfg: params.cfg,
152
+ env: params.env ?? process.env
153
+ });
154
+ }
155
+ function moveLegacyPath(params) {
156
+ if (!fs.existsSync(params.sourcePath)) return;
157
+ if (fs.existsSync(params.targetPath)) {
158
+ params.warnings.push(`Matrix legacy ${params.label} not migrated because the target already exists (${params.targetPath}).`);
159
+ return;
160
+ }
161
+ try {
162
+ fs.mkdirSync(path.dirname(params.targetPath), { recursive: true });
163
+ fs.renameSync(params.sourcePath, params.targetPath);
164
+ params.changes.push(`Migrated Matrix legacy ${params.label}: ${params.sourcePath} -> ${params.targetPath}`);
165
+ } catch (err) {
166
+ params.warnings.push(`Failed migrating Matrix legacy ${params.label} (${params.sourcePath} -> ${params.targetPath}): ${String(err)}`);
167
+ }
168
+ }
169
+ async function autoMigrateLegacyMatrixState(params) {
170
+ const env = params.env ?? process.env;
171
+ const detection = detectLegacyMatrixState({
172
+ cfg: params.cfg,
173
+ env
174
+ });
175
+ if (!detection) return {
176
+ migrated: false,
177
+ changes: [],
178
+ warnings: []
179
+ };
180
+ if ("warning" in detection) {
181
+ params.log?.warn?.(`matrix: ${detection.warning}`);
182
+ return {
183
+ migrated: false,
184
+ changes: [],
185
+ warnings: [detection.warning]
186
+ };
187
+ }
188
+ const changes = [];
189
+ const warnings = [];
190
+ moveLegacyPath({
191
+ sourcePath: detection.legacyStoragePath,
192
+ targetPath: detection.targetStoragePath,
193
+ label: "sync store",
194
+ changes,
195
+ warnings
196
+ });
197
+ moveLegacyPath({
198
+ sourcePath: detection.legacyCryptoPath,
199
+ targetPath: detection.targetCryptoPath,
200
+ label: "crypto store",
201
+ changes,
202
+ warnings
203
+ });
204
+ if (changes.length > 0) {
205
+ const details = [
206
+ ...changes.map((entry) => `- ${entry}`),
207
+ ...detection.selectionNote ? [`- ${detection.selectionNote}`] : [],
208
+ "- No user action required."
209
+ ];
210
+ params.log?.info?.(`matrix: plugin upgraded in place for account "${detection.accountId}".\n${details.join("\n")}`);
211
+ }
212
+ if (warnings.length > 0) params.log?.warn?.(`matrix: legacy state migration warnings:\n${warnings.map((entry) => `- ${entry}`).join("\n")}`);
213
+ return {
214
+ migrated: changes.length > 0,
215
+ changes,
216
+ warnings
217
+ };
218
+ }
219
+ //#endregion
220
+ //#region extensions/matrix/src/legacy-crypto-inspector-availability.ts
221
+ const LEGACY_CRYPTO_INSPECTOR_FILE = "legacy-crypto-inspector.js";
222
+ const LEGACY_CRYPTO_INSPECTOR_CHUNK_PREFIX = "legacy-crypto-inspector-";
223
+ const LEGACY_CRYPTO_INSPECTOR_HELPER_CHUNK_PREFIX = "availability-";
224
+ const JAVASCRIPT_MODULE_SUFFIX = ".js";
225
+ function isLegacyCryptoInspectorArtifactName(name) {
226
+ if (name === LEGACY_CRYPTO_INSPECTOR_FILE) return true;
227
+ if (!name.startsWith(LEGACY_CRYPTO_INSPECTOR_CHUNK_PREFIX) || !name.endsWith(JAVASCRIPT_MODULE_SUFFIX)) return false;
228
+ const chunkSuffix = name.slice(24, -3);
229
+ return chunkSuffix.length > 0 && chunkSuffix !== "availability" && !chunkSuffix.startsWith(LEGACY_CRYPTO_INSPECTOR_HELPER_CHUNK_PREFIX);
230
+ }
231
+ function hasSourceInspectorArtifact(currentDir) {
232
+ return [path.resolve(currentDir, "matrix", "legacy-crypto-inspector.ts"), path.resolve(currentDir, "matrix", "legacy-crypto-inspector.js")].some((candidate) => fs.existsSync(candidate));
233
+ }
234
+ function hasBuiltInspectorArtifact(currentDir) {
235
+ if (fs.existsSync(path.join(currentDir, "legacy-crypto-inspector.js"))) return true;
236
+ if (fs.existsSync(path.join(currentDir, "extensions", "matrix", "legacy-crypto-inspector.js"))) return true;
237
+ return fs.readdirSync(currentDir, { withFileTypes: true }).some((entry) => entry.isFile() && isLegacyCryptoInspectorArtifactName(entry.name));
238
+ }
239
+ function isMatrixLegacyCryptoInspectorAvailable() {
240
+ const currentDir = path.dirname(fileURLToPath(import.meta.url));
241
+ if (hasSourceInspectorArtifact(currentDir)) return true;
242
+ try {
243
+ return hasBuiltInspectorArtifact(currentDir);
244
+ } catch {
245
+ return false;
246
+ }
247
+ }
248
+ //#endregion
249
+ //#region extensions/matrix/src/legacy-crypto.ts
250
+ const MATRIX_LEGACY_CRYPTO_INSPECTOR_UNAVAILABLE_MESSAGE = "Legacy Matrix encrypted state was detected, but the Matrix crypto inspector is unavailable.";
251
+ async function loadMatrixLegacyCryptoInspector() {
252
+ return (await import("./legacy-crypto-inspector-zK0hDCbt.js")).inspectLegacyMatrixCryptoStore;
253
+ }
254
+ function detectLegacyBotSdkCryptoStore(cryptoRootDir) {
255
+ try {
256
+ if (!fs.statSync(cryptoRootDir).isDirectory()) return {
257
+ detected: false,
258
+ warning: `Legacy Matrix encrypted state path exists but is not a directory: ${cryptoRootDir}. Klaw skipped automatic crypto migration for that path.`
259
+ };
260
+ } catch (err) {
261
+ return {
262
+ detected: false,
263
+ warning: `Failed reading legacy Matrix encrypted state path (${cryptoRootDir}): ${String(err)}. Klaw skipped automatic crypto migration for that path.`
264
+ };
265
+ }
266
+ try {
267
+ return { detected: fs.existsSync(path.join(cryptoRootDir, "bot-sdk.json")) || fs.existsSync(path.join(cryptoRootDir, "matrix-sdk-crypto.sqlite3")) || fs.readdirSync(cryptoRootDir, { withFileTypes: true }).some((entry) => entry.isDirectory() && fs.existsSync(path.join(cryptoRootDir, entry.name, "matrix-sdk-crypto.sqlite3"))) };
268
+ } catch (err) {
269
+ return {
270
+ detected: false,
271
+ warning: `Failed scanning legacy Matrix encrypted state path (${cryptoRootDir}): ${String(err)}. Klaw skipped automatic crypto migration for that path.`
272
+ };
273
+ }
274
+ }
275
+ function resolveMatrixAccountIds(cfg) {
276
+ return resolveConfiguredMatrixAccountIds(cfg);
277
+ }
278
+ function resolveLegacyMatrixFlatStorePlan(params) {
279
+ const legacy = resolveMatrixLegacyFlatStoragePaths(resolveStateDir(params.env, os.homedir));
280
+ if (!fs.existsSync(legacy.cryptoPath)) return null;
281
+ const legacyStore = detectLegacyBotSdkCryptoStore(legacy.cryptoPath);
282
+ if (legacyStore.warning) return { warning: legacyStore.warning };
283
+ if (!legacyStore.detected) return null;
284
+ const target = resolveLegacyMatrixFlatStoreTarget({
285
+ cfg: params.cfg,
286
+ env: params.env,
287
+ detectedPath: legacy.cryptoPath,
288
+ detectedKind: "encrypted state"
289
+ });
290
+ if ("warning" in target) return target;
291
+ const metadata = loadLegacyBotSdkMetadata(legacy.cryptoPath);
292
+ return {
293
+ accountId: target.accountId,
294
+ rootDir: target.rootDir,
295
+ recoveryKeyPath: path.join(target.rootDir, "recovery-key.json"),
296
+ statePath: path.join(target.rootDir, "legacy-crypto-migration.json"),
297
+ legacyCryptoPath: legacy.cryptoPath,
298
+ homeserver: target.homeserver,
299
+ userId: target.userId,
300
+ accessToken: target.accessToken,
301
+ deviceId: metadata.deviceId ?? target.storedDeviceId
302
+ };
303
+ }
304
+ function loadLegacyBotSdkMetadata(cryptoRootDir) {
305
+ const metadataPath = path.join(cryptoRootDir, "bot-sdk.json");
306
+ const fallback = { deviceId: null };
307
+ const parsed = loadJsonFile(metadataPath);
308
+ return { deviceId: typeof parsed?.deviceId === "string" && parsed.deviceId.trim() ? parsed.deviceId : fallback.deviceId };
309
+ }
310
+ function resolveMatrixLegacyCryptoPlans(params) {
311
+ const warnings = [];
312
+ const plans = [];
313
+ const flatPlan = resolveLegacyMatrixFlatStorePlan(params);
314
+ if (flatPlan) if ("warning" in flatPlan) warnings.push(flatPlan.warning);
315
+ else plans.push(flatPlan);
316
+ for (const accountId of resolveMatrixAccountIds(params.cfg)) {
317
+ const target = resolveMatrixMigrationAccountTarget({
318
+ cfg: params.cfg,
319
+ env: params.env,
320
+ accountId
321
+ });
322
+ if (!target) continue;
323
+ const legacyCryptoPath = path.join(target.rootDir, "crypto");
324
+ if (!fs.existsSync(legacyCryptoPath)) continue;
325
+ const detectedStore = detectLegacyBotSdkCryptoStore(legacyCryptoPath);
326
+ if (detectedStore.warning) {
327
+ warnings.push(detectedStore.warning);
328
+ continue;
329
+ }
330
+ if (!detectedStore.detected) continue;
331
+ if (plans.some((plan) => plan.accountId === accountId && path.resolve(plan.legacyCryptoPath) === path.resolve(legacyCryptoPath))) continue;
332
+ const metadata = loadLegacyBotSdkMetadata(legacyCryptoPath);
333
+ plans.push({
334
+ accountId: target.accountId,
335
+ rootDir: target.rootDir,
336
+ recoveryKeyPath: path.join(target.rootDir, "recovery-key.json"),
337
+ statePath: path.join(target.rootDir, "legacy-crypto-migration.json"),
338
+ legacyCryptoPath,
339
+ homeserver: target.homeserver,
340
+ userId: target.userId,
341
+ accessToken: target.accessToken,
342
+ deviceId: metadata.deviceId ?? target.storedDeviceId
343
+ });
344
+ }
345
+ return {
346
+ plans,
347
+ warnings
348
+ };
349
+ }
350
+ function loadStoredRecoveryKey(filePath) {
351
+ return loadJsonFile(filePath) ?? null;
352
+ }
353
+ function loadLegacyCryptoMigrationState(filePath) {
354
+ return loadJsonFile(filePath) ?? null;
355
+ }
356
+ async function persistLegacyMigrationState(params) {
357
+ await params.writeJsonFileAtomically(params.filePath, params.state);
358
+ }
359
+ function detectLegacyMatrixCrypto(params) {
360
+ const detection = resolveMatrixLegacyCryptoPlans({
361
+ cfg: params.cfg,
362
+ env: params.env ?? process.env
363
+ });
364
+ const inspectorAvailable = detection.plans.length === 0 || isMatrixLegacyCryptoInspectorAvailable();
365
+ if (!inspectorAvailable && detection.plans.length > 0) return {
366
+ inspectorAvailable,
367
+ plans: detection.plans,
368
+ warnings: [...detection.warnings, MATRIX_LEGACY_CRYPTO_INSPECTOR_UNAVAILABLE_MESSAGE]
369
+ };
370
+ return {
371
+ inspectorAvailable,
372
+ plans: detection.plans,
373
+ warnings: detection.warnings
374
+ };
375
+ }
376
+ async function autoPrepareLegacyMatrixCrypto(params) {
377
+ const env = params.env ?? process.env;
378
+ const detection = params.deps?.inspectLegacyStore ? resolveMatrixLegacyCryptoPlans({
379
+ cfg: params.cfg,
380
+ env
381
+ }) : detectLegacyMatrixCrypto({
382
+ cfg: params.cfg,
383
+ env
384
+ });
385
+ const inspectorAvailable = "inspectorAvailable" in detection ? detection.inspectorAvailable : true;
386
+ const warnings = [...detection.warnings];
387
+ const changes = [];
388
+ const writeJsonFileAtomically$1 = params.deps?.writeJsonFileAtomically ?? writeJsonFileAtomically;
389
+ if (detection.plans.length === 0) {
390
+ if (warnings.length > 0) params.log?.warn?.(`matrix: legacy encrypted-state warnings:\n${warnings.map((entry) => `- ${entry}`).join("\n")}`);
391
+ return {
392
+ migrated: false,
393
+ changes,
394
+ warnings
395
+ };
396
+ }
397
+ if (!params.deps?.inspectLegacyStore && !inspectorAvailable) {
398
+ if (warnings.length > 0) params.log?.warn?.(`matrix: legacy encrypted-state warnings:\n${warnings.map((entry) => `- ${entry}`).join("\n")}`);
399
+ return {
400
+ migrated: false,
401
+ changes,
402
+ warnings
403
+ };
404
+ }
405
+ let inspectLegacyStore = params.deps?.inspectLegacyStore;
406
+ if (!inspectLegacyStore) try {
407
+ inspectLegacyStore = await loadMatrixLegacyCryptoInspector();
408
+ } catch (err) {
409
+ const message = formatMatrixErrorMessage(err);
410
+ if (!warnings.includes(message)) warnings.push(message);
411
+ if (warnings.length > 0) params.log?.warn?.(`matrix: legacy encrypted-state warnings:\n${warnings.map((entry) => `- ${entry}`).join("\n")}`);
412
+ return {
413
+ migrated: false,
414
+ changes,
415
+ warnings
416
+ };
417
+ }
418
+ if (!inspectLegacyStore) return {
419
+ migrated: false,
420
+ changes,
421
+ warnings
422
+ };
423
+ for (const plan of detection.plans) {
424
+ if (loadLegacyCryptoMigrationState(plan.statePath)?.version === 1) continue;
425
+ if (!plan.deviceId) {
426
+ warnings.push(`Legacy Matrix encrypted state detected at ${plan.legacyCryptoPath}, but no device ID was found for account "${plan.accountId}". Klaw will continue, but old encrypted history cannot be recovered automatically.`);
427
+ continue;
428
+ }
429
+ let summary;
430
+ try {
431
+ summary = await inspectLegacyStore({
432
+ cryptoRootDir: plan.legacyCryptoPath,
433
+ userId: plan.userId,
434
+ deviceId: plan.deviceId,
435
+ log: params.log?.info
436
+ });
437
+ } catch (err) {
438
+ warnings.push(`Failed inspecting legacy Matrix encrypted state for account "${plan.accountId}" (${plan.legacyCryptoPath}): ${String(err)}`);
439
+ continue;
440
+ }
441
+ let decryptionKeyImported = false;
442
+ if (summary.decryptionKeyBase64) {
443
+ const existingRecoveryKey = loadStoredRecoveryKey(plan.recoveryKeyPath);
444
+ if (existingRecoveryKey?.privateKeyBase64 && existingRecoveryKey.privateKeyBase64 !== summary.decryptionKeyBase64) warnings.push(`Legacy Matrix backup key was found for account "${plan.accountId}", but ${plan.recoveryKeyPath} already contains a different recovery key. Leaving the existing file unchanged.`);
445
+ else if (!existingRecoveryKey?.privateKeyBase64) {
446
+ const payload = {
447
+ version: 1,
448
+ createdAt: (/* @__PURE__ */ new Date()).toISOString(),
449
+ keyId: null,
450
+ privateKeyBase64: summary.decryptionKeyBase64
451
+ };
452
+ try {
453
+ await writeJsonFileAtomically$1(plan.recoveryKeyPath, payload);
454
+ changes.push(`Imported Matrix legacy backup key for account "${plan.accountId}": ${plan.recoveryKeyPath}`);
455
+ decryptionKeyImported = true;
456
+ } catch (err) {
457
+ warnings.push(`Failed writing Matrix recovery key for account "${plan.accountId}" (${plan.recoveryKeyPath}): ${String(err)}`);
458
+ }
459
+ } else decryptionKeyImported = true;
460
+ }
461
+ const localOnlyKeys = summary.roomKeyCounts && summary.roomKeyCounts.total > summary.roomKeyCounts.backedUp ? summary.roomKeyCounts.total - summary.roomKeyCounts.backedUp : 0;
462
+ if (localOnlyKeys > 0) warnings.push(`Legacy Matrix encrypted state for account "${plan.accountId}" contains ${localOnlyKeys} room key(s) that were never backed up. Backed-up keys can be restored automatically, but local-only encrypted history may remain unavailable after upgrade.`);
463
+ if (!summary.decryptionKeyBase64 && (summary.roomKeyCounts?.backedUp ?? 0) > 0) warnings.push(`Legacy Matrix encrypted state for account "${plan.accountId}" has backed-up room keys, but no local backup decryption key was found. Ask the operator to run "klaw matrix verify backup restore --recovery-key <key>" after upgrade if they have the recovery key.`);
464
+ if (!summary.decryptionKeyBase64 && (summary.roomKeyCounts?.total ?? 0) > 0) warnings.push(`Legacy Matrix encrypted state for account "${plan.accountId}" cannot be fully converted automatically because the old rust crypto store does not expose all local room keys for export.`);
465
+ if (summary.decryptionKeyBase64 && !decryptionKeyImported && !loadStoredRecoveryKey(plan.recoveryKeyPath)) continue;
466
+ const state = {
467
+ version: 1,
468
+ source: "matrix-bot-sdk-rust",
469
+ accountId: plan.accountId,
470
+ deviceId: summary.deviceId,
471
+ roomKeyCounts: summary.roomKeyCounts,
472
+ backupVersion: summary.backupVersion,
473
+ decryptionKeyImported,
474
+ restoreStatus: decryptionKeyImported ? "pending" : "manual-action-required",
475
+ detectedAt: (/* @__PURE__ */ new Date()).toISOString(),
476
+ lastError: null
477
+ };
478
+ try {
479
+ await persistLegacyMigrationState({
480
+ filePath: plan.statePath,
481
+ state,
482
+ writeJsonFileAtomically: writeJsonFileAtomically$1
483
+ });
484
+ changes.push(`Prepared Matrix legacy encrypted-state migration for account "${plan.accountId}": ${plan.statePath}`);
485
+ } catch (err) {
486
+ warnings.push(`Failed writing Matrix legacy encrypted-state migration record for account "${plan.accountId}" (${plan.statePath}): ${String(err)}`);
487
+ }
488
+ }
489
+ if (changes.length > 0) params.log?.info?.(`matrix: prepared encrypted-state upgrade.\n${changes.map((entry) => `- ${entry}`).join("\n")}`);
490
+ if (warnings.length > 0) params.log?.warn?.(`matrix: legacy encrypted-state warnings:\n${warnings.map((entry) => `- ${entry}`).join("\n")}`);
491
+ return {
492
+ migrated: changes.length > 0,
493
+ changes,
494
+ warnings
495
+ };
496
+ }
497
+ //#endregion
498
+ //#region extensions/matrix/src/migration-snapshot.ts
499
+ function resolveMatrixMigrationStatus(params) {
500
+ const env = params.env ?? process.env;
501
+ const legacyState = detectLegacyMatrixState({
502
+ cfg: params.cfg,
503
+ env
504
+ });
505
+ const legacyCrypto = detectLegacyMatrixCrypto({
506
+ cfg: params.cfg,
507
+ env
508
+ });
509
+ const actionableLegacyState = legacyState !== null && !("warning" in legacyState);
510
+ const actionableLegacyCrypto = legacyCrypto.plans.length > 0 && legacyCrypto.inspectorAvailable;
511
+ return {
512
+ legacyState,
513
+ legacyCrypto,
514
+ pending: legacyState !== null || legacyCrypto.plans.length > 0 || legacyCrypto.warnings.length > 0,
515
+ actionable: actionableLegacyState || actionableLegacyCrypto
516
+ };
517
+ }
518
+ function hasPendingMatrixMigration(params) {
519
+ return resolveMatrixMigrationStatus(params).pending;
520
+ }
521
+ function hasActionableMatrixMigration(params) {
522
+ return resolveMatrixMigrationStatus(params).actionable;
523
+ }
524
+ //#endregion
525
+ export { detectLegacyMatrixCrypto as a, autoPrepareLegacyMatrixCrypto as i, hasPendingMatrixMigration as n, autoMigrateLegacyMatrixState as o, resolveMatrixMigrationStatus as r, detectLegacyMatrixState as s, hasActionableMatrixMigration as t };
@@ -0,0 +1,146 @@
1
+ import { C as formatPollResultsAsText, D as parsePollStartContent, O as resolvePollReferenceEventId, S as formatPollAsText, T as isPollStartType, w as isPollEventType, x as buildPollResultsSummary } from "./send-CJunc6QM.js";
2
+ import path from "node:path";
3
+ //#region extensions/matrix/src/matrix/poll-summary.ts
4
+ function resolveMatrixPollRootEventId(event) {
5
+ if (isPollStartType(event.type)) {
6
+ const eventId = event.event_id?.trim();
7
+ return eventId ? eventId : null;
8
+ }
9
+ return resolvePollReferenceEventId(event.content);
10
+ }
11
+ async function readAllPollRelations(client, roomId, pollEventId) {
12
+ const relationEvents = [];
13
+ let nextBatch;
14
+ do {
15
+ const page = await client.getRelations(roomId, pollEventId, "m.reference", void 0, { from: nextBatch });
16
+ relationEvents.push(...page.events);
17
+ nextBatch = page.nextBatch ?? void 0;
18
+ } while (nextBatch);
19
+ return relationEvents;
20
+ }
21
+ async function fetchMatrixPollSnapshot(client, roomId, event) {
22
+ if (!isPollEventType(event.type)) return null;
23
+ const pollEventId = resolveMatrixPollRootEventId(event);
24
+ if (!pollEventId) return null;
25
+ const rootEvent = isPollStartType(event.type) ? event : await client.getEvent(roomId, pollEventId);
26
+ if (!isPollStartType(rootEvent.type)) return null;
27
+ const pollStartContent = rootEvent.content;
28
+ const pollSummary = parsePollStartContent(pollStartContent);
29
+ if (!pollSummary) return null;
30
+ const relationEvents = await readAllPollRelations(client, roomId, pollEventId);
31
+ const pollResults = buildPollResultsSummary({
32
+ pollEventId,
33
+ roomId,
34
+ sender: rootEvent.sender,
35
+ senderName: rootEvent.sender,
36
+ content: pollStartContent,
37
+ relationEvents
38
+ });
39
+ return {
40
+ pollEventId,
41
+ triggerEvent: event,
42
+ rootEvent,
43
+ text: pollResults ? formatPollResultsAsText(pollResults) : formatPollAsText(pollSummary)
44
+ };
45
+ }
46
+ async function fetchMatrixPollMessageSummary(client, roomId, event) {
47
+ const snapshot = await fetchMatrixPollSnapshot(client, roomId, event);
48
+ if (!snapshot) return null;
49
+ return {
50
+ eventId: snapshot.pollEventId,
51
+ sender: snapshot.rootEvent.sender,
52
+ body: snapshot.text,
53
+ msgtype: "m.text",
54
+ timestamp: snapshot.triggerEvent.origin_server_ts || snapshot.rootEvent.origin_server_ts
55
+ };
56
+ }
57
+ //#endregion
58
+ //#region extensions/matrix/src/matrix/media-text.ts
59
+ const MATRIX_MEDIA_KINDS = {
60
+ "m.audio": "audio",
61
+ "m.file": "file",
62
+ "m.image": "image",
63
+ "m.sticker": "sticker",
64
+ "m.video": "video"
65
+ };
66
+ function resolveMatrixMediaKind(msgtype) {
67
+ return MATRIX_MEDIA_KINDS[msgtype ?? ""] ?? null;
68
+ }
69
+ function resolveMatrixMediaLabel(kind, fallback = "media") {
70
+ return `${kind ?? fallback} attachment`;
71
+ }
72
+ function formatMatrixAttachmentMarker(params) {
73
+ const label = resolveMatrixMediaLabel(params.kind);
74
+ if (params.tooLarge) return `[matrix ${label} too large]`;
75
+ return params.unavailable ? `[matrix ${label} unavailable]` : `[matrix ${label}]`;
76
+ }
77
+ function isLikelyBareFilename(text) {
78
+ const trimmed = text.trim();
79
+ if (!trimmed || trimmed.includes("\n") || /\s/.test(trimmed)) return false;
80
+ if (path.basename(trimmed) !== trimmed) return false;
81
+ return path.extname(trimmed).length > 1;
82
+ }
83
+ function resolveCaptionOrFilename(params) {
84
+ const body = params.body?.trim() ?? "";
85
+ const filename = params.filename?.trim() ?? "";
86
+ if (filename) {
87
+ if (!body || body === filename) return { filename };
88
+ return {
89
+ caption: body,
90
+ filename
91
+ };
92
+ }
93
+ if (!body) return {};
94
+ if (isLikelyBareFilename(body)) return { filename: body };
95
+ return { caption: body };
96
+ }
97
+ function resolveMatrixMessageAttachment(params) {
98
+ const kind = resolveMatrixMediaKind(params.msgtype);
99
+ if (!kind) return;
100
+ const resolved = resolveCaptionOrFilename(params);
101
+ return {
102
+ kind,
103
+ caption: resolved.caption,
104
+ filename: resolved.filename
105
+ };
106
+ }
107
+ function resolveMatrixMessageBody(params) {
108
+ const attachment = resolveMatrixMessageAttachment(params);
109
+ if (!attachment) return (params.body?.trim() ?? "") || void 0;
110
+ return attachment.caption;
111
+ }
112
+ function formatMatrixAttachmentText(params) {
113
+ if (!params.attachment) return;
114
+ return formatMatrixAttachmentMarker({
115
+ kind: params.attachment.kind,
116
+ tooLarge: params.tooLarge,
117
+ unavailable: params.unavailable
118
+ });
119
+ }
120
+ function formatMatrixMessageText(params) {
121
+ const body = params.body?.trim() ?? "";
122
+ const marker = formatMatrixAttachmentText({
123
+ attachment: params.attachment,
124
+ tooLarge: params.tooLarge,
125
+ unavailable: params.unavailable
126
+ });
127
+ if (!marker) return body || void 0;
128
+ if (!body) return marker;
129
+ return `${body}\n\n${marker}`;
130
+ }
131
+ function formatMatrixMediaUnavailableText(params) {
132
+ return formatMatrixMessageText({
133
+ body: resolveMatrixMessageBody(params),
134
+ attachment: resolveMatrixMessageAttachment(params),
135
+ unavailable: true
136
+ }) ?? "";
137
+ }
138
+ function formatMatrixMediaTooLargeText(params) {
139
+ return formatMatrixMessageText({
140
+ body: resolveMatrixMessageBody(params),
141
+ attachment: resolveMatrixMessageAttachment(params),
142
+ tooLarge: true
143
+ }) ?? "";
144
+ }
145
+ //#endregion
146
+ export { resolveMatrixMessageBody as a, resolveMatrixPollRootEventId as c, resolveMatrixMessageAttachment as i, formatMatrixMediaUnavailableText as n, fetchMatrixPollMessageSummary as o, formatMatrixMessageText as r, fetchMatrixPollSnapshot as s, formatMatrixMediaTooLargeText as t };