Agents#
gptme supports highly customizable “agents”: persistent AI assistants with structured memory, identity, and workspace management capabilities.
Each agent is implemented as a git repository that serves as their “brain,” containing all their data, configuration, and interaction history.
Overview#
✨ Superpowers#
        graph LR
    Persistent[🔒 Persistent<br/>Complete history<br/>Version controlled]
    Autonomous[🎯 Autonomous<br/>Long-term goals<br/>Proactive & self-directed]
    Evolving[🌱 Self-Improving<br/>Gets smarter over time<br/>Learns from experience]
    %% Force left-to-right layout
    Persistent --- Autonomous --- Evolving
    classDef benefits fill:#fff8e1,stroke:#f57f17,stroke-width:3px,color:#000
    class Persistent,Autonomous,Evolving benefits
    🧠 Agent Brain#
        graph TD
    subgraph Core[💎 Core Identity]
        Identity[Who am I?<br/>My goals & capabilities]
    end
    subgraph LivingMemory[🔄 Living Memory Systems]
        Journal[📔 Journal<br/>Every decision & insight<br/>Continuous learning]
        Tasks[🎯 Tasks<br/>Goals & achievements<br/>Progress tracking]
        Knowledge[📚 Knowledge<br/>Learned lessons<br/>Cross-referenced insights]
        People[👥 Relationships<br/>Collaboration history<br/>Social intelligence]
        Projects[🚀 Projects<br/>Active work & outcomes<br/>Success patterns]
    end
    subgraph Intelligence[🤖 Dynamic Intelligence]
        direction LR
        Context[⚡ Live Context<br/>Situational awareness<br/>Current state]
        Learning[📈 Continuous Learning<br/>Self-improvement<br/>Pattern recognition]
    end
    %% Internal intelligence flow
    Core --> LivingMemory
    LivingMemory --> Intelligence
    Context --- Learning
    %% Memory interconnections (selective)
    Journal -.->|Informs| Tasks
    Knowledge -.->|Supports| Projects
    People -.->|Collaborate on| Projects
    classDef core fill:#fff3e0,stroke:#ef6c00,stroke-width:3px,color:#000
    classDef memory fill:#e8f5e8,stroke:#2e7d32,stroke-width:2px,color:#000
    classDef intelligence fill:#fce4ec,stroke:#c2185b,stroke-width:3px,color:#000
    class Core,Identity core
    class LivingMemory,Journal,Tasks,Knowledge,People,Projects memory
    class Intelligence,Context,Learning intelligence
    🌍 External World#
        graph LR
    subgraph World
        User[👤 User]
        Web[🌐 Web & APIs]
        Files[📁 Files & Code]
        Social[✉️ Email & Discord]
    end
    classDef world fill:#e3f2fd,stroke:#1565c0,stroke-width:2px,color:#000
    class World,User,Web,Files,Social world
    Architecture#
Git-based Repository Structure: Each agent is a complete git repository with a structured workspace.
- Core files - - README.md,- ABOUT.md,- ARCHITECTURE.md,- gptme.toml
- journal/- Daily activity logs (YYYY-MM-DD.md format)
- tasks/- Individual task files with YAML metadata
- knowledge/- Long-term documentation and insights
- lessons/- Learned lessons and best practices
- people/- Contact profiles and relationship management
- projects/- Project-specific information
Dynamic Context Generation: Agents use sophisticated context generation to maintain awareness.
- Project configuration ( - gptme.toml) specifies core- filesalways in context
- A - context_cmdcommand specified in- gptme.tomlis used for dynamic context generation
- Each interaction includes recent journal entries, active tasks, and git status 
- Provides comprehensive situational awareness across sessions 
Key Systems#
Journal System:
- One file per day in append-only format 
- Contains task progress, decisions, reflections, and plans 
- Most recent entries automatically included in context 
- Maintains historical record of all activities and thoughts 
Task Management:
- Individual Markdown files with YAML frontmatter metadata 
- States: new, active, paused, done, cancelled 
- Priority levels, tags, and dependencies 
- CLI tools for management and status tracking 
- Integrated with journal entries for progress updates 
Knowledge Base:
- Long-term information storage organized by topic 
- Technical documentation, best practices, and insights 
- Cross-referenced with tasks and journal entries 
Lessons System:
- Used to document learned lessons and best practices 
- Learned lessons are to be retrieved when the context arises 
- Helps avoid repeating mistakes and improves decision-making 
People Directory:
- Individual profiles for contacts and collaborators 
- Includes interests, skills, project history, and interaction notes 
- Privacy-conscious with appropriate detail levels 
Usage#
Note
We are working on a graphical way to create and interact with agents using the gptme web interface. Try it out and let us know what you think! Soon coming as a managed service.
Installing dependencies:
First install the required dependencies using pipx (recommended) to ensure isolation and easy management:
# Install required dependencies
pipx install gptme   # or `pipx install -e ./gptme` to install from local source
pipx install uv
pipx install pre-commit
Creating an Agent:
Use the gptme-agent-template to create new agents:
# Clone the template repository
git clone https://github.com/gptme/gptme-agent-template
cd gptme-agent-template
# Fork the template
./fork.sh ../my-agent "MyAgent"
cd ../my-agent
# (optional) set up pre-commit hooks
make install
Running an Agent:
# Run the agent
gptme "your prompt here"
Execution Flow:
- gptmebuilds context from all systems- Includes journal entries, tasks, knowledge, and people 
- Static context is included using the - filesin- gptme.toml
- Dynamic context is generated using the - context_cmdin- gptme.toml
 
- gptmeruns the agent- With prompt, tools, and collected context 
 
- Agent processes the prompt - Uses the context to inform decisions and responses 
- Updates journal, tasks, and knowledge as needed 
 
Benefits#
Version Control:
- All agent data and interactions are version-controlled 
- Complete history of agent development and interactions 
- Easy backup, sharing, and collaboration 
Persistence:
- Agents maintain state across sessions 
- Remember previous conversations, decisions, and progress 
- Build knowledge and relationships over time 
Structured Memory:
- Organized information storage prevents knowledge loss 
- Easy retrieval of past decisions and context 
- Cross-referencing between different information types 
Extensibility:
- Template provides consistent foundation 
- Customizable identity, goals, and capabilities 
- Integration with external tools and services 
Goal-Oriented Behavior:
- Clear goals transform agents from reactive tools into proactive collaborators 
- Well-defined purpose enables agents to take initiative, suggest improvements, and identify opportunities 
- Strategic direction helps agents prioritize decisions and maintain long-term perspective 
- Goals provide the contextual framework that “pulls agents forward” toward meaningful outcomes 
Examples#
Bob: Bob, aka @TimeToBuildBob, is an experimental agent that helps with gptme development. He demonstrates practical agent capabilities including:
- Project management and task tracking 
- Code review and development assistance 
- Documentation and knowledge management (he has a website) 
- Community interaction and support (he reads and responds on the Discord server) 
Bob tries to be more than just a AI assistant, he tries to expand his own impact and seek autonomy to safely scale his efforts and improve the agent harness.
Creating Specialized Agents: The template system enables creating agents for specific domains:
- Development assistants with project-specific knowledge 
- Research assistants with domain expertise 
- Personal productivity assistants with custom workflows 
- Team collaboration agents with shared knowledge bases 
External Integrations#
Agents can be extended with various external integrations and tools for enhanced capabilities:
Content & Information:
- Web Browsing: Access and analyze web content using built-in browser tools 
- Search Integration: Query search engines and process results 
- RSS Reader: Consume and process RSS feeds in LLM-friendly formats 
Communication & Sharing:
- Email Integration: Send and receive emails for external communication 
- Social Media: - Twitter integration for sharing updates and public communication 
- Discord integration for community interaction 
 
- GitHub Integration: Create and share gists, manage repositories 
- Website Publishing: Share information and updates publicly 
Collaboration Tools:
- Git Integration: Version control with co-authoring capabilities 
- Issue Tracking: Integration with GitHub issues and project management 
- Documentation: Automated documentation generation and updates 
Development & Operations:
- CI/CD Integration: Automated testing and deployment workflows 
- Monitoring: System and application monitoring capabilities 
- Database Access: Query and update databases as needed 
These integrations transform agents from isolated assistants into connected participants in digital workflows, enabling them to:
- Stay informed about relevant developments through content feeds 
- Communicate with external parties and communities 
- Share their work and insights publicly 
- Collaborate on projects with proper attribution 
- Maintain awareness of project status and issues 
Note: Many integrations are work-in-progress (WIP) and under active development.
Why personify agents?#
While personifying agents might seem unnecessary for professional use, it provides several benefits:
- Mental Model: Helps users understand the agent’s role and capabilities 
- Consistency: Encourages consistent interaction patterns and expectations 
- Memory: Makes it easier to remember what you’ve told the agent 
- Engagement: Creates more natural and memorable interactions 
- Identity: Distinguishes between different specialized agents 
Links#
For more details, see the following resources:
- gptme-agent-template - Template for creating new agents 
- gptme-contrib - Community-contributed tools and scripts for agents 
