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.
- package/LICENSE +21 -0
- package/README.md +205 -0
- package/dist/cli/connect.d.ts +2 -0
- package/dist/cli/connect.d.ts.map +1 -0
- package/dist/cli/connect.js +108 -0
- package/dist/cli/connect.js.map +1 -0
- package/dist/cli/index.d.ts +3 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +46 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/cli/init.d.ts +4 -0
- package/dist/cli/init.d.ts.map +1 -0
- package/dist/cli/init.js +177 -0
- package/dist/cli/init.js.map +1 -0
- package/dist/cli/start.d.ts +2 -0
- package/dist/cli/start.d.ts.map +1 -0
- package/dist/cli/start.js +33 -0
- package/dist/cli/start.js.map +1 -0
- package/dist/cli/status.d.ts +2 -0
- package/dist/cli/status.d.ts.map +1 -0
- package/dist/cli/status.js +30 -0
- package/dist/cli/status.js.map +1 -0
- package/dist/core/config.d.ts +15 -0
- package/dist/core/config.d.ts.map +1 -0
- package/dist/core/config.js +24 -0
- package/dist/core/config.js.map +1 -0
- package/dist/core/db.d.ts +4 -0
- package/dist/core/db.d.ts.map +1 -0
- package/dist/core/db.js +90 -0
- package/dist/core/db.js.map +1 -0
- package/dist/core/memory.d.ts +4 -0
- package/dist/core/memory.d.ts.map +1 -0
- package/dist/core/memory.js +9 -0
- package/dist/core/memory.js.map +1 -0
- package/dist/core/models.d.ts +67 -0
- package/dist/core/models.d.ts.map +1 -0
- package/dist/core/models.js +29 -0
- package/dist/core/models.js.map +1 -0
- package/dist/dashboard/index.html +676 -0
- package/dist/dashboard/server.d.ts +2 -0
- package/dist/dashboard/server.d.ts.map +1 -0
- package/dist/dashboard/server.js +20 -0
- package/dist/dashboard/server.js.map +1 -0
- package/dist/mcp/server.d.ts +5 -0
- package/dist/mcp/server.d.ts.map +1 -0
- package/dist/mcp/server.js +386 -0
- package/dist/mcp/server.js.map +1 -0
- package/dist/server/index.d.ts +7 -0
- package/dist/server/index.d.ts.map +1 -0
- package/dist/server/index.js +41 -0
- package/dist/server/index.js.map +1 -0
- package/dist/server/routes/conversations.d.ts +3 -0
- package/dist/server/routes/conversations.d.ts.map +1 -0
- package/dist/server/routes/conversations.js +86 -0
- package/dist/server/routes/conversations.js.map +1 -0
- package/dist/server/routes/entities.d.ts +3 -0
- package/dist/server/routes/entities.d.ts.map +1 -0
- package/dist/server/routes/entities.js +51 -0
- package/dist/server/routes/entities.js.map +1 -0
- package/dist/server/routes/facts.d.ts +3 -0
- package/dist/server/routes/facts.d.ts.map +1 -0
- package/dist/server/routes/facts.js +41 -0
- package/dist/server/routes/facts.js.map +1 -0
- package/dist/server/routes/health.d.ts +3 -0
- package/dist/server/routes/health.d.ts.map +1 -0
- package/dist/server/routes/health.js +72 -0
- package/dist/server/routes/health.js.map +1 -0
- package/dist/server/routes/search.d.ts +3 -0
- package/dist/server/routes/search.d.ts.map +1 -0
- package/dist/server/routes/search.js +60 -0
- package/dist/server/routes/search.js.map +1 -0
- package/dist/server/routes/workspace.d.ts +3 -0
- package/dist/server/routes/workspace.d.ts.map +1 -0
- package/dist/server/routes/workspace.js +34 -0
- package/dist/server/routes/workspace.js.map +1 -0
- 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 @@
|
|
|
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 @@
|
|
|
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 @@
|
|
|
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"}
|
package/dist/cli/init.js
ADDED
|
@@ -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 @@
|
|
|
1
|
+
{"version":3,"file":"start.d.ts","sourceRoot":"","sources":["../../src/cli/start.ts"],"names":[],"mappings":"AAeA,wBAAsB,KAAK,CAAC,OAAO,CAAC,EAAE,MAAM,iBAyB3C"}
|