nodal-agents 0.1.4 → 0.1.6

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 (75) hide show
  1. package/README.md +211 -81
  2. package/cli.js +6 -5
  3. package/migrations/0018_mcp_servers_bearer_auth.sql +12 -0
  4. package/migrations/meta/_journal.json +139 -132
  5. package/package.json +1 -2
  6. package/runner.js +58419 -791
  7. package/web/.next/BUILD_ID +1 -1
  8. package/web/.next/app-path-routes-manifest.json +2 -2
  9. package/web/.next/build-manifest.json +2 -2
  10. package/web/.next/server/app/(dashboard)/agents/[id]/edit/page_client-reference-manifest.js +1 -1
  11. package/web/.next/server/app/(dashboard)/agents/[id]/telegram/page_client-reference-manifest.js +1 -1
  12. package/web/.next/server/app/(dashboard)/agents/page_client-reference-manifest.js +1 -1
  13. package/web/.next/server/app/(dashboard)/approvals/page_client-reference-manifest.js +1 -1
  14. package/web/.next/server/app/(dashboard)/automations/page_client-reference-manifest.js +1 -1
  15. package/web/.next/server/app/(dashboard)/billing/page_client-reference-manifest.js +1 -1
  16. package/web/.next/server/app/(dashboard)/connectors/page_client-reference-manifest.js +1 -1
  17. package/web/.next/server/app/(dashboard)/credentials/page_client-reference-manifest.js +1 -1
  18. package/web/.next/server/app/(dashboard)/jobs/[id]/page_client-reference-manifest.js +1 -1
  19. package/web/.next/server/app/(dashboard)/jobs/page_client-reference-manifest.js +1 -1
  20. package/web/.next/server/app/(dashboard)/logs/page_client-reference-manifest.js +1 -1
  21. package/web/.next/server/app/(dashboard)/mcp/page.js +1 -1
  22. package/web/.next/server/app/(dashboard)/mcp/page_client-reference-manifest.js +1 -1
  23. package/web/.next/server/app/(dashboard)/memories/page_client-reference-manifest.js +1 -1
  24. package/web/.next/server/app/(dashboard)/settings/page_client-reference-manifest.js +1 -1
  25. package/web/.next/server/app/(dashboard)/skills/[id]/edit/page_client-reference-manifest.js +1 -1
  26. package/web/.next/server/app/(dashboard)/skills/page_client-reference-manifest.js +1 -1
  27. package/web/.next/server/app/(dashboard)/stats/page_client-reference-manifest.js +1 -1
  28. package/web/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
  29. package/web/.next/server/app/_global-error.html +1 -1
  30. package/web/.next/server/app/_global-error.rsc +1 -1
  31. package/web/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  32. package/web/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
  33. package/web/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
  34. package/web/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  35. package/web/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  36. package/web/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  37. package/web/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  38. package/web/.next/server/app/_not-found.html +1 -1
  39. package/web/.next/server/app/_not-found.rsc +1 -1
  40. package/web/.next/server/app/_not-found.segments/_full.segment.rsc +1 -1
  41. package/web/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  42. package/web/.next/server/app/_not-found.segments/_index.segment.rsc +1 -1
  43. package/web/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  44. package/web/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  45. package/web/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
  46. package/web/.next/server/app/index.html +1 -1
  47. package/web/.next/server/app/index.rsc +1 -1
  48. package/web/.next/server/app/index.segments/__PAGE__.segment.rsc +1 -1
  49. package/web/.next/server/app/index.segments/_full.segment.rsc +1 -1
  50. package/web/.next/server/app/index.segments/_head.segment.rsc +1 -1
  51. package/web/.next/server/app/index.segments/_index.segment.rsc +1 -1
  52. package/web/.next/server/app/index.segments/_tree.segment.rsc +1 -1
  53. package/web/.next/server/app/login/page_client-reference-manifest.js +1 -1
  54. package/web/.next/server/app/onboarding/page_client-reference-manifest.js +1 -1
  55. package/web/.next/server/app/onboarding.html +1 -1
  56. package/web/.next/server/app/onboarding.rsc +1 -1
  57. package/web/.next/server/app/onboarding.segments/_full.segment.rsc +1 -1
  58. package/web/.next/server/app/onboarding.segments/_head.segment.rsc +1 -1
  59. package/web/.next/server/app/onboarding.segments/_index.segment.rsc +1 -1
  60. package/web/.next/server/app/onboarding.segments/_tree.segment.rsc +1 -1
  61. package/web/.next/server/app/onboarding.segments/onboarding/__PAGE__.segment.rsc +1 -1
  62. package/web/.next/server/app/onboarding.segments/onboarding.segment.rsc +1 -1
  63. package/web/.next/server/app/page_client-reference-manifest.js +1 -1
  64. package/web/.next/server/app-paths-manifest.json +2 -2
  65. package/web/.next/server/chunks/574.js +1 -1
  66. package/web/.next/server/chunks/631.js +2 -2
  67. package/web/.next/server/middleware-build-manifest.js +1 -1
  68. package/web/.next/server/pages/404.html +1 -1
  69. package/web/.next/server/pages/500.html +1 -1
  70. package/web/.next/server/server-reference-manifest.js +1 -1
  71. package/web/.next/server/server-reference-manifest.json +1 -1
  72. package/web/.next/static/chunks/app/(dashboard)/mcp/page-69f5cfd2e4f57677.js +1 -0
  73. package/web/.next/static/chunks/app/(dashboard)/mcp/page-77dd7810003d6437.js +0 -1
  74. /package/web/.next/static/{2lmxaWvI1cL9_1Ob3gIFq → 1HpaEqSrARPvyPllAmQtF}/_buildManifest.js +0 -0
  75. /package/web/.next/static/{2lmxaWvI1cL9_1Ob3gIFq → 1HpaEqSrARPvyPllAmQtF}/_ssgManifest.js +0 -0
package/README.md CHANGED
@@ -1,81 +1,211 @@
1
- # Nodal-Agents
2
-
3
- Local-first AI agent platform. Self-host on Mac, PC, Linux, VPS, or NAS in 3 commands.
4
-
5
- ## Install in 30 seconds (Docker)
6
-
7
- Works on any host with Docker — Mac, PC, Linux, VPS, Synology / Unraid / TrueNAS NAS, Raspberry Pi.
8
-
9
- ```bash
10
- curl -O https://raw.githubusercontent.com/Kwintspiracy/nodal-agents/main/docker-compose.yml
11
- docker compose up -d
12
- ```
13
-
14
- Open <http://localhost:3000> — Nodal-Agents is running. Configure your LLM provider from **Settings → LLM keys** in the dashboard.
15
-
16
- Data (config, postgres, logs) lives in the `nodal-data` Docker volume. To wipe everything: `docker compose down -v`.
17
-
18
- The image is published to `ghcr.io/kwintspiracy/nodal-agents:latest` (multi-arch: amd64 + arm64). To pin a version, replace `latest` with a release tag (e.g. `v0.1.0`).
19
-
20
- ### Build the image locally
21
-
22
- If you'd rather build from source instead of pulling the published image:
23
-
24
- ```bash
25
- git clone https://github.com/Kwintspiracy/nodal-agents.git
26
- cd nodal-agents
27
- docker compose build
28
- docker compose up -d
29
- ```
30
-
31
- (Comment the `image:` line and uncomment `build: .` in `docker-compose.yml`.)
32
-
33
- ## Developer setup (monorepo)
34
-
35
- ```bash
36
- pnpm install
37
- pnpm typecheck
38
- pnpm lint
39
- pnpm test
40
- pnpm --filter nodal-agents dev # CLI in tsx watch mode
41
- ```
42
-
43
- ## Monorepo structure
44
-
45
- - `apps/web` — Next.js dashboard (UI)
46
- - `apps/runner` Agent runtime (HTTP API, job execution, cron ticker)
47
- - `apps/cli` — `nodal-agents` install + ops command
48
- - `packages/db` Drizzle schema + migrations + client (only place that imports postgres)
49
- - `packages/shared` — Zod types and constants shared across web + runner
50
- - `packages/llm` — Vercel AI SDK wrapper, multi-provider abstraction
51
- - `packages/tools` — Tool registration + execution + approval gates
52
- - `packages/memory` — Agent memory CRUD + embeddings
53
- - `packages/orchestration` — Router + Planner patterns (delegation, task board)
54
- - `packages/runner-adapters` Connectors: notion, drive, gmail, sheets, etc.
55
- - `packages/delivery` — Telegram, email, future Slack/Discord
56
- - `packages/auth` — Pluggable auth provider (local-trust default, better-auth opt-in, bearer-token for LAN)
57
-
58
- ## Architecture rules (enforced by `dependency-cruiser`)
59
-
60
- - `apps/*` may import `packages/*`, never the reverse
61
- - `apps/web` and `apps/runner` cannot import each other (DB or HTTP only)
62
- - Only `packages/db` may import postgres clients (`pg`, `postgres`, `drizzle-orm`)
63
- - `packages/runner-adapters/*` may only import from `packages/tools` and `packages/shared`
64
- - No circular dependencies
65
-
66
- Run `pnpm deps:check` locally before pushing.
67
-
68
- ## Stack
69
-
70
- - **Runtime:** Node 22+, TypeScript strict
71
- - **Monorepo:** pnpm workspaces + Turborepo
72
- - **DB:** embedded-postgres (local + Docker), Drizzle ORM, pgvector
73
- - **Validation:** Zod
74
- - **HTTP server:** Hono (runner)
75
- - **LLM:** Vercel AI SDK
76
- - **Auth:** local-trust (single-user loopback) / local-auth (better-auth, multi-user LAN) / bearer-token
77
- - **Tests:** Vitest (unit), Playwright (e2e), dependency-cruiser (architecture)
78
-
79
- ## License
80
-
81
- TBD.
1
+ # Nodal-Agents
2
+
3
+ > **Your AI agents. Your data. Your machine.**
4
+ > Self-hosted, local-first AI agent platform — install in two commands.
5
+
6
+ [![npm](https://img.shields.io/npm/v/nodal-agents?color=cb3837&label=npm&logo=npm)](https://www.npmjs.com/package/nodal-agents)
7
+ [![Node](https://img.shields.io/badge/node-22%2B-339933?logo=node.js&logoColor=white)](https://nodejs.org)
8
+ [![TypeScript](https://img.shields.io/badge/typescript-strict-3178c6?logo=typescript&logoColor=white)](https://www.typescriptlang.org)
9
+
10
+ Build and orchestrate AI agents on your own hardware. Multi-LLM,
11
+ multi-channel, multi-connector **no SaaS lock-in, no per-token markup,
12
+ no cloud roundtrip.** Runs on any machine with Node 22+ — Mac, PC, Linux.
13
+
14
+ ---
15
+
16
+ ## Why Nodal-Agents
17
+
18
+ | | |
19
+ | --- | --- |
20
+ | 🏠 &nbsp;**Local-first** | Single binary, embedded Postgres, zero cloud dependency. Your conversations, memory, and credentials stay on your machine. |
21
+ | 🔌 &nbsp;**LLM-agnostic** | Anthropic, OpenAI, Google, Groq, Mistral, OpenRouter, or any OpenAI-compatible local model (LM Studio, Ollama). Per-agent key, swap providers without code changes. |
22
+ | 🧠 &nbsp;**Memory that compounds** | Persistent facts (entity-scoped, auto-injected into every job) and chat-thread continuity (your agent remembers what it said 30 seconds ago — and what it said yesterday). |
23
+ | 🤝 &nbsp;**Orchestrators that finish** | Router and planner orchestrators delegate to specialist sub-agents. Hard guards against runaway loops — turn caps, chain caps, per-slug delegation budgets, smart retry on side-effect-free failures. |
24
+ | 🔧 &nbsp;**Multi-instance connectors** | Gmail perso *and* Gmail boulot on the same install. OAuth *and* API-key supported. Active list + Marketplace UI in the dashboard. |
25
+ | 📡 &nbsp;**MCP support** | Connect Streamable HTTP MCP servers — per-job tool discovery, tool whitelisting, multi-instance. |
26
+ | 💬 &nbsp;**Telegram out of the box** | Long-polling, multi-agent routing (`/ask <slug>`), group-chat filters, conversation continuity, delegation gracefulness on Telegram. |
27
+ | ⚙️ &nbsp;**Real engineering** | TypeScript strict, dependency-cruiser-enforced architecture, full unit + integration suite, Playwright e2e, idempotent migrations, encryption at rest for keys. |
28
+
29
+ ---
30
+
31
+ ## Install
32
+
33
+ ```bash
34
+ npm install -g nodal-agents
35
+ nodal-agents up
36
+ ```
37
+
38
+ Open <http://localhost:3000>. The CLI spawns an embedded Postgres on a
39
+ free port, applies migrations, seeds the system skills, and starts the
40
+ runner (`:3001`) and dashboard (`:3000`). Configure your LLM provider
41
+ from **Settings → LLM Keys** in the dashboard.
42
+
43
+ > Requires Node 22+. No external Postgres, no Redis, no cloud config.
44
+ > Data lives at `~/.nodalai/` — wipe with `rm -rf ~/.nodalai`.
45
+
46
+ To stop the stack: `nodal-agents down`.
47
+
48
+ ### Build from source
49
+
50
+ ```bash
51
+ git clone https://github.com/Kwintspiracy/nodal-agents.git
52
+ cd nodal-agents
53
+ pnpm install
54
+ pnpm --filter nodal-agents exec tsx src/index.ts --dev
55
+ ```
56
+
57
+ Dev mode runs `next dev` so the dashboard hot-reloads on file changes.
58
+
59
+ ---
60
+
61
+ ## How it works
62
+
63
+ ```
64
+ ┌─────────────┐ Telegram / ┌────────────────────────────────┐
65
+ │ Channel │ Dashboard ───▶ │ Runner (Hono) │
66
+ │ (telegram, │ POST /api ◀── │ • Job queue + executor │
67
+ │ web …) │ │ • Anti-runaway guards │
68
+ └─────────────┘ │ • Per-agent tool whitelist │
69
+ │ • Memory auto-injection │
70
+ │ • Session-thread continuity │
71
+ └─────────┬──────────┬────────────┘
72
+ │ │
73
+ ┌───────▼───┐ ┌───▼─────────────┐
74
+ │ LLM │ │ Connectors / │
75
+ │ client │ │ MCP servers │
76
+ (multi- │ │ (Gmail, Drive,
77
+ provider) │ │ Notion, Cogni
78
+ └───────────┘ │ Cortex …) │
79
+ └─────────────────┘
80
+ ```
81
+
82
+ Every agent is a row in Postgres — personality, skills, connectors,
83
+ memory budget, team assignments live in the database. The runtime is
84
+ generic: **zero hardcoded agent metadata.** Adding capabilities means
85
+ inserting rows, not editing code.
86
+
87
+ A user message via Telegram becomes an `agent_jobs` row. The runner
88
+ loads the agent's prior chat-thread history, injects relevant
89
+ persistent memories, dispatches to the LLM, executes any tool calls
90
+ emitted, and finalizes via `telegram_send_message` + `return_result`.
91
+ Delegations create child jobs that resume the parent on completion.
92
+
93
+ ---
94
+
95
+ ## Dashboard
96
+
97
+ | Route | Purpose |
98
+ | --- | --- |
99
+ | `/agents` | Create, edit, assign skills + connectors + MCP servers to agents. |
100
+ | `/jobs` | Live job stream — task, agent, status, full transcript, tool I/O. |
101
+ | `/connectors` | Active connector instances + Marketplace (multi-instance, OAuth or API-key). |
102
+ | `/mcp` | Active MCP servers + Marketplace (HTTP transport). |
103
+ | `/memories` | Persistent facts per entity — search, edit, archive. |
104
+ | `/skills` | Procedural memory blocks — shipped with the product, user-overridable. |
105
+ | `/logs` | Tool-call audit — input/output JSON per call, filterable by tool name. |
106
+ | `/approvals` | Human-in-the-loop gates for risky tools. |
107
+ | `/automations` | Cron-scheduled agent triggers. |
108
+ | `/settings` | LLM keys, auth mode, network (loopback / LAN), bot tokens. |
109
+
110
+ ---
111
+
112
+ ## Stack
113
+
114
+ | Layer | Tech |
115
+ | --- | --- |
116
+ | Runtime | Node 22+, TypeScript strict (no `any`, no `@ts-ignore` without comment) |
117
+ | Monorepo | pnpm workspaces + Turborepo |
118
+ | Database | embedded-postgres (Win / Mac / Linux), Drizzle ORM, idempotent migrations |
119
+ | Validation | Zod everywhere |
120
+ | HTTP server | Hono (runner), Next.js 16 (dashboard) |
121
+ | LLM | Vercel AI SDK — multi-provider with retry + timeout + tolerant parsing |
122
+ | Auth | local-trust (single-user loopback) / better-auth (multi-user LAN) / bearer-token |
123
+ | Encryption | AES-256-GCM at rest for API keys, master key in `~/.nodalai/secrets.key` |
124
+ | Tests | Vitest (unit + integration), Playwright (e2e), dependency-cruiser (architecture) |
125
+
126
+ ---
127
+
128
+ ## Monorepo
129
+
130
+ ```
131
+ apps/
132
+ ├── cli nodal-agents CLI: install, up, down, ops
133
+ ├── runner Hono server: job execution, cron, channel pollers
134
+ └── web Next.js dashboard
135
+
136
+ packages/
137
+ ├── db Drizzle schema + migrations + client (only postgres importer)
138
+ ├── shared Zod types + constants shared across web + runner
139
+ ├── llm Vercel AI SDK wrapper, retry, timeout, native tool-call parsers
140
+ ├── tools Tool registration + execution + approval gates
141
+ ├── memory Persistent memory CRUD + sanitation + dedup + auto-injection
142
+ ├── orchestration Router / Planner patterns, delegation, chain counters
143
+ ├── adapters Connector packages (gmail, drive, sheets, docs, notion,
144
+ │ airtable, apify, firecrawl, tavily, MCP)
145
+ ├── runner-adapters Adapter registry, agent ↔ tool wiring
146
+ ├── delivery Telegram, email
147
+ ├── auth Pluggable auth provider
148
+ ├── catalog Shipped system skills (telegram-responder, obsidian,
149
+ │ research-scope-discipline, claude-html-design)
150
+ └── secrets AES-256-GCM key vault
151
+ ```
152
+
153
+ ---
154
+
155
+ ## Architecture rules (enforced by `dependency-cruiser`)
156
+
157
+ - `apps/*` may import `packages/*` — never the reverse.
158
+ - `apps/web` and `apps/runner` cannot import each other (DB or HTTP only).
159
+ - Only `packages/db` may import `postgres` / `drizzle-orm` / `pg`.
160
+ - `packages/runner-adapters/*` may only import from `packages/tools` and
161
+ `packages/shared`.
162
+ - No circular dependencies.
163
+
164
+ ```bash
165
+ pnpm deps:check # runs locally and in CI before every release
166
+ ```
167
+
168
+ ---
169
+
170
+ ## Status
171
+
172
+ **Current release:** `0.1.5` on npm `latest`. Used daily by the
173
+ maintainer, stable enough for personal production. Pre-1.0 — breaking
174
+ changes are still possible between minors.
175
+
176
+ ### Shipped and working
177
+
178
+ - Multi-LLM provider routing with per-agent keys
179
+ - Persistent memory (sanitation, dedup, importance ranking, auto-injection,
180
+ feedback loop)
181
+ - Session-thread continuity on chat channels (Telegram today)
182
+ - Orchestrator (router + planner) with delegation chains and anti-runaway
183
+ caps
184
+ - Multi-instance connectors with OAuth (Gmail, Drive, Sheets, Docs, Notion,
185
+ Airtable) and API-key (Notion, Airtable, Apify, Firecrawl, Tavily)
186
+ - MCP Streamable HTTP catalog with API-key auth
187
+ - Telegram delivery (long-poll, group filters, multi-agent routing,
188
+ delegation gracefulness)
189
+ - Approval gates for risky tools
190
+ - Cron scheduling
191
+ - Encryption at rest for LLM keys + MCP keys
192
+ - Embedded Postgres distribution via npm (no external DB to install)
193
+
194
+ ### On the roadmap (genuine, not vaporware)
195
+
196
+ - **MCP OAuth flow** → unlocks Linear, Notion remote, GitHub remote,
197
+ Atlassian, Sentry, and the rest of the SaaS-as-MCP ecosystem.
198
+ - **MCP stdio transport** → unlocks the Anthropic reference servers
199
+ (filesystem, sqlite, brave-search, GitHub stdio…) and the community
200
+ catalog.
201
+ - **pgvector binaries bundled in the npm pack** → semantic memory search
202
+ active out-of-the-box. Today, installs without pgvector fall back to
203
+ keyword search (which works, just less smart for cross-vocabulary
204
+ recall).
205
+ - Data migration tools from the legacy Python stack.
206
+
207
+ ---
208
+
209
+ ## License
210
+
211
+ TBD.
package/cli.js CHANGED
@@ -12990,7 +12990,7 @@ var init_mcp = __esm({
12990
12990
  check("mcp_servers_transport_check", sql`${table.transport} IN ('http','stdio')`),
12991
12991
  check(
12992
12992
  "mcp_servers_auth_scheme_check",
12993
- sql`${table.authScheme} IN ('header','query') OR ${table.authScheme} IS NULL`
12993
+ sql`${table.authScheme} IN ('header','query','bearer') OR ${table.authScheme} IS NULL`
12994
12994
  )
12995
12995
  // Multi-instance brique (migration 0017): the (entity_id, slug) UNIQUE
12996
12996
  // index was dropped to allow multiple instances of the same MCP server
@@ -13464,10 +13464,11 @@ function buildEnvForWeb(config, databaseUrl) {
13464
13464
  // readConfig() guarantees this is set (auto-mints on first read).
13465
13465
  NEXT_SERVER_ACTIONS_ENCRYPTION_KEY: config.serverActionsKey ?? "",
13466
13466
  // The Next.js standalone server reads HOSTNAME for its listener bind
13467
- // (defaults to '0.0.0.0' when unset). Docker sets HOSTNAME to the
13468
- // container ID, which Next interprets as the hostname to bind on —
13469
- // resolving via /etc/hosts to 127.0.0.1 only, breaking port forwarding
13470
- // and the `localhost:3000` healthcheck. Pin to the loopback/lan choice.
13467
+ // (defaults to '0.0.0.0' when unset). Some host environments set
13468
+ // HOSTNAME to an arbitrary identifier (e.g. a runner ID), which Next
13469
+ // would interpret as the hostname to bind on usually resolving via
13470
+ // /etc/hosts to 127.0.0.1 only, breaking port forwarding and the
13471
+ // `localhost:3000` healthcheck. Pin to the loopback/lan choice.
13471
13472
  HOSTNAME: bind
13472
13473
  };
13473
13474
  if (config.llm) {
@@ -0,0 +1,12 @@
1
+ -- Migration 0018 — relax mcp_servers.auth_scheme to allow 'bearer'.
2
+ --
3
+ -- Brique A v3 (MCP catalog enrichment): adds the 'bearer' auth scheme so
4
+ -- catalog entries for servers expecting `Authorization: Bearer <token>`
5
+ -- (Stripe, OpenAI, etc.) can be represented and connected without a
6
+ -- bespoke per-server hack. The adapter injects the literal "Bearer "
7
+ -- prefix when this scheme is selected; authParamName is ignored.
8
+
9
+ ALTER TABLE "mcp_servers" DROP CONSTRAINT IF EXISTS "mcp_servers_auth_scheme_check";
10
+ --> statement-breakpoint
11
+ ALTER TABLE "mcp_servers" ADD CONSTRAINT "mcp_servers_auth_scheme_check"
12
+ CHECK ("auth_scheme" IN ('header','query','bearer') OR "auth_scheme" IS NULL);
@@ -1,132 +1,139 @@
1
- {
2
- "version": "7",
3
- "dialect": "postgresql",
4
- "entries": [
5
- {
6
- "idx": 0,
7
- "version": "7",
8
- "when": 1777221376983,
9
- "tag": "0000_flashy_clea",
10
- "breakpoints": true
11
- },
12
- {
13
- "idx": 1,
14
- "version": "7",
15
- "when": 1777222639218,
16
- "tag": "0001_exotic_shooting_star",
17
- "breakpoints": true
18
- },
19
- {
20
- "idx": 2,
21
- "version": "7",
22
- "when": 1777222668100,
23
- "tag": "0002_gray_devos",
24
- "breakpoints": true
25
- },
26
- {
27
- "idx": 3,
28
- "version": "7",
29
- "when": 1778116559502,
30
- "tag": "0003_stormy_thaddeus_ross",
31
- "breakpoints": true
32
- },
33
- {
34
- "idx": 4,
35
- "version": "7",
36
- "when": 1778141889404,
37
- "tag": "0004_married_deadpool",
38
- "breakpoints": true
39
- },
40
- {
41
- "idx": 5,
42
- "version": "7",
43
- "when": 1778237574443,
44
- "tag": "0005_tense_hedge_knight",
45
- "breakpoints": true
46
- },
47
- {
48
- "idx": 6,
49
- "version": "7",
50
- "when": 1778341607214,
51
- "tag": "0006_credentials_table",
52
- "breakpoints": true
53
- },
54
- {
55
- "idx": 7,
56
- "version": "7",
57
- "when": 1778421836079,
58
- "tag": "0007_free_speed",
59
- "breakpoints": true
60
- },
61
- {
62
- "idx": 8,
63
- "version": "7",
64
- "when": 1778459305708,
65
- "tag": "0008_curious_thor_girl",
66
- "breakpoints": true
67
- },
68
- {
69
- "idx": 9,
70
- "version": "7",
71
- "when": 1778860776473,
72
- "tag": "0009_agent_memory_token_budget",
73
- "breakpoints": true
74
- },
75
- {
76
- "idx": 10,
77
- "version": "7",
78
- "when": 1778940762250,
79
- "tag": "0010_agent_workspace_root",
80
- "breakpoints": true
81
- },
82
- {
83
- "idx": 11,
84
- "version": "7",
85
- "when": 1779000000000,
86
- "tag": "0011_agent_jobs_failed_delegations_count",
87
- "breakpoints": true
88
- },
89
- {
90
- "idx": 12,
91
- "version": "7",
92
- "when": 1779100000000,
93
- "tag": "0012_agent_jobs_last_failed_delegation_slug",
94
- "breakpoints": true
95
- },
96
- {
97
- "idx": 13,
98
- "version": "7",
99
- "when": 1779200000000,
100
- "tag": "0013_cascade_agent_fks",
101
- "breakpoints": true
102
- },
103
- {
104
- "idx": 14,
105
- "version": "7",
106
- "when": 1779400000000,
107
- "tag": "0014_mcp_server_credentials",
108
- "breakpoints": true
109
- },
110
- {
111
- "idx": 15,
112
- "version": "7",
113
- "when": 1779500000000,
114
- "tag": "0015_agent_mcp_servers_unique",
115
- "breakpoints": true
116
- },
117
- {
118
- "idx": 16,
119
- "version": "7",
120
- "when": 1779600000000,
121
- "tag": "0016_drop_connector_entity_slug_unique",
122
- "breakpoints": true
123
- },
124
- {
125
- "idx": 17,
126
- "version": "7",
127
- "when": 1779700000000,
128
- "tag": "0017_drop_mcp_server_entity_slug_unique",
129
- "breakpoints": true
130
- }
131
- ]
132
- }
1
+ {
2
+ "version": "7",
3
+ "dialect": "postgresql",
4
+ "entries": [
5
+ {
6
+ "idx": 0,
7
+ "version": "7",
8
+ "when": 1777221376983,
9
+ "tag": "0000_flashy_clea",
10
+ "breakpoints": true
11
+ },
12
+ {
13
+ "idx": 1,
14
+ "version": "7",
15
+ "when": 1777222639218,
16
+ "tag": "0001_exotic_shooting_star",
17
+ "breakpoints": true
18
+ },
19
+ {
20
+ "idx": 2,
21
+ "version": "7",
22
+ "when": 1777222668100,
23
+ "tag": "0002_gray_devos",
24
+ "breakpoints": true
25
+ },
26
+ {
27
+ "idx": 3,
28
+ "version": "7",
29
+ "when": 1778116559502,
30
+ "tag": "0003_stormy_thaddeus_ross",
31
+ "breakpoints": true
32
+ },
33
+ {
34
+ "idx": 4,
35
+ "version": "7",
36
+ "when": 1778141889404,
37
+ "tag": "0004_married_deadpool",
38
+ "breakpoints": true
39
+ },
40
+ {
41
+ "idx": 5,
42
+ "version": "7",
43
+ "when": 1778237574443,
44
+ "tag": "0005_tense_hedge_knight",
45
+ "breakpoints": true
46
+ },
47
+ {
48
+ "idx": 6,
49
+ "version": "7",
50
+ "when": 1778341607214,
51
+ "tag": "0006_credentials_table",
52
+ "breakpoints": true
53
+ },
54
+ {
55
+ "idx": 7,
56
+ "version": "7",
57
+ "when": 1778421836079,
58
+ "tag": "0007_free_speed",
59
+ "breakpoints": true
60
+ },
61
+ {
62
+ "idx": 8,
63
+ "version": "7",
64
+ "when": 1778459305708,
65
+ "tag": "0008_curious_thor_girl",
66
+ "breakpoints": true
67
+ },
68
+ {
69
+ "idx": 9,
70
+ "version": "7",
71
+ "when": 1778860776473,
72
+ "tag": "0009_agent_memory_token_budget",
73
+ "breakpoints": true
74
+ },
75
+ {
76
+ "idx": 10,
77
+ "version": "7",
78
+ "when": 1778940762250,
79
+ "tag": "0010_agent_workspace_root",
80
+ "breakpoints": true
81
+ },
82
+ {
83
+ "idx": 11,
84
+ "version": "7",
85
+ "when": 1779000000000,
86
+ "tag": "0011_agent_jobs_failed_delegations_count",
87
+ "breakpoints": true
88
+ },
89
+ {
90
+ "idx": 12,
91
+ "version": "7",
92
+ "when": 1779100000000,
93
+ "tag": "0012_agent_jobs_last_failed_delegation_slug",
94
+ "breakpoints": true
95
+ },
96
+ {
97
+ "idx": 13,
98
+ "version": "7",
99
+ "when": 1779200000000,
100
+ "tag": "0013_cascade_agent_fks",
101
+ "breakpoints": true
102
+ },
103
+ {
104
+ "idx": 14,
105
+ "version": "7",
106
+ "when": 1779400000000,
107
+ "tag": "0014_mcp_server_credentials",
108
+ "breakpoints": true
109
+ },
110
+ {
111
+ "idx": 15,
112
+ "version": "7",
113
+ "when": 1779500000000,
114
+ "tag": "0015_agent_mcp_servers_unique",
115
+ "breakpoints": true
116
+ },
117
+ {
118
+ "idx": 16,
119
+ "version": "7",
120
+ "when": 1779600000000,
121
+ "tag": "0016_drop_connector_entity_slug_unique",
122
+ "breakpoints": true
123
+ },
124
+ {
125
+ "idx": 17,
126
+ "version": "7",
127
+ "when": 1779700000000,
128
+ "tag": "0017_drop_mcp_server_entity_slug_unique",
129
+ "breakpoints": true
130
+ },
131
+ {
132
+ "idx": 18,
133
+ "version": "7",
134
+ "when": 1779800000000,
135
+ "tag": "0018_mcp_servers_bearer_auth",
136
+ "breakpoints": true
137
+ }
138
+ ]
139
+ }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "nodal-agents",
3
- "version": "0.1.4",
3
+ "version": "0.1.6",
4
4
  "description": "Local-first AI agent platform — self-host on Mac, PC, Linux, VPS, or NAS.",
5
5
  "license": "MIT",
6
6
  "repository": {
@@ -52,7 +52,6 @@
52
52
  "@mendable/firecrawl-js": "^4.22.0",
53
53
  "@tavily/core": "^0.7.0",
54
54
  "apify-client": "^2.23.0",
55
- "exceljs": "^4.4.0",
56
55
  "pdf-parse": "^2.4.5",
57
56
  "mammoth": "^1.9.0",
58
57
  "@napi-rs/canvas": "^0.1.80",