Skip to main content

One CLI for Docker, Kubernetes and Helm: compose projects (up/down/ps), kubectx/kubens, helm-repos/helm-list.

Project description

POCO

Test pypi pypi Test Coverage Maintainability

Poco is one CLI for Docker, Kubernetes and Helm: catalogue and run compose projects, switch kubectl context and namespace, and list Helm repos and releases — without leaving your terminal or remembering three different tools.

  • Dockerpoco up, poco down, poco ps, poco status (overview), compose config, build, pull; YAML catalog and plans.

  • Kubernetespoco kubectx, poco kubens (list/switch context and namespace); poco kube-get pods|ns|svc|...; presets (context+namespace in one command).

  • Helmpoco helm-repos, poco helm-list (releases; optional --all-namespaces, -i to pick and show status).

  • Simple. Configure, run and switch between projects with a very simple command line interface.

  • Flexibility. Manage, scale, maintain projects of any complexity with ease.

  • Configure Once, Use Everywhere. Configure project once so the rest of your team will feel the value of zero configuration.

Features

  • Docker, Kubernetes, Helm in one place — Compose projects, kubectl context/namespace, Helm repos and releases.
  • Git, SVN support out of the box.
  • Project Catalog, Multiple Catalogues. Create your own project catalog. Organise your projects without additional tools.
  • Multiple Plans. Create multiple plans for different environments or even environments for demo purposes. Switch between plans (environments) with ease.
  • Simple Config Files. Poco helps to split config files, so it is easy to maintain and scale them any time.
  • Script Support (Hooks). Add additional scripts any time.

Global options

  • -i, --interactive — Interactive menu: choose actions step by step without typing commands (poco -i).
  • -V, --verbose — Print more (e.g. merged docker compose config for up/down).
  • -VV or --no-matrix — No matrix effect, show full output (for up/down). Implies verbose.
  • -q, --quiet — Print less.
  • --offline — Offline mode.
  • --always-update — Project repository handle by user.

For poco up / poco down, a matrix-style effect runs by default; only the final result is shown. Set POCO_MATRIX=0 to disable the effect, or use -VV / --no-matrix to disable it and see the full log.

Documentation

All documentation is available on getpoco.io

Requirements

  • Python 3.12.3 or newer (supported version: 3.14.3)
  • Git or SVN
  • SSH
  • Docker (17.0.0 or higher version is recommended)
  • Docker Compose V2 (plugin: docker compose), for compose support
  • kubectl, for Kubernetes support
  • helm, for helm functionality support

Quick start

Install poco:

$:~ pip install poco

Or use the install script (curl one-liner):

bash -c "$(curl -fsSL https://raw.githubusercontent.com/shiwaforce/poco/master/install.sh)"

Install script options:

Option Description
Full reset Remove previous install, then install fresh: bash -c "$(curl -fsSL https://raw.githubusercontent.com/shiwaforce/poco/master/install.sh)" -- --reset
Self-update Update the install script itself: bash -c "$(curl -fsSL https://raw.githubusercontent.com/shiwaforce/poco/master/install.sh)" -- --update
Dev branch Install from dev branch: bash -c "$(curl -fsSL https://raw.githubusercontent.com/shiwaforce/poco/master/install.sh)" -- dev

Init project:

$:~ mkdir my-project
$:~ cd my-project
$:~ poco init

poco.yml and docker-compose.yml example files will be created.

Start project:

$:~ poco up

Before adding your project to Poco Repo create new empty git repository, add repository to your local Poco Repo config:

$:~ poco repo add <name> <git-url>

Now you can add your project to repo:

$:~ poco project add [<target-dir>] [<catalog>]

Publish your changes:

$:~ poco repo push

Stop your project:

$:~ poco stop

One CLI: Docker, kubectl, Helm

Stack Poco commands What you get
Docker poco up, poco down, poco ps, poco config, … Compose projects from a YAML catalog; matrix-style run; verbose merged config.
Kubernetes poco kubectx, poco kubens List/switch context and namespace (kubectx/kubens-style).
Helm poco helm-repos, poco helm-list List repos and releases; helm-list --all-namespaces for all.

Requires Docker and/or kubectl/helm installed. Poco checks availability and works with different kubectl/helm versions.

Presets (workflow)

Save and switch context + namespace in one step:

  • poco preset list — List saved presets.
  • poco preset use <name> — Switch to a preset (context and namespace).
  • poco preset save <name> — Save current context and namespace as a preset.

Presets are stored in ~/.poco/presets.yml.

Kube-get

Shortcut for common kubectl get usage:

  • poco kube-get <resource> [name] — e.g. poco kube-get pods, poco kube-get ns, poco kube-get svc.
  • Use -n <namespace> or -A (all namespaces) when needed.

Interactive mode (-i / --choose)

When a command can show a list, use -i to pick from a menu (or fzf if installed):

  • poco kubectx -i — Choose context from list.
  • poco kubens -i — Choose namespace from list.
  • poco preset use -i — Choose preset from list.
  • poco helm-list -i — Choose release, then show helm status.

Security

  • Dependencies: We track known vulnerabilities and bump affected packages (e.g. GitPython ≥3.1.41 for CVE fixes). To audit your install: pip install pip-audit && pip-audit (or pip-audit -r requirements.txt).
  • Build tools: Keep setuptools and wheel up to date: pip install -U setuptools wheel to address CVEs in the toolchain.

Agent Skills

Use Poco with AI coding agents (Cursor, Claude Code, etc.): install Agent Skills so the agent knows when and how to run poco. Add the poco-skills repo as a Remote Rule: Settings > Rules > Add Rule > Remote Rule (Github) with shiwaforce/poco-skills. Optionally, run poco init --with-cursor-skill in a project to generate a project-specific skill (.cursor/skills/poco-project/SKILL.md).

Changelog

See CHANGELOG.md for release history. 1.0 — Docker + Kubernetes + Helm in one CLI; presets; kube-get; interactive menu (poco -i); poco status; matrix effect; before_docker_script; security (GitPython, pip-audit).

Licence

MIT Copyright (c) 2017-present, Shiwaforce.com

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

poco-1.0.1.tar.gz (59.1 kB view details)

Uploaded Source

Built Distribution

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

poco-1.0.1-py2.py3-none-any.whl (83.5 kB view details)

Uploaded Python 2Python 3

File details

Details for the file poco-1.0.1.tar.gz.

File metadata

  • Download URL: poco-1.0.1.tar.gz
  • Upload date:
  • Size: 59.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.25

File hashes

Hashes for poco-1.0.1.tar.gz
Algorithm Hash digest
SHA256 8a15d11d8d0105ee61aa2145d4793b2fb3da833e0086e9c862604d62ac9f28b5
MD5 98884b45926a92c7bbcade76111e9e20
BLAKE2b-256 70116bfbb20bda56f457117a89a69cb14deb0c6e94dcd2b4d399e9c751e52926

See more details on using hashes here.

File details

Details for the file poco-1.0.1-py2.py3-none-any.whl.

File metadata

  • Download URL: poco-1.0.1-py2.py3-none-any.whl
  • Upload date:
  • Size: 83.5 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.25

File hashes

Hashes for poco-1.0.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 cdde46d094b397babc300909883fb427cb652e62e005f5f8fc8b66ae2c9da7ce
MD5 3b7283e88796a2216606ce01300f0f71
BLAKE2b-256 a35a27e6a0dbb4e8c43687c13db9eb2f5e6ec1ef8dcf373fcbee07a507c28a9a

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