Skip to main content

A framework for running persistent AI agents.

Project description

Cousins

A framework for running persistent AI agents ("cousins").

PyPI Python

A cousin is a long-lived AI agent with its own identity, memory, and chat surface — not a one-shot prompt, but an agent that persists across sessions and reboots. Cousins is the machinery to define, run, and maintain them.

Install

pip install cousins

Stdlib-only Python (3.11 or newer); no runtime third-party dependencies.

End-to-end: a Telegram bot driven by a local Ollama model

from cousins import client
from cousins.transports import OllamaTransport, TelegramBotTransport
from cousins.bridges.telegram import TelegramBridge
from cousins.chat import ClientBackend

c = client.build_client("ollama", transport=OllamaTransport(model="phi4-mini"))
bot = TelegramBotTransport(token="<your-bot-token>", poll_timeout=25)
bridge = TelegramBridge(bot=bot, backend=ClientBackend(c))

while True:
    bridge.poll_once()

That is a working LLM-on-Telegram bot in eight lines, against a local Ollama model with no API keys. See docs/site/bridges.md for the longer walkthrough (system prompts, error translation, persisting messages to the chat-server).

What ships today (v0.2.9)

  • cousins CLIinit, onboard, run, serve-chat.
  • Provider abstraction + LLM client — stable contract, capability enforcement, offline EchoTransport plus live transports.
  • Live transports (cousins.transports):
    • OllamaTransport for a local Ollama HTTP server (no credential).
    • TelegramBotTransport for the Telegram Bot API.
  • Telegram bridge (cousins.bridges.telegram) — normalises updates, routes them through a ChatBackend, handles long-poll offsets.
  • Chat package (cousins.chat):
    • Store — sqlite-backed per-cousin message log.
    • Server — stdlib threading HTTP server with on_inbound / on_outbound host-seam callbacks.
    • EchoBackend + ClientBackend — concrete bridge backends.
  • Configuration — strict cousin.toml schema with [sandbox] modes (host / systemd / container).
  • Onboarding wizard — guided first-cousin scaffold; writes a validated cousin.toml, memory/, an AGENTS.md stub, and a .env.example template when the provider needs credentials.
  • Runtime layout — platform-appropriate install root (Windows %APPDATA%, macOS Application Support, XDG on Linux).
  • Releases — SemVer, Keep-a-Changelog cadence, GitHub Releases with attached sdist + wheel.

Layout

src/cousins/              the package
  ├─ bridges/             channel adapters (telegram)
  ├─ chat/                store + HTTP server + bridge backends
  ├─ providers/           provider abstraction
  ├─ transports/          live network-backed transports
  ├─ client.py            LLM client + Transport seam
  ├─ config.py            cousin.toml load + validate
  ├─ layout.py            runtime directory layout
  ├─ onboarding.py        cousins onboard wizard
  ├─ run.py               cousins run handler
  ├─ runtime.py           sandbox-mode launch artifact rendering
  └─ version.py           SemVer 2.0.0
tests/unit/               fast, isolated tests
tests/auto/               integration / end-to-end tests
docs/                     architecture, contribution, site, perimeter policy
.github/workflows/        CI

Getting started

cousins init                          # runtime layout at a default root
cousins onboard --root ./cousins      # guided setup for a new cousin
cousins serve-chat <slug> --root ./cousins   # foreground chat HTTP server

With Nix:

nix build          # build the package
nix develop        # dev shell
nix flake check    # run the test suite in a sandbox

Tests

No dependencies, no pytest — stdlib only:

python3 -m tests._runner            # everything
python3 -m tests._runner unit       # only unit tests
python3 -m tests._runner --filter chat -v

CI runs the same command across Python 3.11–3.13. Live integration tests against real backends are gated behind environment variables:

COUSINS_LIVE_OLLAMA=1 python3 -m tests._runner unit --filter ollama
COUSINS_LIVE_TELEGRAM=1 COUSINS_TELEGRAM_BOT_TOKEN=... \
    python3 -m tests._runner unit --filter telegram

Roadmap

Tracked as the product-track items in the origin framework's backlog. What's deferred from v0.2.x:

  • Anthropic and OpenAI live transports (gated on credentials to verify against).
  • Host-style chat-server features (tmux fan-out, static file serving, agent-log endpoints) — the host wires its own glue via on_inbound / on_outbound seams today.
  • The full cousin lifecycle (spawn / flip / transplant / reincarnate), memory layers, hooks and scheduling — migrating in from the origin framework.

Documentation

License

See LICENSE.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

cousins-0.2.9.tar.gz (64.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

cousins-0.2.9-py3-none-any.whl (74.5 kB view details)

Uploaded Python 3

File details

Details for the file cousins-0.2.9.tar.gz.

File metadata

  • Download URL: cousins-0.2.9.tar.gz
  • Upload date:
  • Size: 64.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.30 {"installer":{"name":"uv","version":"0.9.30","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"NixOS","version":"25.11","id":"xantusia","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for cousins-0.2.9.tar.gz
Algorithm Hash digest
SHA256 f8b35950c770f1b51888b64baa46800c69b0091e26e66e67137e93b09022a08a
MD5 a45fc12c97a3505d1688a9c2fcdc378c
BLAKE2b-256 149565eee4664594ea7b0a344bc15ab47edd4bb19da4ccb82c2265218c7b1a45

See more details on using hashes here.

File details

Details for the file cousins-0.2.9-py3-none-any.whl.

File metadata

  • Download URL: cousins-0.2.9-py3-none-any.whl
  • Upload date:
  • Size: 74.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.30 {"installer":{"name":"uv","version":"0.9.30","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"NixOS","version":"25.11","id":"xantusia","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for cousins-0.2.9-py3-none-any.whl
Algorithm Hash digest
SHA256 115773d1b858bcf205e0c8b5b6780ca25828427d7f93b045525e731e1cffe778
MD5 e667fbdd0a9059caee6901ca9c67fe7b
BLAKE2b-256 2d405664bfbdd062e14f22ea57f232109fafad9167a96c9d75d04dbb77c2517b

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page