Skip to main content

A portable containerized shell

Project description

Kitt

Kitt is a container based portable shell environment manager.

Build, spawn, push and distribute your shell, with your tools, and your config, anywhere.

Demo

Installation

First, make sure you have python3 and Docker installed.

To use kitt as a non root user, you should be in docker group : sudo usermod -aG docker USER.

➜  pip install kitt-shell

.. or just run kitt.py from sources.

How to use Kitt

Fill a configuration file (see examples folder) either in toml or json format. Feed it to Kitt and let the magic happend !

➜  kitt build examples/devops.conf devops
✓ Build success !

➜  kitt run devops
user@kitt:~# 

Not your computer but you need your tools ? No problem.

➜  kitt pull senges/kitt devops
✓  Image devops pull done

➜  kitt run devops
user@kitt:~# 

Few commands workflow examples are available in examples folder.

Kitt CLI reference

➜  kitt --help

Usage: kitt [OPTIONS] COMMAND [ARGS]...

  main command group

Options:
  -h, --help   Show this message and exit.
  -d, --debug  Debug mode

Commands:
  build    Build image from source config file
  inspect  Show image metadata
  list     List local images
  patch    Patch image runtime metadata
  prune    Prune local images
  pull     Pull image and exit
  push     Push kitt image to registry
  refresh  Pull latest version of local images
  remove   Remove local image
  run      Run kitt shell
  version  Show version

Configuration

Basics

[options]
docker_in_docker = false    # Share docker socket
forward_x11 = false         # Configure x11 forward

[workspace]
image = "ubuntu:22.04"  # OCI System Image
tools = []              # Nix tools
user = "user"           # Username inside container
hostname = "kitt"       # Container hostname
default_shell = "bash"  # One of bash, zsh, sh, dash
paths = []              # Additional folders in $PATH

# [[workspace.envs]]  # Container exported ENV (multiple)
# name = ""
# value = ""

# [[workspace.volumes]]   # Container bind volumes (multiple)
# host = ""   # Local directory
# bind = ""   # Bin inside container
# mode = ""   # Mode (default is 'rw')

# [secrets]
# [[secrets.files]]   # File entry (multiple)
# src = ""                    # Host path
# dest = ""                   # Container path
# [[secrets.envs]]   # Env variable (multiple)
# name = ""                   # Variable name
# value = ""                  # Secret value

For more details about Nix tools, see tools installation section.

Secrets

Kitt is able to embed password encrypted secrets (files and env vars) inside an image.

A password prompt will be shown at container runtime to decrypt and restore the secrets :

  • Env vars are loaded inside the container
  • Files are restored insed a tempFS destoyed at container exit

Warning
Kitt vault uses SHA256(password) as AES encryption key. Use with caution, weak password could lead to sensitive information leak.

Plugins

Kitt offers multiple optional plugins to improve environment customization.

Plugin Description Requires
zsh install and setup Zsh (oh-my-zsh)
copy copy local files inside container
download download ressources inside container curl
git clone git repository inside container git
pip install pip package pip

See PLUGINS.md for configuration details.

Need another plugin ?

Add jinja formated plugin inside kitt/static/plugins folder and use it in your config file under the same name.

How does it work ?

Kitt will build an OCI Container Image (compatible with Docker, Podman, ...), according to the provided configuration file. It will install requested tools inside, setup your desired shell(s), shortcuts, completion, plugins, and add your configuration files.

At runtime, Kitt will create a container from this image, spawn a shell inside and attach it to your current TTY.

Tools installation

For the tool installation part, Kitt relies on the huge 80k+ packages NixOS Store. It does provide an uniform OS agnostic way of installing tools inside containers, and can be extended if necessary.

Thanks to Nix, you can effortlessly change your base image OS, anytime.

Containerization

At first, kitt was meant to run with Podman as it is rootless by design (which solves uig/gid mapping problems).
However, for multiple reasons, it should now mainly run with Docker. Podman support is in progress, see branch feat/podman.

What is UID/GID reflexion ?

TL;DR: It's great for shared folders file rigths.

Kitt uses fixuid project to reflect host user UID/GID inside the container. What does that means ?

As Docker containers run as root (except rootless ones, but still), if you have a shared volume between your host and container, files created inside the container will be owned by root on the host. This mecanism makes working with volumes for user owned files very unconvenient.

With fixuid, the user inside the container will have the exact same real uid as your current host user. So if you bind a directory (your home for example), any file created by the user inside the container will be own by your user on the host side instead of root.

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

kitt-shell-0.8.6.tar.gz (29.7 kB view details)

Uploaded Source

Built Distribution

kitt_shell-0.8.6-py3-none-any.whl (31.0 kB view details)

Uploaded Python 3

File details

Details for the file kitt-shell-0.8.6.tar.gz.

File metadata

  • Download URL: kitt-shell-0.8.6.tar.gz
  • Upload date:
  • Size: 29.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.8

File hashes

Hashes for kitt-shell-0.8.6.tar.gz
Algorithm Hash digest
SHA256 7ef8eabd815e3d9344cc660f096044a65b2a2322c72b076b29623657b261efb5
MD5 fe3a10ea7fd5441cb7cc78821ce74a58
BLAKE2b-256 bac0ab8d2d3bffe4e9fd4954523c1826cf25e83845971e46303474488c1147b0

See more details on using hashes here.

File details

Details for the file kitt_shell-0.8.6-py3-none-any.whl.

File metadata

  • Download URL: kitt_shell-0.8.6-py3-none-any.whl
  • Upload date:
  • Size: 31.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.8

File hashes

Hashes for kitt_shell-0.8.6-py3-none-any.whl
Algorithm Hash digest
SHA256 3f75c286755285c41bb01594fc542f253419d0763e14c9eb6edc0d713286b568
MD5 ee1f8b8ea1252976c64ad151aa0d05a0
BLAKE2b-256 6a74a335d87467361a113bccdb9ae93c3d17f7a2662686b72833876e8962dcf8

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page