Skip to main content

Micro-agent runner for task automation using markdown definitions

Project description

tsugite

Tsugite (継ぎ手) is an agent framework where you define AI agents as markdown files and run them from the CLI, a web UI, or through scheduled tasks.

I built it because none of the existing agent frameworks did what I wanted. I needed something self-hosted, model-agnostic, and simple enough that an agent is just a text file I can edit and version control.

Originally it was meant to be a framework for micro-agents inspired by ESA, but has grown a lot since that goal.

What an agent looks like

A simple "hello world" agent looks like:

---
name: morning-brief
model: anthropic:claude-sonnet-4-20250514
tools: [web_search, fetch_text, write_file, final_answer]
---

You are a morning briefing assistant.

Current date: {{ now() }}
User location: {{ env("LOCATION", "unknown") }}

Check the weather, scan top news, and write a short briefing.
Use final_answer() to return the result.

YAML frontmatter for config, markdown body for instructions, Jinja for dynamic context. Run it with:

tsu run +morning-brief "what's happening today"

Key ideas

  • Agents are markdown. A basic agent is just markdown with yaml frontmatter. Advanced agents are still just markdown but can use jinja templating and a special <!--tsu --> syntax.
  • Code execution over tool-calling. Inspired by smolagents. Instead of using native tool calling, LLMs write python code. Tools are exposed as python functions.
  • Any LLM. Plugin interface to add support for additional LLM providers. Built-in we have openai-compatible apis, ollama, anthropic, and claude code.
  • Workspaces. Each workspace is a persistent directory with agents, skills, memory files, and config. The agent runs inside its workspace and can read/write files, spawn sub-agents, manage schedules, and persist state across conversations. Workspaces are entirely optional.
  • CLI and/or Daemon with a Web UI Use tsu run commands for cli-only, or run tsu daemon for a daemon that supports scheduled tasks, a web ui, and some other neat things.

Install

uv tool install tsugite-cli    # recommended
pipx install tsugite-cli       # alternative
pip install tsugite-cli        # or plain pip

The package is tsugite-cli, the command is tsugite (or tsu for short).

Quick start

# Initialize a workspace
tsu init my-workspace
cd my-workspace

# Run the built-in default agent
tsu run +default "summarize the files in this directory"

# Run an agent file directly
tsu run my-agent.md "do the thing"

# Start the web UI
tsu serve

Features

  • Multi-step workflows with <!-- tsu:step --> to chain steps and pass data between them
  • Scheduling built-in cron for recurring agent tasks (daily summaries, monitoring, etc.)
  • Web UI for conversations, with Discord as an alternative interface
  • Sub-agents that can spawn other agents for specific subtasks
  • Skills reusable knowledge files agents can load on demand, mostly compatible with agentskills.io
  • Hooks that fire shell commands on lifecycle events (post-tool, pre-message, pre/post-compact)
  • Sandbox (linux only) via bubblewrap with filesystem and network isolation
  • KV store for persistent agent state
  • MCP integration for connecting to MCP servers

Agents in more detail

Agents support YAML frontmatter for configuration:

---
name: code-reviewer
model: anthropic:claude-sonnet-4-20250514
max_turns: 15
tools: [read_file, list_files, web_search, final_answer]
auto_load_skills: [coding-standards]
---

You can restrict which tools an agent has access to, set turn limits, auto-load skills, attach context files, and extend other agents. TODO: See docs/ for the full spec.

Multi-step agents use <!--tsu --> comments as directives:

<!-- tsu:step name="research" model="openai:gpt-4o" -->
Research the topic and save findings to a variable.

<!-- tsu:step name="write" -->
Using the research from the previous step, write a summary.
The variable `research` is available as a Python variable.

For a complete example, check the built-in default agent.

Sandbox

On Linux only (for now), agent code runs inside a bubblewrap sandbox when you pass --sandbox:

tsu run +default "task" --sandbox --allow-domain "github.com"
tsu run +default "task" --sandbox --no-network

Filesystem access is limited to the workspace. Network goes through a filtering proxy that only allows domains you specify.

Config and Data Directories

All paths follow XDG Base Directory conventions and can be overridden with the standard environment variables.

Path Default Contents
$XDG_CONFIG_HOME/tsugite/ ~/.config/tsugite/ config.json, mcp.json, daemon.yaml
$XDG_DATA_HOME/tsugite/history/ ~/.local/share/tsugite/history/ Session history (JSONL per session)
$XDG_DATA_HOME/tsugite/daemon/ ~/.local/share/tsugite/daemon/ Daemon state
$XDG_DATA_HOME/tsugite/secrets/ ~/.local/share/tsugite/secrets/ Encrypted secrets (secrets.db)
$XDG_DATA_HOME/tsugite/kvstore/ ~/.local/share/tsugite/kvstore/ Key-value store (kv.db)
$XDG_DATA_HOME/tsugite/usage/ ~/.local/share/tsugite/usage/ Usage (cost and token) tracking (usage.db)
$XDG_DATA_HOME/tsugite/workspaces/ ~/.local/share/tsugite/workspaces/ Workspace directories
$XDG_CACHE_HOME/tsugite/attachments/ ~/.cache/tsugite/attachments/ Attachment cache

Development

git clone https://github.com/justyns/tsugite.git
cd tsugite
uv sync --dev

Status

This is a personal project I use daily. It works for my use cases but isn't polished for general consumption yet. Issues and PRs welcome, but set expectations accordingly. Documentation is very sparse because I keep changing things.

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

tsugite_cli-0.10.0.tar.gz (808.6 kB view details)

Uploaded Source

Built Distribution

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

tsugite_cli-0.10.0-py3-none-any.whl (518.9 kB view details)

Uploaded Python 3

File details

Details for the file tsugite_cli-0.10.0.tar.gz.

File metadata

  • Download URL: tsugite_cli-0.10.0.tar.gz
  • Upload date:
  • Size: 808.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for tsugite_cli-0.10.0.tar.gz
Algorithm Hash digest
SHA256 32e093a376e0cf0861f3184abfa01467d4a7d6ee0a4661138dbf0631a44a283b
MD5 56a870d5ec392a07dde8d7f5b5280f9c
BLAKE2b-256 525a3932697fef1e6f756c658ca78ceaa1696fc7376e7b0cfcff985b029f65b9

See more details on using hashes here.

Provenance

The following attestation bundles were made for tsugite_cli-0.10.0.tar.gz:

Publisher: pypi-publish.yml on justyns/tsugite

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file tsugite_cli-0.10.0-py3-none-any.whl.

File metadata

  • Download URL: tsugite_cli-0.10.0-py3-none-any.whl
  • Upload date:
  • Size: 518.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for tsugite_cli-0.10.0-py3-none-any.whl
Algorithm Hash digest
SHA256 3cbf1b898e9e00c665b2adef3a7c91e469f8052ebf01ab4f41954116214af417
MD5 2368f54febe8943980da37713e2b4626
BLAKE2b-256 c8cc800779d7ab9656bf6ffacfa489167e3f7d34e08fb9b2ab2e9cd11da1f5a4

See more details on using hashes here.

Provenance

The following attestation bundles were made for tsugite_cli-0.10.0-py3-none-any.whl:

Publisher: pypi-publish.yml on justyns/tsugite

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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