botinabox 2.5.0 → 2.5.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 (278) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +190 -190
  3. package/bin/botinabox.mjs +2 -2
  4. package/dist/channels/discord/adapter.d.ts +32 -0
  5. package/dist/channels/discord/adapter.js +70 -0
  6. package/dist/channels/discord/inbound.d.ts +25 -0
  7. package/dist/channels/discord/inbound.js +24 -0
  8. package/dist/channels/discord/models.d.ts +8 -0
  9. package/dist/channels/discord/models.js +5 -0
  10. package/dist/channels/discord/outbound.d.ts +14 -0
  11. package/dist/channels/discord/outbound.js +38 -0
  12. package/dist/channels/slack/adapter.d.ts +33 -0
  13. package/dist/channels/slack/adapter.js +74 -0
  14. package/dist/channels/slack/inbound.d.ts +59 -0
  15. package/dist/channels/slack/inbound.js +96 -0
  16. package/dist/channels/slack/models.d.ts +9 -0
  17. package/dist/channels/slack/models.js +5 -0
  18. package/dist/channels/slack/outbound.d.ts +12 -0
  19. package/dist/channels/slack/outbound.js +18 -0
  20. package/dist/channels/slack/transcribe.d.ts +41 -0
  21. package/dist/channels/slack/transcribe.js +106 -0
  22. package/dist/channels/webhook/adapter.d.ts +23 -0
  23. package/dist/channels/webhook/adapter.js +86 -0
  24. package/dist/channels/webhook/hmac.d.ts +13 -0
  25. package/dist/channels/webhook/hmac.js +26 -0
  26. package/dist/channels/webhook/models.d.ts +9 -0
  27. package/dist/channels/webhook/models.js +5 -0
  28. package/dist/channels/webhook/server.d.ts +20 -0
  29. package/dist/channels/webhook/server.js +91 -0
  30. package/dist/chat-pipeline-BWrtVqEP.d.ts +652 -0
  31. package/dist/chat-pipeline-C-XlLGNl.d.ts +648 -0
  32. package/dist/chat-pipeline-CR1KF6eX.d.ts +652 -0
  33. package/dist/chat-pipeline-DisuC8SB.d.ts +643 -0
  34. package/dist/chunk-2LGXQPEA.js +41 -0
  35. package/dist/chunk-3X3YKI4T.js +357 -0
  36. package/dist/chunk-D47AIFOD.js +351 -0
  37. package/dist/chunk-DSNJKNEW.js +328 -0
  38. package/dist/chunk-GS2JFL6I.js +144 -0
  39. package/dist/chunk-J6S6QMUY.js +144 -0
  40. package/dist/chunk-QLA6YOFN.js +22 -0
  41. package/dist/chunk-UACT2WXX.js +381 -0
  42. package/dist/cli/templates/config.yml.d.ts +7 -0
  43. package/dist/cli/templates/config.yml.js +61 -0
  44. package/dist/cli/templates/env.d.ts +1 -0
  45. package/dist/cli/templates/env.js +30 -0
  46. package/dist/cli/templates/index.ts.d.ts +2 -0
  47. package/dist/cli/templates/index.ts.js +30 -0
  48. package/dist/cli/templates/package.json.d.ts +5 -0
  49. package/dist/cli/templates/package.json.js +28 -0
  50. package/dist/cli.js +0 -0
  51. package/dist/connector-DDahQw-2.d.ts +63 -0
  52. package/dist/connectors/google/calendar-connector.d.ts +40 -0
  53. package/dist/connectors/google/calendar-connector.js +243 -0
  54. package/dist/connectors/google/gmail-connector.d.ts +42 -0
  55. package/dist/connectors/google/gmail-connector.js +345 -0
  56. package/dist/connectors/google/index.d.ts +67 -1
  57. package/dist/connectors/google/index.js +240 -0
  58. package/dist/connectors/google/oauth.d.ts +48 -0
  59. package/dist/connectors/google/oauth.js +112 -0
  60. package/dist/connectors/google/types.d.ts +78 -0
  61. package/dist/connectors/google/types.js +2 -0
  62. package/dist/core/chat/auto-discovery.d.ts +16 -0
  63. package/dist/core/chat/auto-discovery.js +54 -0
  64. package/dist/core/chat/channel-registry.d.ts +45 -0
  65. package/dist/core/chat/channel-registry.js +96 -0
  66. package/dist/core/chat/chat-pipeline.d.ts +113 -0
  67. package/dist/core/chat/chat-pipeline.js +395 -0
  68. package/dist/core/chat/chat-responder.d.ts +90 -0
  69. package/dist/core/chat/chat-responder.js +185 -0
  70. package/dist/core/chat/formatter.d.ts +11 -0
  71. package/dist/core/chat/formatter.js +60 -0
  72. package/dist/core/chat/index.d.ts +24 -0
  73. package/dist/core/chat/index.js +18 -0
  74. package/dist/core/chat/message-interpreter.d.ts +91 -0
  75. package/dist/core/chat/message-interpreter.js +166 -0
  76. package/dist/core/chat/message-store.d.ts +66 -0
  77. package/dist/core/chat/message-store.js +131 -0
  78. package/dist/core/chat/notification-queue.d.ts +34 -0
  79. package/dist/core/chat/notification-queue.js +111 -0
  80. package/dist/core/chat/pipeline.d.ts +38 -0
  81. package/dist/core/chat/pipeline.js +89 -0
  82. package/dist/core/chat/policies.d.ts +16 -0
  83. package/dist/core/chat/policies.js +25 -0
  84. package/dist/core/chat/routing.d.ts +17 -0
  85. package/dist/core/chat/routing.js +36 -0
  86. package/dist/core/chat/session-key.d.ts +30 -0
  87. package/dist/core/chat/session-key.js +65 -0
  88. package/dist/core/chat/session-manager.d.ts +17 -0
  89. package/dist/core/chat/session-manager.js +23 -0
  90. package/dist/core/chat/text-chunker.d.ts +9 -0
  91. package/dist/core/chat/text-chunker.js +48 -0
  92. package/dist/core/chat/triage-router.d.ts +75 -0
  93. package/dist/core/chat/triage-router.js +142 -0
  94. package/dist/core/chat/types.d.ts +5 -0
  95. package/dist/core/chat/types.js +5 -0
  96. package/dist/core/config/defaults.d.ts +2 -0
  97. package/dist/core/config/defaults.js +38 -0
  98. package/dist/core/config/index.d.ts +6 -0
  99. package/dist/core/config/index.js +4 -0
  100. package/dist/core/config/interpolate.d.ts +5 -0
  101. package/dist/core/config/interpolate.js +27 -0
  102. package/dist/core/config/loader.d.ts +24 -0
  103. package/dist/core/config/loader.js +59 -0
  104. package/dist/core/config/schema.d.ts +5 -0
  105. package/dist/core/config/schema.js +119 -0
  106. package/dist/core/data/core-entity-contexts.d.ts +14 -0
  107. package/dist/core/data/core-entity-contexts.js +197 -0
  108. package/dist/core/data/core-migrations.d.ts +5 -0
  109. package/dist/core/data/core-migrations.js +45 -0
  110. package/dist/core/data/core-schema.d.ts +6 -0
  111. package/dist/core/data/core-schema.js +454 -0
  112. package/dist/core/data/data-store.d.ts +67 -0
  113. package/dist/core/data/data-store.js +218 -0
  114. package/dist/core/data/domain-entity-contexts.d.ts +29 -0
  115. package/dist/core/data/domain-entity-contexts.js +321 -0
  116. package/dist/core/data/domain-schema.d.ts +36 -0
  117. package/dist/core/data/domain-schema.js +323 -0
  118. package/dist/core/data/index.d.ts +7 -0
  119. package/dist/core/data/index.js +7 -0
  120. package/dist/core/data/types.d.ts +111 -0
  121. package/dist/core/data/types.js +1 -0
  122. package/dist/core/hooks/hook-bus.d.ts +18 -0
  123. package/dist/core/hooks/hook-bus.js +120 -0
  124. package/dist/core/hooks/index.d.ts +2 -0
  125. package/dist/core/hooks/index.js +1 -0
  126. package/dist/core/hooks/types.d.ts +19 -0
  127. package/dist/core/hooks/types.js +1 -0
  128. package/dist/core/index.d.ts +4 -0
  129. package/dist/core/index.js +4 -0
  130. package/dist/core/llm/auto-discovery.d.ts +11 -0
  131. package/dist/core/llm/auto-discovery.js +49 -0
  132. package/dist/core/llm/cost-tracker.d.ts +6 -0
  133. package/dist/core/llm/cost-tracker.js +38 -0
  134. package/dist/core/llm/index.d.ts +4 -0
  135. package/dist/core/llm/index.js +3 -0
  136. package/dist/core/llm/model-router.d.ts +25 -0
  137. package/dist/core/llm/model-router.js +49 -0
  138. package/dist/core/llm/provider-registry.d.ts +9 -0
  139. package/dist/core/llm/provider-registry.js +25 -0
  140. package/dist/core/llm/types.d.ts +2 -0
  141. package/dist/core/llm/types.js +2 -0
  142. package/dist/core/orchestrator/adapters/api-adapter.d.ts +34 -0
  143. package/dist/core/orchestrator/adapters/api-adapter.js +88 -0
  144. package/dist/core/orchestrator/adapters/cli-adapter.d.ts +22 -0
  145. package/dist/core/orchestrator/adapters/cli-adapter.js +69 -0
  146. package/dist/core/orchestrator/adapters/deterministic-adapter.d.ts +35 -0
  147. package/dist/core/orchestrator/adapters/deterministic-adapter.js +75 -0
  148. package/dist/core/orchestrator/adapters/env-whitelist.d.ts +4 -0
  149. package/dist/core/orchestrator/adapters/env-whitelist.js +27 -0
  150. package/dist/core/orchestrator/adapters/output-extractor.d.ts +11 -0
  151. package/dist/core/orchestrator/adapters/output-extractor.js +59 -0
  152. package/dist/core/orchestrator/adapters/process-manager.d.ts +15 -0
  153. package/dist/core/orchestrator/adapters/process-manager.js +26 -0
  154. package/dist/core/orchestrator/adapters/tool-loop.d.ts +22 -0
  155. package/dist/core/orchestrator/adapters/tool-loop.js +66 -0
  156. package/dist/core/orchestrator/agent-registry.d.ts +31 -0
  157. package/dist/core/orchestrator/agent-registry.js +135 -0
  158. package/dist/core/orchestrator/budget-controller.d.ts +19 -0
  159. package/dist/core/orchestrator/budget-controller.js +73 -0
  160. package/dist/core/orchestrator/chain-guard.d.ts +14 -0
  161. package/dist/core/orchestrator/chain-guard.js +23 -0
  162. package/dist/core/orchestrator/circuit-breaker.d.ts +65 -0
  163. package/dist/core/orchestrator/circuit-breaker.js +159 -0
  164. package/dist/core/orchestrator/claude-stream-parser.d.ts +31 -0
  165. package/dist/core/orchestrator/claude-stream-parser.js +99 -0
  166. package/dist/core/orchestrator/config-revisions.d.ts +6 -0
  167. package/dist/core/orchestrator/config-revisions.js +17 -0
  168. package/dist/core/orchestrator/dependency-resolver.d.ts +20 -0
  169. package/dist/core/orchestrator/dependency-resolver.js +78 -0
  170. package/dist/core/orchestrator/governance-gate.d.ts +110 -0
  171. package/dist/core/orchestrator/governance-gate.js +170 -0
  172. package/dist/core/orchestrator/learning-pipeline.d.ts +109 -0
  173. package/dist/core/orchestrator/learning-pipeline.js +249 -0
  174. package/dist/core/orchestrator/loop-detector.d.ts +51 -0
  175. package/dist/core/orchestrator/loop-detector.js +133 -0
  176. package/dist/core/orchestrator/ndjson-logger.d.ts +6 -0
  177. package/dist/core/orchestrator/ndjson-logger.js +18 -0
  178. package/dist/core/orchestrator/permission-relay.d.ts +72 -0
  179. package/dist/core/orchestrator/permission-relay.js +164 -0
  180. package/dist/core/orchestrator/run-manager.d.ts +31 -0
  181. package/dist/core/orchestrator/run-manager.js +178 -0
  182. package/dist/core/orchestrator/scheduler.d.ts +70 -0
  183. package/dist/core/orchestrator/scheduler.js +198 -0
  184. package/dist/core/orchestrator/secret-store.d.ts +57 -0
  185. package/dist/core/orchestrator/secret-store.js +171 -0
  186. package/dist/core/orchestrator/session-manager.d.ts +13 -0
  187. package/dist/core/orchestrator/session-manager.js +66 -0
  188. package/dist/core/orchestrator/task-queue.d.ts +34 -0
  189. package/dist/core/orchestrator/task-queue.js +83 -0
  190. package/dist/core/orchestrator/template-interpolate.d.ts +5 -0
  191. package/dist/core/orchestrator/template-interpolate.js +18 -0
  192. package/dist/core/orchestrator/user-registry.d.ts +47 -0
  193. package/dist/core/orchestrator/user-registry.js +76 -0
  194. package/dist/core/orchestrator/wakeup-queue.d.ts +9 -0
  195. package/dist/core/orchestrator/wakeup-queue.js +45 -0
  196. package/dist/core/orchestrator/workflow-engine.d.ts +47 -0
  197. package/dist/core/orchestrator/workflow-engine.js +204 -0
  198. package/dist/core/security/audit.d.ts +20 -0
  199. package/dist/core/security/audit.js +33 -0
  200. package/dist/core/security/column-validator.d.ts +20 -0
  201. package/dist/core/security/column-validator.js +37 -0
  202. package/dist/core/security/index.d.ts +5 -0
  203. package/dist/core/security/index.js +5 -0
  204. package/dist/core/security/process-env.d.ts +13 -0
  205. package/dist/core/security/process-env.js +49 -0
  206. package/dist/core/security/sanitizer.d.ts +11 -0
  207. package/dist/core/security/sanitizer.js +39 -0
  208. package/dist/core/security/types.d.ts +11 -0
  209. package/dist/core/security/types.js +1 -0
  210. package/dist/core/update/auto-update.d.ts +21 -0
  211. package/dist/core/update/auto-update.js +102 -0
  212. package/dist/core/update/backup-manager.d.ts +7 -0
  213. package/dist/core/update/backup-manager.js +24 -0
  214. package/dist/core/update/index.d.ts +8 -0
  215. package/dist/core/update/index.js +6 -0
  216. package/dist/core/update/migration-hooks.d.ts +11 -0
  217. package/dist/core/update/migration-hooks.js +10 -0
  218. package/dist/core/update/types.d.ts +11 -0
  219. package/dist/core/update/types.js +1 -0
  220. package/dist/core/update/update-checker.d.ts +11 -0
  221. package/dist/core/update/update-checker.js +63 -0
  222. package/dist/core/update/update-manager.d.ts +25 -0
  223. package/dist/core/update/update-manager.js +101 -0
  224. package/dist/core/update/version-utils.d.ts +6 -0
  225. package/dist/core/update/version-utils.js +34 -0
  226. package/dist/gmail-connector-2FVYTQJH.js +6 -0
  227. package/dist/gmail-connector-MNUBRNFM.js +6 -0
  228. package/dist/gmail-connector-PS2VLGNE.js +6 -0
  229. package/dist/gmail-connector-ULSMN6X2.js +6 -0
  230. package/dist/gmail-connector-URRFX6A3.js +6 -0
  231. package/dist/inbound-AFBUPSPG.js +10 -0
  232. package/dist/inbound-AFOHYNUY.js +6 -0
  233. package/dist/inbound-CGIXRXGC.js +8 -0
  234. package/dist/inbound-MCOLRH6U.js +10 -0
  235. package/dist/inbound-SNEMBLGA.js +6 -0
  236. package/dist/inbound-ZJHAYVMF.js +10 -0
  237. package/dist/index.d.ts +11 -1
  238. package/dist/index.js +27 -11
  239. package/dist/provider-qqJYv9nv.d.ts +75 -0
  240. package/dist/providers/anthropic/models.d.ts +2 -0
  241. package/dist/providers/anthropic/models.js +29 -0
  242. package/dist/providers/anthropic/provider.d.ts +13 -0
  243. package/dist/providers/anthropic/provider.js +119 -0
  244. package/dist/providers/anthropic/tool-converter.d.ts +10 -0
  245. package/dist/providers/anthropic/tool-converter.js +7 -0
  246. package/dist/providers/ollama/provider.d.ts +17 -0
  247. package/dist/providers/ollama/provider.js +185 -0
  248. package/dist/providers/openai/models.d.ts +2 -0
  249. package/dist/providers/openai/models.js +29 -0
  250. package/dist/providers/openai/provider.d.ts +13 -0
  251. package/dist/providers/openai/provider.js +163 -0
  252. package/dist/providers/openai/tool-converter.d.ts +10 -0
  253. package/dist/providers/openai/tool-converter.js +10 -0
  254. package/dist/shared/constants.d.ts +50 -0
  255. package/dist/shared/constants.js +64 -0
  256. package/dist/shared/index.d.ts +14 -0
  257. package/dist/shared/index.js +14 -0
  258. package/dist/shared/types/agent.d.ts +36 -0
  259. package/dist/shared/types/agent.js +2 -0
  260. package/dist/shared/types/channel.d.ts +70 -0
  261. package/dist/shared/types/channel.js +2 -0
  262. package/dist/shared/types/config.d.ts +111 -0
  263. package/dist/shared/types/config.js +2 -0
  264. package/dist/shared/types/connector.d.ts +77 -0
  265. package/dist/shared/types/connector.js +2 -0
  266. package/dist/shared/types/execution.d.ts +29 -0
  267. package/dist/shared/types/execution.js +2 -0
  268. package/dist/shared/types/provider.d.ts +73 -0
  269. package/dist/shared/types/provider.js +2 -0
  270. package/dist/shared/types/task.d.ts +47 -0
  271. package/dist/shared/types/task.js +2 -0
  272. package/dist/shared/types/workflow.d.ts +39 -0
  273. package/dist/shared/types/workflow.js +2 -0
  274. package/dist/shared/utils.d.ts +6 -0
  275. package/dist/shared/utils.js +13 -0
  276. package/dist/update-check.d.ts +5 -0
  277. package/dist/update-check.js +56 -0
  278. package/package.json +100 -100
@@ -0,0 +1,197 @@
1
+ import { truncateAtWord } from "../../shared/utils.js";
2
+ /**
3
+ * Define default entity context rendering for botinabox core tables.
4
+ * Call after defineCoreTables() and before or after init().
5
+ *
6
+ * Renders:
7
+ * - agents/ — per-agent context (AGENT.md, PROJECTS.md if agent_project exists)
8
+ * - users/ — per-user context (USER.md) — protected
9
+ * - skills/ — per-skill context (SKILL.md)
10
+ *
11
+ * Apps can override by calling db.defineEntityContext() with the same table name
12
+ * BEFORE calling defineCoreEntityContexts().
13
+ */
14
+ export function defineCoreEntityContexts(db) {
15
+ // --- Agents ---
16
+ db.defineEntityContext("agents", {
17
+ table: "agents",
18
+ directory: "agents",
19
+ slugColumn: "slug",
20
+ indexFile: "agents/AGENTS.md",
21
+ files: {
22
+ "AGENT.md": {
23
+ source: { type: "self" },
24
+ render: (rows) => {
25
+ const a = rows[0];
26
+ if (!a)
27
+ return "";
28
+ return [
29
+ `# ${a.name}`,
30
+ "",
31
+ a.role ? `**Role:** ${a.role}` : null,
32
+ a.adapter ? `**Adapter:** ${a.adapter}` : null,
33
+ a.status ? `**Status:** ${a.status}` : null,
34
+ a.cwd ? `**Working Directory:** ${a.cwd}` : null,
35
+ a.reports_to ? `**Reports To:** ${a.reports_to}` : null,
36
+ "",
37
+ ]
38
+ .filter(Boolean)
39
+ .join("\n");
40
+ },
41
+ },
42
+ "SKILLS.md": {
43
+ source: {
44
+ type: "manyToMany",
45
+ junctionTable: "agent_skills",
46
+ localKey: "agent_id",
47
+ remoteKey: "skill_id",
48
+ remoteTable: "skills",
49
+ },
50
+ omitIfEmpty: true,
51
+ render: (rows) => {
52
+ if (!rows.length)
53
+ return "";
54
+ const lines = [`# Skills (${rows.length})`, ""];
55
+ for (const s of rows) {
56
+ lines.push(`## ${s.name}`);
57
+ if (s.category)
58
+ lines.push(`**Category:** ${s.category}`);
59
+ if (s.description)
60
+ lines.push("", s.description);
61
+ if (s.definition)
62
+ lines.push("", "```", s.definition, "```");
63
+ lines.push("");
64
+ }
65
+ return lines.join("\n");
66
+ },
67
+ },
68
+ "PLAYBOOKS.md": {
69
+ source: {
70
+ type: "manyToMany",
71
+ junctionTable: "agent_playbooks",
72
+ localKey: "agent_id",
73
+ remoteKey: "playbook_id",
74
+ remoteTable: "playbooks",
75
+ },
76
+ omitIfEmpty: true,
77
+ render: (rows) => {
78
+ if (!rows.length)
79
+ return "";
80
+ const lines = [`# Playbooks (${rows.length})`, ""];
81
+ for (const pb of rows) {
82
+ lines.push(`## ${pb.pattern ?? pb.name ?? "Unnamed"}`);
83
+ if (pb.rule)
84
+ lines.push("", pb.rule);
85
+ lines.push("");
86
+ }
87
+ return lines.join("\n");
88
+ },
89
+ },
90
+ },
91
+ });
92
+ // --- Users (protected) ---
93
+ db.defineEntityContext("users", {
94
+ table: "users",
95
+ directory: "users",
96
+ slugColumn: "id",
97
+ protected: true,
98
+ indexFile: "users/USERS.md",
99
+ files: {
100
+ "USER.md": {
101
+ source: { type: "self" },
102
+ render: (rows) => {
103
+ const u = rows[0];
104
+ if (!u)
105
+ return "";
106
+ return [
107
+ `# ${u.name}`,
108
+ "",
109
+ u.role ? `**Role:** ${u.role}` : null,
110
+ u.title ? `**Title:** ${u.title}` : null,
111
+ u.email ? `**Email:** ${u.email}` : null,
112
+ u.timezone ? `**Timezone:** ${u.timezone}` : null,
113
+ "",
114
+ ]
115
+ .filter(Boolean)
116
+ .join("\n");
117
+ },
118
+ },
119
+ },
120
+ });
121
+ // --- Skills ---
122
+ db.defineEntityContext("skills", {
123
+ table: "skills",
124
+ directory: "skills",
125
+ slugColumn: "slug",
126
+ indexFile: "skills/SKILLS.md",
127
+ files: {
128
+ "SKILL.md": {
129
+ source: { type: "self" },
130
+ render: (rows) => {
131
+ const s = rows[0];
132
+ if (!s)
133
+ return "";
134
+ return [
135
+ `# ${s.name}`,
136
+ "",
137
+ s.category ? `**Category:** ${s.category}` : null,
138
+ s.description ? `\n${s.description}` : null,
139
+ s.definition ? `\n## Definition\n\n${s.definition}` : null,
140
+ "",
141
+ ]
142
+ .filter(Boolean)
143
+ .join("\n");
144
+ },
145
+ },
146
+ },
147
+ });
148
+ // --- Messages ---
149
+ db.defineEntityContext("messages", {
150
+ table: "messages",
151
+ directory: "messages",
152
+ slugColumn: "id",
153
+ indexFile: "messages/MESSAGES.md",
154
+ indexRender: (rows) => {
155
+ const active = rows.filter((r) => r.deleted_at == null);
156
+ if (!active.length)
157
+ return "# Messages\n\nNo messages.\n";
158
+ const recent = active.slice(-100);
159
+ const lines = recent.map((r) => {
160
+ const dir = r.direction === "outbound" ? "→" : "←";
161
+ const who = r.from_agent ?? r.from_user ?? "unknown";
162
+ const time = (r.created_at ?? "").slice(0, 16);
163
+ const preview = truncateAtWord(r.body ?? "", 80);
164
+ return `- ${dir} **${who}** (${time}): ${preview}`;
165
+ });
166
+ return `# Messages\n\nLast ${lines.length} messages:\n\n${lines.join("\n")}\n`;
167
+ },
168
+ files: {
169
+ "MESSAGE.md": {
170
+ source: { type: "self" },
171
+ render: (rows) => {
172
+ const m = rows[0];
173
+ if (!m)
174
+ return "";
175
+ return [
176
+ "# Message",
177
+ "",
178
+ `**Direction:** ${m.direction}`,
179
+ m.from_user ? `**From User:** ${m.from_user}` : null,
180
+ m.from_agent ? `**From Agent:** ${m.from_agent}` : null,
181
+ `**Channel:** ${m.channel}`,
182
+ m.thread_id ? `**Thread:** ${m.thread_id}` : null,
183
+ m.task_id ? `**Task:** ${m.task_id}` : null,
184
+ `**Time:** ${m.created_at}`,
185
+ "",
186
+ "---",
187
+ "",
188
+ m.body,
189
+ "",
190
+ ]
191
+ .filter(Boolean)
192
+ .join("\n");
193
+ },
194
+ },
195
+ },
196
+ });
197
+ }
@@ -0,0 +1,5 @@
1
+ /** Initial migration set for core tables */
2
+ export declare const CORE_MIGRATIONS: Array<{
3
+ version: string;
4
+ sql: string;
5
+ }>;
@@ -0,0 +1,45 @@
1
+ /** Initial migration set for core tables */
2
+ export const CORE_MIGRATIONS = [
3
+ {
4
+ version: "001_initial_schema",
5
+ sql: `-- Initial schema is applied via DataStore.define() + init().
6
+ -- This migration is a no-op placeholder for version tracking.
7
+ SELECT 1;`,
8
+ },
9
+ {
10
+ version: "002_activity_log_indexes",
11
+ sql: `CREATE INDEX IF NOT EXISTS idx_activity_log_type ON activity_log(event_type, recorded_at);`,
12
+ },
13
+ {
14
+ version: "003_runs_cost_index",
15
+ sql: `CREATE INDEX IF NOT EXISTS idx_runs_cost ON runs(agent_id, completed_at) WHERE cost_cents > 0;`,
16
+ },
17
+ {
18
+ version: "004_schedules_table",
19
+ sql: `CREATE TABLE IF NOT EXISTS schedules (
20
+ id TEXT PRIMARY KEY,
21
+ name TEXT NOT NULL,
22
+ description TEXT,
23
+ type TEXT NOT NULL DEFAULT 'recurring',
24
+ cron TEXT,
25
+ run_at TEXT,
26
+ timezone TEXT DEFAULT 'UTC',
27
+ enabled INTEGER NOT NULL DEFAULT 1,
28
+ action TEXT NOT NULL,
29
+ action_config TEXT DEFAULT '{}',
30
+ last_fired_at TEXT,
31
+ next_fire_at TEXT,
32
+ created_at TEXT NOT NULL DEFAULT CURRENT_TIMESTAMP,
33
+ updated_at TEXT NOT NULL DEFAULT CURRENT_TIMESTAMP,
34
+ deleted_at TEXT
35
+ )`,
36
+ },
37
+ {
38
+ version: "005_schedules_name_index",
39
+ sql: `CREATE UNIQUE INDEX IF NOT EXISTS idx_schedules_name ON schedules(name) WHERE deleted_at IS NULL`,
40
+ },
41
+ {
42
+ version: "006_schedules_next_index",
43
+ sql: `CREATE INDEX IF NOT EXISTS idx_schedules_next ON schedules(enabled, next_fire_at) WHERE deleted_at IS NULL`,
44
+ },
45
+ ];
@@ -0,0 +1,6 @@
1
+ import type { DataStore } from "./data-store.js";
2
+ /**
3
+ * Define all 18 core tables on a DataStore instance.
4
+ * Call before db.init().
5
+ */
6
+ export declare function defineCoreTables(db: DataStore): void;