agent-second-brain

agent
Guvenlik Denetimi
Basarisiz
Health Gecti
  • License — License: MIT
  • Description — Repository has a description
  • Active repo — Last push 0 days ago
  • Community trust — 261 GitHub stars
Code Basarisiz
  • rm -rf — Recursive force deletion command in setup.sh
Permissions Gecti
  • Permissions — No dangerous permissions requested

Bu listing icin henuz AI raporu yok.

SUMMARY

An always-on second brain you talk to. Voice notes in Telegram → typed, linked knowledge in your Obsidian vault. Runs 24/7 on the Claude subscription you already have.

README.md

Agent Second Brain

Agent Second Brain

An always-on second brain you talk to.
Voice note in Telegram → typed, linked knowledge in your Obsidian vault.
Runs 24/7 on a $5 VPS and the Claude subscription you already pay for — zero per-token API bills.

🇷🇺 РусскийПолная инструкцияVPS guideautograph engine

License: MIT Python 3.12+ Stars Forks


[!IMPORTANT]
Since June 15, 2026, headless claude -p runs bill against a separate paid Agent SDK credit. v3.0 sidesteps that completely: it drives one long-lived interactive Claude Code session — the same thing you run in a terminal, used exactly the way the subscription is meant to be used. No headless calls in the hot path (enforced by a CI guard), no per-request billing, no surprise invoice.

Start here

You want to… Go to
Understand what this thing is Why I built this
Install it on a fresh VPS in one command Quick start
Upgrade an existing v1 / v2 install Upgrading
Пошаговая инструкция на русском, для новичков docs/setup-guide.ru.md
Just want the memory engine for your own vault autograph →
See how the persistent-session trick works How it works

Why I built this

Every productivity system dies the same way. You set it up on a Sunday, use it for two weeks, then slowly stop — because maintaining the system is more work than the work itself. Voice memos you never re-listen to. Ideas that drown in chat history. A vault of markdown files that nobody, including you, can navigate a month later.

The fix isn't another app. It's removing the organizing step entirely: you talk, the agent files. And it has to be yours — I wasn't going to pipe my private notes, clients, and goals through somebody's SaaS. Everything here runs on your own server, lands in your own Obsidian vault as plain markdown, and is small enough to actually read before you trust it with your life.

What talking to it looks like

You   (voice, 40s, while walking): «Созвон с Алишером — они согласны на пилот,
      но просят сдвинуть старт на июль. Надо обновить КП и напомнить мне
      в пятницу отправить договор.»

Bot:  💾 Сохранил: CRM-карточка Алишера обновлена (пилот, старт июль),
      связал с [[proekt-pilot]]. Напоминание поставлено: пятница 10:00 —
      отправить договор.

      — Friday, 10:00 —

Bot:  🔔 Напоминание: отправить договор Алишеру. Контекст: пилот, старт июль,
      КП обновлено во вторник.
You:  what did I write about the marketing project last week?
Bot:  *finds the entries, quotes them, links the cards*
You:  turn the second idea into a project note with next steps
Bot:  *creates the note, links it to the client and this week's goals*
You:  *forwards a post, drops a photo of a whiteboard, sends a PDF*
Bot:  *reads them itself — files the takeaways into the graph, answers what it saved*

No commands to memorize, no categories to pick, no app to open. Telegram is the whole interface.

Philosophy

Voice-first. Capture has to be cheaper than forgetting, or the system dies. A voice note costs five seconds.

The vault is the source of truth. Everything lives as plain markdown in your Obsidian vault on your server. Delete the agent tomorrow — you keep everything, readable forever. No lock-in, no export button needed.

Memory that forgets, like yours. Storage is not memory. Knowledge decays on the Ebbinghaus curve, fades through five tiers, and resurfaces when it matters — so the graph stays sharp instead of becoming a landfill.

Interactive session, by the rules. One persistent Claude Code session in tmux, driven the way a human drives it. No headless claude -p anywhere in the hot path — a CI guard fails the build if anyone tries.

Small enough to read. One Python process, a handful of modules, 220+ tests. You can audit the thing that reads your private notes in an evening.

What it does

🎙 Total captureVoice (Deepgram, seconds), text, photos, documents, videos, forwarded posts, whole albums — the agent reads files itself and files the takeaways. Nothing you send is ever silently dropped.
🧠 Knowledge graph memoryPowered by autograph: typed cards, wiki-links, Ebbinghaus decay across five tiers, automatic MOC indexes, health scoring, link repair, dedup. The most thorough open-source memory layer you can drop on a vault.
⏰ Self-managed routines"Remind me Friday at 3pm", "every weekday at 18:30 check my inbox folder" — the agent schedules its own cron jobs from plain language. One-shots, intervals, full cron expressions. No external task manager.
🌙 Nightly processingAt 21:00 your time it classifies the day's entries, writes vault cards, updates goals and long-term memory, rebuilds the graph — and sends you a daily report.
🔌 Claude Code, but for PKMIt IS Claude Code under the hood — so drop any MCP server into mcp-config.json, add any skill into vault/.claude/skills/, and your second brain grows new abilities. Like Claude Code through Telegram — for knowledge, not code.
🩺 Self-healingA watchdog recovers a wedged session, a daily doctor sends a 🟢/🔴 canary report, broken jobs disable themselves and tell you. It just stays up.

The memory engine: autograph

The part that makes this a brain rather than a logger is autograph — a typed memory layer for always-on agents, shipped here as a skill and also usable standalone on any Obsidian vault.

  • Typed graph — every card carries a type (note, contact, project, CRM), a description for retrieval, tags, status; one schema.json rules them all
  • Ebbinghaus decay — strength 1 + ln(access_count): each touch slows forgetting; contacts fade in ~100 days, dailies in ~25
  • Five tiers — core → active → warm → cold → archive; touching a card promotes it back up
  • Random recall — occasionally an archived card resurfaces next to something current. Sometimes noise. Sometimes the best idea you forgot you had.
  • Self-maintenance — orphan detection, broken-link repair, dedup into .trash/, MOC generation, a 100-point health score. You never run vault chores again.
Tier What happens
Core Always in context: current projects, active clients, key goals
Active Checked regularly: recent ideas, ongoing threads
Warm Found when you search
Cold Surfaces only in deep searches
Archive Almost gone — but randomly recalled for creative collisions

How it works

Telegram ──▶ bot (aiogram) ──▶ persistent Claude Code session (tmux pane)
                 │                       │
                 │                       ├──▶ Obsidian vault (plain markdown)
                 │                       └──▶ autograph: graph · decay · MOC
                 ├──▶ cron ticker ──▶ second isolated session (reminders never block chat)
                 └──▶ watchdog + daily doctor (self-healing, 🟢/🔴 report)

The bot never spawns claude per message. It keeps one long-lived interactive Claude Code session alive in a tmux pane and types prompts into it — which is why a 24/7 agent runs on a flat Pro/Max subscription instead of metered API tokens. Scheduled jobs fire in a second, isolated session, so a reminder going off never interrupts your conversation. A cross-process lock serializes everything; a watchdog restarts whatever wedges.

Privacy is explicit: voice audio goes to Deepgram for transcription, text goes to Anthropic through your subscription, everything else stays on your server. The vault never leaves the machine.

What it costs

Service Cost
Claude Pro $20/mo
VPS (any cheap one) ~$5/mo
Deepgram free tier ($200 credit)
Total ~$25/mo, flat

A personal assistant that organizes your life, never sleeps, and gets better the more you use it — for the price of two coffees. And because the session is interactive, the price above stays the price: there is no token meter to run away from you.

Quick start

Three steps, ~15 minutes of work (full beginner walkthrough: 🇷🇺 setup-guide / 🇬🇧 vps-setup).

1. Fork this repo (make the fork private — it will contain your life), then fill in vault/goals/ and the persona in vault/.claude/skills/dbrain-processor/references/about.md.

2. Get two keys: a bot token from @BotFather, a free key from Deepgram, plus your Telegram ID from @userinfobot.

3. On a fresh Ubuntu VPS:

curl -fsSL https://raw.githubusercontent.com/YOUR_USERNAME/agent-second-brain/main/bootstrap.sh | bash

The installer interviews you for the tokens, walks you through Claude Code login (browser link), installs systemd services, and finishes with a health check. The bot messages you when it's alive. That's it — start talking.

What the installer actually does (inspect before you trust)

bootstrap.sh clones your fork and hands off to setup.sh, which only asks questions (tokens, timezone, git remote) and writes .env (chmod 600). All real work happens in idempotent upgrade.sh: uv + Python deps, tmux, Claude CLI, dbrain-* systemd user units, a dbrain CLI (status / logs / attach / doctor), permission hardening, and a first doctor run. Every script is short enough to read first.

Upgrading from v1 / v2

One idempotent command — it migrates old units, installs what's missing, repairs permissions, and health-checks itself:

ssh your-server
cd agent-second-brain && git pull && bash upgrade.sh

If a migration ever goes sideways, run claude in the project directory and call the migrate-doctor skill — it diagnoses the install layout (v1/v2/v3), backs up, and repairs interactively.

Vault structure

vault/
├── daily/              # Your raw daily stream (voice, text, attachments)
├── goals/              # Vision → yearly → monthly → weekly
├── business/
│   ├── crm/            # Client cards
│   └── network/        # Professional contacts
├── projects/           # Active work, leads, pipeline
├── thoughts/
│   ├── ideas/          # Ideas and brainstorms
│   ├── learnings/      # Lessons learned
│   └── reflections/    # Personal reflections
├── MOC/                # Maps of Content (auto-generated)
└── MEMORY.md           # The agent's long-term memory

Skills

Skill What it does
dbrain-processor Classifies entries, writes vault cards, daily reports
autograph The memory engine: decay, graph health, MOCs, schema-as-code, dedup
cron The agent manages its own schedule from plain language
migrate-doctor Diagnoses and repairs broken upgrades from older versions

Drop your own into vault/.claude/skills/ — the session picks them up like any Claude Code install.

Configuration

File Controls
.env Tokens, timezone, model, cron tuning (see .env.example)
vault/.claude/CLAUDE.md The agent's personality and rules
mcp-config.json Optional: any MCP servers you want the brain to have

All secrets stay in .env (gitignored, chmod 600). Set CLAUDE_MODEL=sonnet to reduce weekly-limit pressure on a 24/7 bot.

What it does NOT do

  • It does not send your vault anywhere. Plain markdown, your disk, your git remote if you configure one.
  • It does not use headless claude -pscripts/check-no-claude-p.sh runs in CI and fails the build if that ever changes.
  • It does not require any API keys beyond Telegram + Deepgram. No OpenAI, no token meter.
  • It does not lock you in. Delete everything tomorrow; your vault still opens in Obsidian.

Built by

Serge Shima — 20 years in marketing (BBDO, Publicis), now running an AI creative agency in Central Asia and teaching businesses to work with AI at aimasters.me.

This system runs my actual life: 1,100+ vault cards, daily reports, an agent I argue with about my own calendar. It started as a weekend project and became infrastructure.

License

MIT — do whatever you want with it.

Yorumlar (0)

Sonuc bulunamadi