dbrain 0.1.0

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 (76) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +205 -0
  3. package/dist/cli/connect.d.ts +2 -0
  4. package/dist/cli/connect.d.ts.map +1 -0
  5. package/dist/cli/connect.js +108 -0
  6. package/dist/cli/connect.js.map +1 -0
  7. package/dist/cli/index.d.ts +3 -0
  8. package/dist/cli/index.d.ts.map +1 -0
  9. package/dist/cli/index.js +46 -0
  10. package/dist/cli/index.js.map +1 -0
  11. package/dist/cli/init.d.ts +4 -0
  12. package/dist/cli/init.d.ts.map +1 -0
  13. package/dist/cli/init.js +177 -0
  14. package/dist/cli/init.js.map +1 -0
  15. package/dist/cli/start.d.ts +2 -0
  16. package/dist/cli/start.d.ts.map +1 -0
  17. package/dist/cli/start.js +33 -0
  18. package/dist/cli/start.js.map +1 -0
  19. package/dist/cli/status.d.ts +2 -0
  20. package/dist/cli/status.d.ts.map +1 -0
  21. package/dist/cli/status.js +30 -0
  22. package/dist/cli/status.js.map +1 -0
  23. package/dist/core/config.d.ts +15 -0
  24. package/dist/core/config.d.ts.map +1 -0
  25. package/dist/core/config.js +24 -0
  26. package/dist/core/config.js.map +1 -0
  27. package/dist/core/db.d.ts +4 -0
  28. package/dist/core/db.d.ts.map +1 -0
  29. package/dist/core/db.js +90 -0
  30. package/dist/core/db.js.map +1 -0
  31. package/dist/core/memory.d.ts +4 -0
  32. package/dist/core/memory.d.ts.map +1 -0
  33. package/dist/core/memory.js +9 -0
  34. package/dist/core/memory.js.map +1 -0
  35. package/dist/core/models.d.ts +67 -0
  36. package/dist/core/models.d.ts.map +1 -0
  37. package/dist/core/models.js +29 -0
  38. package/dist/core/models.js.map +1 -0
  39. package/dist/dashboard/index.html +676 -0
  40. package/dist/dashboard/server.d.ts +2 -0
  41. package/dist/dashboard/server.d.ts.map +1 -0
  42. package/dist/dashboard/server.js +20 -0
  43. package/dist/dashboard/server.js.map +1 -0
  44. package/dist/mcp/server.d.ts +5 -0
  45. package/dist/mcp/server.d.ts.map +1 -0
  46. package/dist/mcp/server.js +386 -0
  47. package/dist/mcp/server.js.map +1 -0
  48. package/dist/server/index.d.ts +7 -0
  49. package/dist/server/index.d.ts.map +1 -0
  50. package/dist/server/index.js +41 -0
  51. package/dist/server/index.js.map +1 -0
  52. package/dist/server/routes/conversations.d.ts +3 -0
  53. package/dist/server/routes/conversations.d.ts.map +1 -0
  54. package/dist/server/routes/conversations.js +86 -0
  55. package/dist/server/routes/conversations.js.map +1 -0
  56. package/dist/server/routes/entities.d.ts +3 -0
  57. package/dist/server/routes/entities.d.ts.map +1 -0
  58. package/dist/server/routes/entities.js +51 -0
  59. package/dist/server/routes/entities.js.map +1 -0
  60. package/dist/server/routes/facts.d.ts +3 -0
  61. package/dist/server/routes/facts.d.ts.map +1 -0
  62. package/dist/server/routes/facts.js +41 -0
  63. package/dist/server/routes/facts.js.map +1 -0
  64. package/dist/server/routes/health.d.ts +3 -0
  65. package/dist/server/routes/health.d.ts.map +1 -0
  66. package/dist/server/routes/health.js +72 -0
  67. package/dist/server/routes/health.js.map +1 -0
  68. package/dist/server/routes/search.d.ts +3 -0
  69. package/dist/server/routes/search.d.ts.map +1 -0
  70. package/dist/server/routes/search.js +60 -0
  71. package/dist/server/routes/search.js.map +1 -0
  72. package/dist/server/routes/workspace.d.ts +3 -0
  73. package/dist/server/routes/workspace.d.ts.map +1 -0
  74. package/dist/server/routes/workspace.js +34 -0
  75. package/dist/server/routes/workspace.js.map +1 -0
  76. package/package.json +82 -0
package/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2026 Iván Campillo
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
package/README.md ADDED
@@ -0,0 +1,205 @@
1
+ <p align="center">
2
+ <img src="logo.png" alt="dbrain" width="600">
3
+ </p>
4
+
5
+ <p align="center">
6
+ <a href="https://www.npmjs.com/package/dbrain"><img src="https://img.shields.io/npm/v/dbrain?style=for-the-badge" alt="npm"></a>
7
+ <a href="LICENSE"><img src="https://img.shields.io/badge/License-MIT-blue.svg?style=for-the-badge" alt="License"></a>
8
+ <a href="https://nodejs.org"><img src="https://img.shields.io/badge/node-%3E%3D20-green?style=for-the-badge" alt="Node"></a>
9
+ </p>
10
+
11
+ ---
12
+
13
+ Every AI conversation starts from zero. Switch machines, switch apps, and your AI forgets everything. **dbrain** fixes that.
14
+
15
+ Install it once, connect every AI you use — Claude Code at home, Claude Code at work, Gemini on your phone. All share the same identity, the same memories, the same knowledge.
16
+
17
+ ```
18
+ [Home] Claude Code ──MCP──┐
19
+ [Work] Claude Code ──MCP──┤ ┌─────────────────────────────────┐
20
+ [Mobile] Gemini ──REST──────┼────→│ dbrain (your mind) │
21
+ [Server] OpenClaw ──REST────┤ │ identity + memory + knowledge. │
22
+ [Other] Custom AI ──API────┘ └─────────────────────────────────┘
23
+ ```
24
+
25
+ Not an AI agent. Not an assistant. Not a model. **Just memory** — structured, searchable, persistent.
26
+
27
+ ## Quick Start
28
+
29
+ ```bash
30
+ npm install -g dbrain
31
+ dbrain init # interactive wizard — creates DB, config, identity
32
+ dbrain start # starts API on :7878 + dashboard on :7879
33
+ ```
34
+
35
+ Then connect Claude Code from any machine:
36
+
37
+ ```bash
38
+ dbrain connect
39
+ ```
40
+
41
+ The wizard asks for the brain URL and token (shown during `init`):
42
+
43
+ ```
44
+ ┌ dbrain — Connect to a brain
45
+
46
+ ◇ Brain URL
47
+ │ http://localhost:7878
48
+
49
+ ◇ Access token
50
+ │ sk-dbr_...
51
+
52
+ ◇ Brain found
53
+
54
+ ● Brain: dBrain — 2 entities, 0 facts
55
+
56
+ ◇ Claude Code configured
57
+
58
+ ◇ Files updated ──────────────────────────────────────────────╮
59
+ │ │
60
+ │ ~/.claude.json MCP server registered │
61
+ │ ~/.claude/settings.json Permissions granted │
62
+ │ ~/.claude/CLAUDE.md Behavioral instructions installed │
63
+ │ │
64
+ ├──────────────────────────────────────────────────────────────╯
65
+
66
+ └ Connected. Restart Claude Code to activate.
67
+ ```
68
+
69
+ Restart Claude Code and it will start using the brain. You can also skip the wizard:
70
+
71
+ ```bash
72
+ dbrain connect http://your-server:7878 --token=sk-dbr_...
73
+ ```
74
+
75
+ ## Docker
76
+
77
+ ```bash
78
+ git clone https://github.com/ivncmp/dbrain.git
79
+ cd dbrain
80
+ cp .env.example .env # edit token, names, port
81
+ docker compose up -d
82
+ ```
83
+
84
+ Then from any client machine:
85
+
86
+ ```bash
87
+ dbrain connect http://your-server:7878
88
+ ```
89
+
90
+ ## How It Works
91
+
92
+ The brain has 4 layers:
93
+
94
+ | Layer | What | How |
95
+ | ----------------- | ----------------------------------------------------- | ---------------------------------------------------- |
96
+ | **Identity** | Who is the AI? Who is the user? How should it behave? | `documents` table |
97
+ | **Conversations** | Raw chat history from every AI session | `conversations` + `messages` tables |
98
+ | **Knowledge** | Structured facts organized by PARA | `entities` + `facts` tables with hot/warm/cold tiers |
99
+ | **Recall** | Full-text search over all facts | FTS5 with OR logic for multi-language queries |
100
+
101
+ ### Memory Tiers
102
+
103
+ Memories fade if you don't use them — like a real brain.
104
+
105
+ | Tier | Rule |
106
+ | -------- | ------------------------------------------------- |
107
+ | **hot** | Accessed in the last 7 days, or accessCount >= 10 |
108
+ | **warm** | 8–30 days since last access |
109
+ | **cold** | > 30 days — fading, candidate for archival |
110
+
111
+ Every search bumps accessed facts back to hot. The brain stays sharp on what matters.
112
+
113
+ ## MCP Tools
114
+
115
+ Available to any MCP client (Claude Code, etc.):
116
+
117
+ | Tool | Purpose |
118
+ | --------------- | ------------------------------------------- |
119
+ | `recall` | Search memory + get identity (primary tool) |
120
+ | `remember` | Save a fact to an entity |
121
+ | `get_entity` | Read entity with all its facts |
122
+ | `list_entities` | List entities by category or type |
123
+ | `create_entity` | Create a new entity |
124
+ | `bump` | Touch a memory to keep it hot |
125
+ | `log` | Send conversation messages for storage |
126
+ | `wake_up` | Full identity load |
127
+ | `overview` | Brain stats |
128
+
129
+ ## REST API
130
+
131
+ All endpoints require `Authorization: Bearer <token>` except `/health`.
132
+
133
+ | Method | Endpoint | Purpose |
134
+ | ----------------- | --------------------- | ---------------------------------------------- |
135
+ | `GET` | `/health` | Brain pulse |
136
+ | `GET` | `/connect` | Client config (MCP, permissions, instructions) |
137
+ | `GET/PUT/DELETE` | `/workspace/:key` | Identity documents |
138
+ | `GET/POST/DELETE` | `/entities/:id` | Knowledge entities |
139
+ | `POST` | `/entities/:id/facts` | Add facts to an entity |
140
+ | `PATCH` | `/facts/:id/access` | Bump a memory (keep it hot) |
141
+ | `GET/POST` | `/conversations` | Chat history |
142
+ | `POST` | `/search` | Full-text search over all facts |
143
+ | `GET` | `/memory/summary` | Overview: entities x tiers |
144
+
145
+ ## CLI Commands
146
+
147
+ | Command | Where | Purpose |
148
+ | ---------------------- | ------ | ----------------------------------------- |
149
+ | `dbrain init [path]` | Server | Create a new brain (DB, config, identity) |
150
+ | `dbrain start [path]` | Server | Start the API server + dashboard |
151
+ | `dbrain connect [url]` | Client | Connect Claude Code to a running brain |
152
+ | `dbrain status [path]` | Server | Check brain status |
153
+
154
+ `init` runs on the **server** (creates the brain). `connect` runs on the **client** (configures Claude Code). The brain serves its own client config via `GET /connect`.
155
+
156
+ ## Dashboard
157
+
158
+ Web dashboard on port `7879`. Shows brain stats, entities with PARA categories, fact tiers, conversations, and full-text search. Single-file React app — no build step.
159
+
160
+ ## Stack
161
+
162
+ | Layer | Technology |
163
+ | ---------- | ------------------------------------------ |
164
+ | Language | Node.js + TypeScript |
165
+ | API | Fastify |
166
+ | DB | SQLite + FTS5 (better-sqlite3) |
167
+ | MCP | @modelcontextprotocol/sdk (HTTP transport) |
168
+ | Validation | Zod |
169
+ | CLI | @clack/prompts |
170
+ | Dashboard | React 18 (CDN, no build step) |
171
+
172
+ ## Development
173
+
174
+ ```bash
175
+ git clone https://github.com/ivncmp/dbrain.git
176
+ cd dbrain
177
+ npm install # installs deps + builds (prepare script)
178
+ npx dbrain init # create a brain (only needed once)
179
+ npm run dev # starts the server with file watching
180
+ ```
181
+
182
+ | Script | What it does |
183
+ | --------------- | ---------------------------------------- |
184
+ | `npm run dev` | Dev server with file watching (tsx) |
185
+ | `npm run build` | Compile TypeScript + copy dashboard HTML |
186
+ | `npm start` | Start the compiled server from `dist/` |
187
+ | `npm test` | Run tests with vitest |
188
+
189
+ ## Environment Variables
190
+
191
+ For non-interactive setup (Docker, CI):
192
+
193
+ | Variable | Default | Purpose |
194
+ | ------------------- | -------------- | ---------------- |
195
+ | `DBRAIN_DATA` | `~/.dbrain` | Data path |
196
+ | `DBRAIN_PORT` | `7878` | API port |
197
+ | `DBRAIN_HOST` | `0.0.0.0` | Bind address |
198
+ | `DBRAIN_TOKEN` | Auto-generated | Access token |
199
+ | `DBRAIN_AGENT_NAME` | `dBrain` | AI identity name |
200
+ | `DBRAIN_OWNER_NAME` | `Human` | Owner name |
201
+ | `DBRAIN_TIMEZONE` | Auto-detected | Owner timezone |
202
+
203
+ ## License
204
+
205
+ [MIT](LICENSE)
@@ -0,0 +1,2 @@
1
+ export declare function connect(url?: string, tokenArg?: string): Promise<void>;
2
+ //# sourceMappingURL=connect.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"connect.d.ts","sourceRoot":"","sources":["../../src/cli/connect.ts"],"names":[],"mappings":"AAOA,wBAAsB,OAAO,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,MAAM,iBAiH5D"}
@@ -0,0 +1,108 @@
1
+ import { existsSync, readFileSync, writeFileSync, mkdirSync } from 'node:fs';
2
+ import { homedir } from 'node:os';
3
+ import { join } from 'node:path';
4
+ import * as p from '@clack/prompts';
5
+ import pc from 'picocolors';
6
+ export async function connect(url, tokenArg) {
7
+ p.intro(pc.cyan('dbrain') + ' — Connect to a brain');
8
+ if (!url) {
9
+ const input = await p.text({
10
+ message: 'Brain URL',
11
+ placeholder: 'http://your-server:7878',
12
+ validate: (v) => (!v || v.length === 0 ? 'URL is required' : undefined),
13
+ });
14
+ if (p.isCancel(input)) {
15
+ p.cancel('Cancelled.');
16
+ process.exit(0);
17
+ }
18
+ url = input;
19
+ }
20
+ url = url.replace(/\/+$/, '');
21
+ if (!tokenArg) {
22
+ const input = await p.text({
23
+ message: 'Access token',
24
+ placeholder: 'sk-dbr_...',
25
+ validate: (v) => (!v || v.length === 0 ? 'Token is required' : undefined),
26
+ });
27
+ if (p.isCancel(input)) {
28
+ p.cancel('Cancelled.');
29
+ process.exit(0);
30
+ }
31
+ tokenArg = input;
32
+ }
33
+ const s = p.spinner();
34
+ s.start('Connecting to brain');
35
+ let config;
36
+ try {
37
+ const res = await fetch(`${url}/connect`, {
38
+ headers: { Authorization: `Bearer ${tokenArg}` },
39
+ });
40
+ if (res.status === 401)
41
+ throw new Error('Invalid token');
42
+ if (!res.ok)
43
+ throw new Error(`HTTP ${res.status}`);
44
+ config = (await res.json());
45
+ }
46
+ catch (err) {
47
+ s.stop(pc.red('Failed to connect'));
48
+ const message = err instanceof Error ? err.message : String(err);
49
+ p.log.error(`Could not reach ${url}/connect — ${message}`);
50
+ p.log.info('Make sure the brain is running, the URL is correct, and the token is valid.');
51
+ p.outro(pc.red('Connection failed.'));
52
+ return;
53
+ }
54
+ s.stop('Brain found');
55
+ const healthRes = await fetch(`${url}/health`)
56
+ .then((r) => r.json())
57
+ .catch(() => null);
58
+ if (healthRes?.name) {
59
+ p.log.info(`Brain: ${pc.cyan(healthRes.name)} — ${healthRes.entities} entities, ${healthRes.facts} facts`);
60
+ }
61
+ s.start('Configuring Claude Code');
62
+ const claudeDir = join(homedir(), '.claude');
63
+ const claudeJson = join(homedir(), '.claude.json');
64
+ const settingsJson = join(claudeDir, 'settings.json');
65
+ const claudeMd = join(claudeDir, 'CLAUDE.md');
66
+ mkdirSync(claudeDir, { recursive: true });
67
+ let claudeConfig = {};
68
+ if (existsSync(claudeJson)) {
69
+ try {
70
+ claudeConfig = JSON.parse(readFileSync(claudeJson, 'utf-8'));
71
+ }
72
+ catch {
73
+ /* corrupt config, start fresh */
74
+ }
75
+ }
76
+ if (!claudeConfig.mcpServers)
77
+ claudeConfig.mcpServers = {};
78
+ Object.assign(claudeConfig.mcpServers, config.mcp);
79
+ writeFileSync(claudeJson, JSON.stringify(claudeConfig, null, 2) + '\n', 'utf-8');
80
+ let settings = {};
81
+ if (existsSync(settingsJson)) {
82
+ try {
83
+ settings = JSON.parse(readFileSync(settingsJson, 'utf-8'));
84
+ }
85
+ catch {
86
+ /* corrupt config, start fresh */
87
+ }
88
+ }
89
+ if (!settings.permissions)
90
+ settings.permissions = {};
91
+ if (!settings.permissions.allow)
92
+ settings.permissions.allow = [];
93
+ for (const perm of config.permissions) {
94
+ if (!settings.permissions.allow.includes(perm)) {
95
+ settings.permissions.allow.push(perm);
96
+ }
97
+ }
98
+ writeFileSync(settingsJson, JSON.stringify(settings, null, 2) + '\n', 'utf-8');
99
+ writeFileSync(claudeMd, config.claudeMd, 'utf-8');
100
+ s.stop('Claude Code configured');
101
+ p.note([
102
+ `${pc.green('~/.claude.json')} MCP server registered`,
103
+ `${pc.green('~/.claude/settings.json')} Permissions granted`,
104
+ `${pc.green('~/.claude/CLAUDE.md')} Behavioral instructions installed`,
105
+ ].join('\n'), 'Files updated');
106
+ p.outro(pc.green('Connected. Restart Claude Code to activate.'));
107
+ }
108
+ //# sourceMappingURL=connect.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"connect.js","sourceRoot":"","sources":["../../src/cli/connect.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ #!/usr/bin/env node
2
+ export {};
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/cli/index.ts"],"names":[],"mappings":""}
@@ -0,0 +1,46 @@
1
+ #!/usr/bin/env node
2
+ import { argv } from 'node:process';
3
+ const command = argv[2];
4
+ async function main() {
5
+ switch (command) {
6
+ case 'init': {
7
+ const { init } = await import('./init.js');
8
+ const nonInteractive = argv.includes('--non-interactive');
9
+ const pathArg = argv.slice(3).find((a) => !a.startsWith('--'));
10
+ await init(pathArg, { nonInteractive });
11
+ break;
12
+ }
13
+ case 'start': {
14
+ const { start } = await import('./start.js');
15
+ await start(argv[3]);
16
+ break;
17
+ }
18
+ case 'connect': {
19
+ const { connect } = await import('./connect.js');
20
+ const connectArgs = argv.slice(3).filter((a) => !a.startsWith('--'));
21
+ const tokenFlag = argv.find((a) => a.startsWith('--token='))?.split('=')[1];
22
+ await connect(connectArgs[0], tokenFlag);
23
+ break;
24
+ }
25
+ case 'status': {
26
+ const { status } = await import('./status.js');
27
+ await status(argv[3]);
28
+ break;
29
+ }
30
+ default:
31
+ console.log(`
32
+ dbrain — Your distributed mind. Wherever you go, I remember.
33
+
34
+ Usage:
35
+ dbrain init [path] Initialize a new brain (server)
36
+ dbrain start [path] Wake up
37
+ dbrain connect [url] [--token=] Connect Claude Code to a brain (client)
38
+ dbrain status [path] Check brain status
39
+ `);
40
+ }
41
+ }
42
+ main().catch((err) => {
43
+ console.error(err.message);
44
+ process.exit(1);
45
+ });
46
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/cli/index.ts"],"names":[],"mappings":";AAEA,OAAO,EAAE,IAAI,EAAE,MAAM,cAAc,CAAC;AAEpC,MAAM,OAAO,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;AAExB,KAAK,UAAU,IAAI;IACjB,QAAQ,OAAO,EAAE,CAAC;QAChB,KAAK,MAAM,CAAC,CAAC,CAAC;YACZ,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,MAAM,CAAC,WAAW,CAAC,CAAC;YAC3C,MAAM,cAAc,GAAG,IAAI,CAAC,QAAQ,CAAC,mBAAmB,CAAC,CAAC;YAC1D,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC;YAC/D,MAAM,IAAI,CAAC,OAAO,EAAE,EAAE,cAAc,EAAE,CAAC,CAAC;YACxC,MAAM;QACR,CAAC;QACD,KAAK,OAAO,CAAC,CAAC,CAAC;YACb,MAAM,EAAE,KAAK,EAAE,GAAG,MAAM,MAAM,CAAC,YAAY,CAAC,CAAC;YAC7C,MAAM,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;YACrB,MAAM;QACR,CAAC;QACD,KAAK,SAAS,CAAC,CAAC,CAAC;YACf,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,MAAM,CAAC,cAAc,CAAC,CAAC;YACjD,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC;YACrE,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;YAC5E,MAAM,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC;YACzC,MAAM;QACR,CAAC;QACD,KAAK,QAAQ,CAAC,CAAC,CAAC;YACd,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,MAAM,CAAC,aAAa,CAAC,CAAC;YAC/C,MAAM,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;YACtB,MAAM;QACR,CAAC;QACD;YACE,OAAO,CAAC,GAAG,CAAC;;;;;;;;CAQjB,CAAC,CAAC;IACD,CAAC;AACH,CAAC;AAED,IAAI,EAAE,CAAC,KAAK,CAAC,CAAC,GAAG,EAAE,EAAE;IACnB,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;IAC3B,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AAClB,CAAC,CAAC,CAAC"}
@@ -0,0 +1,4 @@
1
+ export declare function init(pathArg?: string, flags?: {
2
+ nonInteractive?: boolean;
3
+ }): Promise<void>;
4
+ //# sourceMappingURL=init.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"init.d.ts","sourceRoot":"","sources":["../../src/cli/init.ts"],"names":[],"mappings":"AAmBA,wBAAsB,IAAI,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE;IAAE,cAAc,CAAC,EAAE,OAAO,CAAA;CAAE,iBAwLhF"}
@@ -0,0 +1,177 @@
1
+ import { randomBytes } from 'node:crypto';
2
+ import { existsSync, writeFileSync, mkdirSync } from 'node:fs';
3
+ import { homedir } from 'node:os';
4
+ import { join, resolve } from 'node:path';
5
+ import * as p from '@clack/prompts';
6
+ import pc from 'picocolors';
7
+ import { createDatabase } from '../core/db.js';
8
+ function generateToken() {
9
+ return `sk-dbr_${randomBytes(24).toString('base64url')}`;
10
+ }
11
+ function defaultDataPath() {
12
+ return join(homedir(), '.dbrain');
13
+ }
14
+ export async function init(pathArg, flags) {
15
+ const nonInteractive = flags?.nonInteractive || process.env.DBRAIN_NON_INTERACTIVE === '1';
16
+ if (nonInteractive) {
17
+ return initNonInteractive(pathArg);
18
+ }
19
+ p.intro(pc.cyan('dbrain') + ' — Your distributed mind');
20
+ const existingPath = resolve(pathArg || defaultDataPath());
21
+ if (existsSync(join(existingPath, 'config.json'))) {
22
+ p.log.info(`Brain already exists at ${pc.green(existingPath)}`);
23
+ p.log.info(`To connect a client, run: ${pc.cyan('dbrain connect <url>')}`);
24
+ p.outro(pc.green('Done.'));
25
+ return;
26
+ }
27
+ const answers = await p.group({
28
+ dataPath: () => p.text({
29
+ message: 'Where should the brain live?',
30
+ initialValue: pathArg || defaultDataPath(),
31
+ validate: (v) => (!v || v.length === 0 ? 'Path is required' : undefined),
32
+ }),
33
+ port: () => p.text({
34
+ message: 'API port?',
35
+ initialValue: '7878',
36
+ validate: (v) => {
37
+ const n = parseInt(v ?? '', 10);
38
+ if (isNaN(n) || n < 1 || n > 65535)
39
+ return 'Invalid port';
40
+ },
41
+ }),
42
+ host: () => p.select({
43
+ message: 'Bind address?',
44
+ options: [
45
+ { value: '0.0.0.0', label: '0.0.0.0 — All interfaces (accessible from network)' },
46
+ { value: '127.0.0.1', label: '127.0.0.1 — Localhost only' },
47
+ ],
48
+ initialValue: '0.0.0.0',
49
+ }),
50
+ token: () => p.text({
51
+ message: 'Access token (leave default to auto-generate)',
52
+ initialValue: generateToken(),
53
+ }),
54
+ agentName: () => p.text({
55
+ message: "What's my name? (your AI's identity)",
56
+ initialValue: 'dBrain',
57
+ validate: (v) => (!v || v.length === 0 ? 'Name is required' : undefined),
58
+ }),
59
+ ownerName: () => p.text({
60
+ message: 'And you are...? (your name)',
61
+ validate: (v) => (!v || v.length === 0 ? 'Name is required' : undefined),
62
+ }),
63
+ ownerTimezone: () => p.text({
64
+ message: 'Your timezone',
65
+ initialValue: Intl.DateTimeFormat().resolvedOptions().timeZone,
66
+ }),
67
+ }, {
68
+ onCancel: () => {
69
+ p.cancel('Init cancelled.');
70
+ process.exit(0);
71
+ },
72
+ });
73
+ const dataPath = resolve(answers.dataPath.replace('~', homedir()));
74
+ if (existsSync(join(dataPath, 'config.json'))) {
75
+ p.log.info(`Brain already exists at ${pc.green(dataPath)}`);
76
+ p.log.info(`To connect a client, run: ${pc.cyan('dbrain connect <url>')}`);
77
+ p.outro(pc.green('Done.'));
78
+ return;
79
+ }
80
+ const port = parseInt(answers.port, 10);
81
+ const config = {
82
+ dataPath,
83
+ port,
84
+ host: answers.host,
85
+ token: answers.token,
86
+ tiers: { hotDays: 7, hotMinAccess: 10, warmDays: 30 },
87
+ };
88
+ const s = p.spinner();
89
+ s.start('Creating data directory');
90
+ mkdirSync(dataPath, { recursive: true });
91
+ writeFileSync(join(dataPath, 'config.json'), JSON.stringify(config, null, 2) + '\n', 'utf-8');
92
+ s.stop('Config saved');
93
+ s.start('Initializing database');
94
+ const db = createDatabase(config);
95
+ const now = new Date().toISOString();
96
+ const insertDoc = db.prepare('INSERT INTO documents (key, title, content, updated_at) VALUES (?, ?, ?, ?)');
97
+ insertDoc.run('identity', 'Identity', [
98
+ `# Identity`,
99
+ ``,
100
+ `- **Name:** ${answers.agentName}`,
101
+ `- **Created:** ${now.split('T')[0]}`,
102
+ ].join('\n'), now);
103
+ insertDoc.run('user', 'User', [
104
+ `# User`,
105
+ ``,
106
+ `- **Name:** ${answers.ownerName}`,
107
+ `- **Timezone:** ${answers.ownerTimezone}`,
108
+ ].join('\n'), now);
109
+ insertDoc.run('soul', 'Soul', [
110
+ `# Soul`,
111
+ ``,
112
+ `Be genuinely helpful, not performatively helpful.`,
113
+ `Have opinions. Be resourceful before asking.`,
114
+ `Private things stay private. When in doubt, ask before acting externally.`,
115
+ ].join('\n'), now);
116
+ insertDoc.run('memory', 'Memory', [`# Memory`, ``, `Narrative memory: reflections, decisions, learnings.`].join('\n'), now);
117
+ const insertEntity = db.prepare('INSERT INTO entities (id, name, type, category, created_at, updated_at) VALUES (?, ?, ?, ?, ?, ?)');
118
+ const ownerId = answers.ownerName.toLowerCase().replace(/\s+/g, '-');
119
+ const agentId = answers.agentName.toLowerCase().replace(/\s+/g, '-');
120
+ insertEntity.run(ownerId, answers.ownerName, 'person', 'areas', now, now);
121
+ insertEntity.run(agentId, answers.agentName, 'system', 'areas', now, now);
122
+ db.close();
123
+ s.stop(`Brain ready — I'm ${answers.agentName}, and I know ${answers.ownerName}`);
124
+ p.note([
125
+ `Data: ${pc.green(dataPath)}`,
126
+ `Port: ${pc.green(String(port))}`,
127
+ `Host: ${pc.green(config.host)}`,
128
+ `Token: ${pc.green(config.token)}`,
129
+ ].join('\n'), 'Configuration');
130
+ p.note([
131
+ `Start the server:`,
132
+ ` ${pc.cyan('dbrain start')}`,
133
+ ``,
134
+ `Then connect clients:`,
135
+ ` ${pc.cyan('dbrain connect http://localhost:' + port)}`,
136
+ ].join('\n'), 'Next steps');
137
+ p.outro(pc.green("Brain online. Wherever you go, I'll remember."));
138
+ }
139
+ function initNonInteractive(pathArg) {
140
+ const dataPath = resolve(pathArg || process.env.DBRAIN_DATA || defaultDataPath());
141
+ const port = parseInt(process.env.DBRAIN_PORT || '7878', 10);
142
+ const host = process.env.DBRAIN_HOST || '0.0.0.0';
143
+ const token = process.env.DBRAIN_TOKEN || generateToken();
144
+ const agentName = process.env.DBRAIN_AGENT_NAME || 'dBrain';
145
+ const ownerName = process.env.DBRAIN_OWNER_NAME || 'Human';
146
+ const ownerTimezone = process.env.DBRAIN_TIMEZONE || Intl.DateTimeFormat().resolvedOptions().timeZone;
147
+ if (existsSync(join(dataPath, 'config.json'))) {
148
+ console.log(`Config already exists at ${dataPath}, skipping init.`);
149
+ return;
150
+ }
151
+ const config = {
152
+ dataPath,
153
+ port,
154
+ host,
155
+ token,
156
+ tiers: { hotDays: 7, hotMinAccess: 10, warmDays: 30 },
157
+ };
158
+ mkdirSync(dataPath, { recursive: true });
159
+ writeFileSync(join(dataPath, 'config.json'), JSON.stringify(config, null, 2) + '\n', 'utf-8');
160
+ const db = createDatabase(config);
161
+ const now = new Date().toISOString();
162
+ const insertDoc = db.prepare('INSERT INTO documents (key, title, content, updated_at) VALUES (?, ?, ?, ?)');
163
+ insertDoc.run('identity', 'Identity', `# Identity\n\n- **Name:** ${agentName}\n- **Created:** ${now.split('T')[0]}`, now);
164
+ insertDoc.run('user', 'User', `# User\n\n- **Name:** ${ownerName}\n- **Timezone:** ${ownerTimezone}`, now);
165
+ insertDoc.run('soul', 'Soul', `# Soul\n\nBe genuinely helpful, not performatively helpful.\nHave opinions. Be resourceful before asking.\nPrivate things stay private. When in doubt, ask before acting externally.`, now);
166
+ insertDoc.run('memory', 'Memory', `# Memory\n\nNarrative memory: reflections, decisions, learnings.`, now);
167
+ const insertEntity = db.prepare('INSERT INTO entities (id, name, type, category, created_at, updated_at) VALUES (?, ?, ?, ?, ?, ?)');
168
+ const ownerId = ownerName.toLowerCase().replace(/\s+/g, '-');
169
+ const agentId = agentName.toLowerCase().replace(/\s+/g, '-');
170
+ insertEntity.run(ownerId, ownerName, 'person', 'areas', now, now);
171
+ insertEntity.run(agentId, agentName, 'system', 'areas', now, now);
172
+ db.close();
173
+ console.log(`Brain initialized at ${dataPath} (agent: ${agentName}, owner: ${ownerName})`);
174
+ console.log(`Token: ${token}`);
175
+ console.log(`Connect clients with: dbrain connect http://localhost:${port}`);
176
+ }
177
+ //# sourceMappingURL=init.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"init.js","sourceRoot":"","sources":["../../src/cli/init.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export declare function start(pathArg?: string): Promise<void>;
2
+ //# sourceMappingURL=start.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"start.d.ts","sourceRoot":"","sources":["../../src/cli/start.ts"],"names":[],"mappings":"AAeA,wBAAsB,KAAK,CAAC,OAAO,CAAC,EAAE,MAAM,iBAyB3C"}