Skip to main content

Telegram gateway for Claude Code CLI - control Claude remotely via Telegram

Project description

Claude Gateway

A Telegram bot that lets you remotely control Claude Code CLI from your phone. Designed to run on a Raspberry Pi or any Linux server, it forwards your Telegram messages to Claude Code and streams responses back in real time.

Telegram <──> claude-gateway <──> Claude Code CLI

Dashboard: A web dashboard for browser-based access is included but is still a work in progress.


Features

  • Send messages to Claude Code from Telegram from anywhere
  • Conversations carry context automatically (uses --continue between messages)
  • Switch between projects with /project or an inline keyboard
  • Create new project directories with /newproject
  • Upload images directly to your current project folder
  • Cancel running Claude operations with /stop
  • Chat ID whitelist keeps the bot private
  • Interactive setup wizard (claude-gateway setup)
  • Optional systemd service for auto-start on boot
  • Code blocks in responses — code in Claude's output is automatically formatted as Telegram code blocks for easy reading and one-tap copying

Prerequisites

  1. Claude Code CLI installed and authenticated on the host machine:

    npm install -g @anthropic-ai/claude-code
    claude --version
    
  2. Python 3.11+ on the host machine.

  3. A Telegram bot token — create one via @BotFather on Telegram (/newbot).

  4. Your Telegram chat ID — you can find it by messaging @userinfobot or by starting the bot without a whitelist and reading the ID from the unauthorized message.


Installation

Recommended: pipx (isolated environment)

pipx install claude-gateway

Alternative: pip

pip install claude-gateway

From source

git clone https://github.com/yourusername/claude-gateway.git
cd claude-gateway
pip install -e .

Setup

Run the interactive wizard after installation:

claude-gateway setup

The wizard will ask for:

Setting Description
Bot token The token from @BotFather
Allowed chat IDs Comma-separated Telegram chat IDs that can use the bot
Default project path Directory Claude opens in for each new session
Project search dirs Comma-separated dirs scanned for the /project command
New project dir Where /newproject creates folders
Dashboard host/port Optional, defaults to 0.0.0.0:3000

Configuration is saved to ~/.config/claude-gateway/config.env.

Getting your chat ID

If you're not sure of your chat ID, start the bot without setting one, send any message, and the bot will reply with your ID. Then re-run claude-gateway setup and add it.


Running the bot

claude-gateway start

The bot will connect to Telegram and start listening for messages.


Bot commands

Command Description
/start Welcome message and current project
/help Show all commands
/new Start a fresh Claude conversation
/project Show project picker (inline keyboard)
/project <name> Switch to a named project
/newproject <name> Create a new project directory and switch to it
/status Show current session info
/stop Cancel the current Claude operation

Any other message is forwarded directly to Claude Code.


Configuration reference

All settings can be set via environment variables or in ~/.config/claude-gateway/config.env:

# Required
TELEGRAM_BOT_TOKEN=your_bot_token_here

# Security: comma-separated chat IDs allowed to use the bot
ALLOWED_CHAT_IDS=123456789,987654321

# Project directories
DEFAULT_PROJECT_PATH=/home/user/projects
PROJECT_SEARCH_DIRS=/home/user/projects,/mnt/ssd/projects
NEW_PROJECT_DIR=/home/user/projects

# Dashboard (optional, work in progress)
DASHBOARD_HOST=0.0.0.0
DASHBOARD_PORT=3000

# Data storage for the dashboard agent store
DATA_DIR=/home/user/.local/share/claude-gateway

Environment variables always take precedence over the config file. A .env file in the current working directory takes precedence over ~/.config/claude-gateway/config.env.


Running as a systemd service

Generate service files with:

claude-gateway systemd

This creates claude-gateway.service and claude-dashboard.service in the current directory. Install them:

sudo cp claude-gateway.service /etc/systemd/system/
sudo systemctl daemon-reload
sudo systemctl enable --now claude-gateway

Check status and logs:

sudo systemctl status claude-gateway
journalctl -u claude-gateway -f

Dashboard (Work in Progress)

A web dashboard is included that provides browser-based access to Claude via agents. It is currently a work in progress and may have rough edges.

To start it:

claude-gateway dashboard

Then open http://localhost:3000 in your browser.

The dashboard exposes a REST + WebSocket API (/api/*) and a React frontend (if the frontend has been built). The frontend source is in the frontend/ directory.


Security

  • Chat ID whitelist: Only configured chat IDs can interact with the bot. Anyone else receives an unauthorized message showing their chat ID.
  • Path validation: The bot blocks access to sensitive system directories (/etc, /root, /var, /usr, /bin, /sbin, /boot).
  • --dangerously-skip-permissions: Claude Code runs without interactive permission prompts since there is no TTY. Access control is delegated to the Telegram whitelist and path validation.
  • Config file permissions: The setup wizard creates ~/.config/claude-gateway/config.env with mode 0600 (owner read/write only).

Project structure

claude_gateway/
├── cli.py           # CLI entry point (setup, start, dashboard, systemd)
├── config.py        # Configuration loading
├── gateway.py       # Telegram bot handlers
├── claude_runner.py # Claude Code process manager
├── dashboard.py     # FastAPI dashboard (WIP)
├── agent_store.py   # JSON persistence for dashboard agents
└── models.py        # Pydantic data models

License

MIT

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

claude_gateway-0.1.1.tar.gz (17.8 kB view details)

Uploaded Source

Built Distribution

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

claude_gateway-0.1.1-py3-none-any.whl (20.2 kB view details)

Uploaded Python 3

File details

Details for the file claude_gateway-0.1.1.tar.gz.

File metadata

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

File hashes

Hashes for claude_gateway-0.1.1.tar.gz
Algorithm Hash digest
SHA256 88ac541499c50bc5884e2925d9638ab2e137191424532d441f56fc7f2b0f63b6
MD5 bc72bda532fa4ac4672e00e516ddfb19
BLAKE2b-256 ccd9bcd4424895a2aaf1e6f2f44712ccd502fc7f91eabd5dec663500f8965e7f

See more details on using hashes here.

Provenance

The following attestation bundles were made for claude_gateway-0.1.1.tar.gz:

Publisher: publish.yml on gieldid/claude_gateway

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

File details

Details for the file claude_gateway-0.1.1-py3-none-any.whl.

File metadata

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

File hashes

Hashes for claude_gateway-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 1e1c6c45a37d8146b3436c9fb0b88ed538c94097aab5f470c2678f1f8281c4bc
MD5 6a8a956afaed5fe8964c9c75f5b9e0b9
BLAKE2b-256 0cf4d61edfb138196992fbab7b18296b13aca4359fe181bbc2fe0c0c1fbca25d

See more details on using hashes here.

Provenance

The following attestation bundles were made for claude_gateway-0.1.1-py3-none-any.whl:

Publisher: publish.yml on gieldid/claude_gateway

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