PawFlow-Agents

mcp
Guvenlik Denetimi
Basarisiz
Health Uyari
  • License — License: MIT
  • Description — Repository has a description
  • Active repo — Last push 0 days ago
  • Low visibility — Only 5 GitHub stars
Code Basarisiz
  • rm -rf — Recursive force deletion command in .github/workflows/docker-publish.yml
  • rm -rf — Recursive force deletion command in config/relay_image_catalog.json
Permissions Gecti
  • Permissions — No dangerous permissions requested

Bu listing icin henuz AI raporu yok.

SUMMARY

PawFlow (Platform for Agentic Workflows) Self-hosted agent runtime for real infrastructure. Run durable AI agents against your own files, tools, browsers, desktops, services, and workflows with relay-backed execution, shared context, multi-provider agents, and deterministic flows.

README.md

PawFlow

PawFlow

Self-hosted agent runtime for real infrastructure.
Run durable AI agents against your own files, tools, browsers, desktops, services, and workflows.

Website · Quickstart · Docs · Releases

CI MIT License Python 3.10+ Alpha


PawFlow is the runtime layer between chat agents, local tools, and production workflows. The server keeps conversations, context, memory, files, flows, and provider sessions durable. Relays execute filesystem, shell, browser, desktop, and media tools next to the machines where the work actually happens.

Use it when a hosted coding assistant is too boxed-in, a workflow tool is too rigid, and a library is not enough runtime.

Why PawFlow

PawFlow gives agents a real operating surface without handing your workspace to a vendor-controlled agent cloud.

  • Relay-backed tools: read, edit, grep, run commands, browse, control desktops, generate media, and inspect projects through explicit relay routes.
  • Durable context: conversations, shared context, per-agent context, memory, knowledge graphs, diaries, project graphs, files, and buckets survive restarts.
  • Multi-provider agents: mix Codex app-server, Claude Code, Antigravity/Agy, Gemini CLI, Anthropic, OpenAI, and OpenAI-compatible services per agent or conversation.
  • Shared clients: continue the same conversation from the web UI, PawCode CLI, VS Code, API clients, or channel integrations.
  • Deterministic flows: turn repeated work into NiFi-style DAGs with scheduling, backpressure, checkpoints, approvals, and explicit LLM steps.
  • Package ecosystem: distribute agents, skills, tools, services, flow tasks, flows, and UI extensions as signed .pfp packages or import skills from supported marketplaces.

What You Can Build

  • Agentic coding sessions against a linked workspace, with persistent context and auditable tool output.
  • Multi-agent operations where planners, coders, reviewers, researchers, and verifiers work in the same conversation.
  • Browser and desktop automation for workflows that do not have clean APIs.
  • Media pipelines that create images, video, audio, 3D assets, voice, and FileStore outputs.
  • Scheduled operational flows: daily digests, inbox triage, data transforms, reports, monitoring, and webhook-driven automation.
  • Reusable packages and registries for sharing internal or community agents, skills, tools, services, flow tasks, flows, and UI extensions.
  • Portable conversations with full PawFlow archives, including optional FileStore attachments and generated files.

Quick Start

The easiest path is the Docker installer from the latest release. It starts PawFlow, opens the bootstrap wizard, creates the first admin user, configures the selected LLM services, deploys the starter flow, and opens your first agent conversation.

Docker Installer

Downloadable artifacts are published on the latest GitHub release: installer zip, PawCode packages, Relay CLI archives, Relay Desktop installers, checksums, and source archives.

PAWFLOW_VERSION=$(curl -fsSL https://api.github.com/repos/allcolor/PawFlow-Agents/releases/latest \
  | python3 -c 'import json,sys; print(json.load(sys.stdin)["tag_name"])')

curl -L -o "pawflow-install-$PAWFLOW_VERSION.zip" \
  "https://github.com/allcolor/PawFlow-Agents/releases/download/$PAWFLOW_VERSION/pawflow-install-$PAWFLOW_VERSION.zip"
unzip "pawflow-install-$PAWFLOW_VERSION.zip"
cd "pawflow-install-$PAWFLOW_VERSION"

bash scripts/install-pawflow.sh --port PORT --pull-images --version "$PAWFLOW_VERSION"

On Windows PowerShell with Docker Desktop Linux containers, use the bundled
PowerShell installer instead:

powershell -ExecutionPolicy Bypass -File scripts/install-pawflow.ps1 -Port PORT -PullImages -Version $env:PAWFLOW_VERSION

Check and apply release updates with:

bash scripts/install-pawflow.sh --check-updates
bash scripts/install-pawflow.sh --self-update
bash scripts/install-pawflow.sh --version NEW_VERSION --port PORT --pull-images

The update command recreates the PawFlow server container on the requested image
while keeping persistent data under PAWFLOW_HOME, then removes older PawFlow
server/relay image tags unless --keep-old-images is set.

Open the installer at:

https://localhost:PORT/install

The first-run Private Gateway key is RoyBetty. Finalizing the wizard replaces it.

From Source

git clone https://github.com/allcolor/PawFlow-Agents.git
cd PawFlow-Agents
pip install -r requirements.txt
python cli.py start --host 0.0.0.0 --port PORT

Open the web chat at:

http://localhost:PORT/chat

Clients

Web UI

The web UI is the main operator surface: chat, context editor, memory editor, file attachments, relay tools, desktop entry points, terminals, provider sessions, and flow actions in one place.

PawCode CLI

PawCode is a terminal client for the same PawFlow conversations. It can be used interactively or in Claude Code-compatible stream-JSON mode.

pawcode --server http://localhost:PORT

echo '{"type":"user","message":{"role":"user","content":"hello"}}' | \
  pawcode --input-format stream-json --output-format stream-json

VS Code and Relays

Use the relay CLI or Relay Desktop to connect workspaces, desktops, browsers, and terminals. The VS Code extension can attach to the same conversation and resource panel.

Architecture

┌─────────────────────────────────────────────────────────────────┐
│                        PawFlow Server                           │
│                                                                 │
│  ┌──────────┐  ┌──────────┐  ┌─────────┐  ┌────────────────┐  │
│  │  Agents  │  │ Pipeline │  │   Auth   │  │  Web Chat UI   │  │
│  │  (LLM +  │  │  Engine  │  │ Gateway  │  │  (SSE, files,  │  │
│  │  tools)  │  │ (100+    │  │ (9 OAuth │  │   context,     │  │
│  │          │  │  tasks)  │  │ provid.) │  │   commands)    │  │
│  └────┬─────┘  └──────────┘  └──────────┘  └────────────────┘  │
│       │                                                         │
│  ┌────┴─────────────────────────────────────────────────────┐  │
│  │              90+ Tool Handlers (via relay)                │  │
│  │  bash, read, write, edit, glob, grep, web_search,        │  │
│  │  screen, browser, generate_image, generate_video,        │  │
│  │  generate_audio, generate_3d, clone_voice, speak,        │  │
│  │  remember, kg_add, project_graph, delegate, plans, ...   │  │
│  └──────────────────────────┬───────────────────────────────┘  │
│                             │ WebSocket                        │
└─────────────────────────────┼──────────────────────────────────┘
                              │
                    ┌─────────┴─────────┐
                    │   Relay (Docker)   │  ← runs on user's machine
                    │   or native host   │
                    └───────────────────┘

The server hosts the API, agent orchestration, pipeline engine, and web UI. A relay runs on the user's machine (or in a Docker container) and executes tools — filesystem access, bash commands, code edits — over a WebSocket connection. This means agents can manipulate your local codebase without the server needing direct access to your files.

LLM Providers

Provider Mode Features
Claude Code CLI subprocess/container + MCP Non-interactive coding turns, session persistence, thinking
Claude Code interactive Interactive CLI container + observed stream Claude subscription sessions, live control, provider-observed usage
Codex app-server App-server protocol in pooled container Codex subscription or OpenAI API-key coding agents, threads, steering
Antigravity / Agy Interactive CLI container + observed stream Default Gemini subscription provider, Gemini OAuth pool, MCP tools
Gemini CLI CLI subprocess/container Secondary Gemini CLI path for Pro/CLI-specific workflows
Anthropic API Direct HTTP Streaming, tool use, vision, extended thinking
OpenAI API Direct HTTP Streaming, tool use, vision, JSON mode
OpenAI-compatible Direct HTTP Local/self-hosted and third-party compatible endpoints via base_url

Switch providers per agent, per conversation, or globally. API keys normally use direct openai/anthropic services; subscription logins use the matching CLI-backed provider (codex-app-server, claude-code-interactive, or antigravity-interactive). Self-hosted and third-party LLMs can use the OpenAI-compatible endpoint (base_url override). See LLM Providers.

Agent Capabilities

Cognitive Systems

Agents have persistent memory that survives across conversations:

System Purpose Storage
Memory Facts, preferences, events organized in wing/hall/room taxonomy data/memories/{user}.json
Knowledge Graph Entity-relationship triples with temporal validity data/knowledge_graphs/{user}.json
Agent Diary Personal observations, decisions, learnings per agent data/memories/{user}/diary_{agent}.jsonl
Project Graph AST-based code structure graph (17 languages via tree-sitter) data/graphs/{user}/{conv}/graph.json

Memory digests and diary entries are automatically injected into the system prompt.

Multi-Agent

  • Delegate tasks to sub-agents with delegate()
  • Each sub-agent gets its own LLM, tools, and conversation context
  • Agents can run in parallel or sequentially
  • Git worktree isolation for parallel coding tasks is on the roadmap

Plans

  • Create structured multi-step plans with create_plan()
  • Step-by-step execution with approval gates
  • Assign steps to different agents
  • Verify completed work before moving on

Pipeline Engine

100+ tasks across 5 categories for data processing workflows:

Category Count Examples
System 11+ log, wait, executeScript, cronTrigger, listFiles
IO 50+ HTTP, Telegram, Discord, Slack, WhatsApp, S3, GCS, Azure, SFTP, Kafka, MQTT, email, chat UI, relay
Data 25+ transformJSON, inferLLM, executeSQL, compressContent, validateJSON, Avro/Parquet
Control 10+ routeOnAttribute, splitContent, mergeContent, controlRate, subflows, wait/notify
AI 2+ agentLoop, agentActions, tool-use cycle

Flows are defined in JSON, executed as DAGs, and support backpressure, checkpointing, crash recovery, parameter contexts, subflows, and CRON scheduling.

Packages and Marketplace

PawFlow Packages (.pfp) are signed zip artifacts for distributing PawFlow resources. A package can include agents, prompts, skills, themes, task definitions, flows, service definitions, tools, service providers, flow tasks, task providers, and UI extensions. Install is review-first: PawFlow verifies the package signature and lock file, shows a selectable install plan, records per-object provenance, and executes code-bearing objects through a relay runtime instead of importing third-party code into the server process.

Common package workflows:

/pfp key-create
/pfp build ./my-package.pfpdir --key-env PAWFLOW_PFP_SIGNING_KEY
/pfp inspect ./dist/my-package-1.0.0.pfp
/pfp install ./dist/my-package-1.0.0.pfp --include skill:x,service_provider:y
/pfp dev-load ./my-package.pfpdir --include service_provider:image --secret api_key=my_provider_key
/pfp export --package my.bundle --version 0.1.0 --include agent:helper,flow:daily --out ./my.bundle.pfpdir

Marketplace and registry support is decentralized. Users can add static package registries, search them, inspect remote packages with explicit download confirmation, then install or update selected objects. Skill marketplace import is also supported for Codex/OpenAI skills, Claude/Anthropic plugin marketplaces, HermesHub, and OpenClaw GitHub tree URLs; imports are bounded, reviewed, and never grant tool permissions automatically.

See PawFlow Packages, PFP Developer Guide, PFP Publisher Guide, and Marketplace.

Expression Language

40+ chainable operations for dynamic configuration:

${name:upper}                                     → "ALICE"
${api_key:default("not-set")}                      → uses fallback if empty
${status:equals("active"):then("ON"):else("OFF")}  → conditional logic
${csv_line:split(","):index(0):trim}               → first CSV field, trimmed
${response:json_get("data.items.0.id")}             → extract from JSON
${content:hash_sha256}                              → hash a value
${:uuid}                                            → generate a UUID
${:now:format("yyyy-MM-dd")}                         → "2026-04-08"

Expressions resolve through a cascade: secrets → flow parameters → conversation → user → global → environment variables. See Expression Language docs for the full reference.

Web Chat

  • Real-time streaming via SSE
  • Shared conversations across web, PawCode CLI, VS Code, API clients, and channel flows
  • File explorer with relay filesystem access
  • Context editor (view/edit agent context)
  • Conversation management with auto-titles
  • Drag & drop file attachments and FileStore outputs
  • 60+ slash commands (/agent, /memory, /relay, /run, /plan, /desktop, ...)
  • Desktop/VNC entry points plus relay-backed screen actions
  • Escape key: 1x = graceful interrupt, 2x = force stop
  • Multi-agent with agent switching

Authentication

9 OAuth providers out of the box:

Provider Status
Built-in (username/password) Ready, tested
Generic OAuth2 Ready, tested
Google Ready, tested
GitHub Ready, tested
X (Twitter) Ready, tested
Telegram Ready, tested
Microsoft Ready, not tested
Facebook Ready, not tested
Amazon Ready, not tested

Configuration

Agents, services, and flows are configured via JSON. Parameters cascade: flow → conversation → user → global.

{
  "llm_service": "claude_code_llm_service",
  "summarizer_service": "claude_code_llm_service",
  "permission_mode": "auto",
  "max_iterations": 200
}

See .env.example for environment variables.

Tests

pytest tests/ -v    # 2500+ tests across 100+ test files

Documentation

Document Description
Architecture Internal architecture, FlowFile, components
Agent System Agent loop, context, plans, multi-agent, streaming
Cognitive Tools Memory, KG, diary, project graph (21 tools)
Expression Language 40+ operators, scopes, cascade
Slash Commands All webchat commands
LLM Providers OpenAI, Anthropic, Claude Code, Codex app-server, Antigravity/Agy, Gemini CLI, compatible APIs
PawCode CLI Terminal client and stream-JSON mode
VS Code Extension Editor client and resource panel
Multi-Client Conversations Shared runtime across web, CLI, VS Code, API, channels
Desktop/VNC noVNC desktop, screen tool, audio notes
Media Tools Image/video/audio/3D/voice tools
Tool Catalog Agent-facing tools
Services Catalog Service types and provider integrations
Task Catalog Built-in flow tasks and tool tasks
PawFlow Packages Signed .pfp packages, install plans, registries, export/build, and security model
PFP Developer Guide Local package development with dev-load, service providers, flow tasks, media artifacts, and SDK patterns
PFP Publisher Guide Registry publishing, versioning, SHA pinning, and key rotation
Marketplace PFP registries, skill marketplace import, review model, and UI/CLI entry points
Security Model Trust boundaries and production checklist
Deployment Local, Docker, production
Docker Docker setup, relay mode
Filesystem Relay, backends, permissions
Development Creating custom tasks/services

Roadmap

See ROADMAP.md for the full roadmap.

Key upcoming areas:

  • Stabilization and release hardening
  • Manual flow editor
  • New media service providers
  • Git worktree isolation for parallel agents
  • Mobile client (PWA)
  • MCP elicitation and PawFlow as an MCP server
  • Filesystem hooks
  • Full cost tracking dashboard

Contributing

See CONTRIBUTING.md. In short:

  1. Fork & clone
  2. pip install -r requirements.txt
  3. Make changes, run pytest tests/
  4. Open a PR

License

MIT

Yorumlar (0)

Sonuc bulunamadi