Skip to main content

The Watcher - An agentic system troubleshooting tool powered by Claude

Project description

Uatu

AI-powered system troubleshooting agent using Claude.

autu-demo

What it does:

  • Chat with your system to diagnose issues
  • Pipe logs directly for instant analysis
  • Approve commands before execution with granular controls
  • Connects symptoms across CPU, memory, network, and processes

Platforms:

  • macOS
  • Linux

Installation

Using pipx (recommended)

# Install with pipx for isolated environment
pipx install uatu

# Configure API key
echo "ANTHROPIC_API_KEY=your_key" > .env

Using pip

# Install globally or in a virtual environment
pip install uatu

# Configure API key
echo "ANTHROPIC_API_KEY=your_key" > .env

From source with uv

# Install uv (if not already installed)
curl -LsSf https://astral.sh/uv/install.sh | sh

# Clone and install
git clone https://github.com/fractalops/uatu.git
cd uatu
uv sync

# Configure API key
echo "ANTHROPIC_API_KEY=your_key" > .env

Quick Start

Interactive Chat

Start a troubleshooting session:

# Read-only mode (default) - uses MCP tools, no bash
uatu

# Allow bash commands with approval prompts
UATU_READ_ONLY=false uatu

Example questions:

  • "What's causing high CPU usage?"
  • "Why is my server running slowly?"
  • "Investigate recent memory issues"
  • "What's listening on port 8080?"

Commands require approval unless allowlisted.

Stdin Mode

Pipe data for analysis:

# Read-only (default) - MCP tools only
cat /var/log/app.log | uatu "find errors"

# Enable bash commands (requires UATU_READ_ONLY=false)
UATU_READ_ONLY=false journalctl -u myservice | uatu "why did this crash?"

# Safe bash commands (ps, df, top, etc.) auto-approve from allowlist
UATU_READ_ONLY=false ps aux | uatu "diagnose memory issues"

Allowlisted commands auto-approve in stdin mode. TTY required for interactive approval prompts.

Configuration

Create .env:

# Required
ANTHROPIC_API_KEY=your_key

# Security (defaults shown)
UATU_READ_ONLY=true                     # true: MCP tools only, false: allow bash
UATU_REQUIRE_APPROVAL=true              # Require approval before bash execution
UATU_ALLOW_NETWORK=false                # Allow network access (WebFetch, WebSearch)

# Agent features
UATU_MODEL=claude-sonnet-4-5-20250929  # Claude model
UATU_ENABLE_SUBAGENTS=true              # Specialized diagnostic agents
UATU_ENABLE_SKILLS=true                 # Filesystem-based agent skills
UATU_MAX_BACKGROUND_JOBS=2              # Concurrent background bash jobs

# UI options
UATU_CONSOLE_WIDTH=80                   # Terminal width (80, 0=full, None=auto)
UATU_SHOW_TOOL_PREVIEWS=true            # Show tool result previews
UATU_SHOW_STATS=true                    # Show session token/cost stats

# Telemetry (opt-out)
UATU_ENABLE_TELEMETRY=true              # Local session telemetry
UATU_TELEMETRY_PATH=~/.uatu/telemetry.jsonl

Security

Command Approval

Bash commands require approval unless allowlisted:

 Bash command approval required
Risk: Credential Access

⚠ Warning: This command may access SSH keys, certificates, or other credentials

ls -la ~/.ssh/

   Allow once
   Always allow (exact)
   Deny

Audit Log

Security decisions are logged to ~/.config/uatu/audit.jsonl:

# View audit log (last 100 events)
uatu audit

# View recent events
uatu audit --last 20

# View specific event types
uatu audit --type bash_command_approval

# View summary statistics
uatu audit --summary

Allowlist

Manage approved commands in ~/.config/uatu/allowlist.json:

# View directly
cat ~/.config/uatu/allowlist.json

# In interactive chat (with tab completion)
/allowlist                    # Show approved commands
/allowlist add <command>      # Add to allowlist
/allowlist remove <pattern>   # Remove from allowlist
/allowlist clear              # Clear all

Development

# Run tests
uv run pytest

# Lint
uv run ruff check .

# Format
uv run ruff format .

License

This project is licensed under the MIT License - see the LICENSE file for details.

Built With

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

uatu-0.1.15.tar.gz (9.6 MB view details)

Uploaded Source

Built Distribution

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

uatu-0.1.15-py3-none-any.whl (99.4 kB view details)

Uploaded Python 3

File details

Details for the file uatu-0.1.15.tar.gz.

File metadata

  • Download URL: uatu-0.1.15.tar.gz
  • Upload date:
  • Size: 9.6 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for uatu-0.1.15.tar.gz
Algorithm Hash digest
SHA256 f4047c6fdcffed689e9aceed01f95884b7228b9e14eba1ea9794937dd35e46fa
MD5 b6d04b91d399c286e81529265a080c45
BLAKE2b-256 097ab2ac578dd1622507c9ee850e079e32a7468112d5046608e3fc21e399f276

See more details on using hashes here.

Provenance

The following attestation bundles were made for uatu-0.1.15.tar.gz:

Publisher: publish.yml on fractalops/uatu

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

File details

Details for the file uatu-0.1.15-py3-none-any.whl.

File metadata

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

File hashes

Hashes for uatu-0.1.15-py3-none-any.whl
Algorithm Hash digest
SHA256 cc0f08b1b36cac6419b89340435342436236f69b8b397dd74faa23fba39d40cc
MD5 9abc7e0e1709fe389f8b90d12c8ee63f
BLAKE2b-256 c35e81239625b205a57f832a26e42ee733634d753107fe2ad9bcbdd5b301cc53

See more details on using hashes here.

Provenance

The following attestation bundles were made for uatu-0.1.15-py3-none-any.whl:

Publisher: publish.yml on fractalops/uatu

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