Skip to main content

A remote terminal API.

Project description

⚡ Open Terminal

A lightweight API for running shell commands remotely — designed for AI agents and automation.

The container ships with a full toolkit (Python, git, jq, curl, build tools, and more) and runs as a non-root user with passwordless sudo.

Getting Started

Docker (recommended)

docker run -d --name open-terminal --restart unless-stopped -p 8000:8000 -v open-terminal:/home/user -e OPEN_TERMINAL_API_KEY=your-secret-key ghcr.io/open-webui/open-terminal

If no API key is provided, one is auto-generated and printed on startup (docker logs open-terminal).

Build from Source

docker build -t open-terminal .
docker run -p 8000:8000 open-terminal

Bare Metal

# One-liner with uvx (no install needed)
uvx open-terminal run --host 0.0.0.0 --port 8000 --api-key your-secret-key

# Or install globally with pip
pip install open-terminal
open-terminal run --host 0.0.0.0 --port 8000 --api-key your-secret-key

Quick Examples

Run a command:

curl -X POST http://localhost:8000/execute?wait=5 \
  -H "Authorization: Bearer <api-key>" \
  -H "Content-Type: application/json" \
  -d '{"command": "echo hello"}'

Upload a file:

curl -X POST "http://localhost:8000/files/upload?directory=/home/user&url=https://example.com/data.csv" \
  -H "Authorization: Bearer <api-key>"

API Docs

Full interactive API documentation is available at http://localhost:8000/docs.

License

MIT — see LICENSE for details.

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

open_terminal-0.2.7.tar.gz (16.6 kB view details)

Uploaded Source

Built Distribution

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

open_terminal-0.2.7-py3-none-any.whl (13.7 kB view details)

Uploaded Python 3

File details

Details for the file open_terminal-0.2.7.tar.gz.

File metadata

  • Download URL: open_terminal-0.2.7.tar.gz
  • Upload date:
  • Size: 16.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.8.0

File hashes

Hashes for open_terminal-0.2.7.tar.gz
Algorithm Hash digest
SHA256 c440a489b01219afaec3cc821b718b53a393dc81e4991875ba44450a90f29bf8
MD5 5994aa040f909a20e4e1f0d26f07936a
BLAKE2b-256 e1658b79ab2dbf737781fb0cde9d2872e4d114a1ea211b43dd6fba2e762c76bb

See more details on using hashes here.

File details

Details for the file open_terminal-0.2.7-py3-none-any.whl.

File metadata

File hashes

Hashes for open_terminal-0.2.7-py3-none-any.whl
Algorithm Hash digest
SHA256 7f4df84523b38735643105134d1b599152ee86dd0725562a3c98ef602df073e3
MD5 a1874d29b30f7daa23d5c09e5af88011
BLAKE2b-256 a76d9b3259c073f30397b60842bef0d8c0ce2f179d6316bf6637747a8c5979ad

See more details on using hashes here.

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