Skip to main content

Python based Assistance for Docker

Project description

Q: I can’t figure out why I would need this

A:

In traditional ways, we make aliases ourselves all over the Docker commands.

The reason why I develop this project is to encourage people to contribute and share their ideas and thoughts into plugins, which would give Tsaotun ability to do those things. And, the aboved thing is just one of things that Tsaotun can achieve, you will be able to load variety of plugins in the future as well.

Besides, if you are doing some projects involved running containers, Tsaotun has provide the higher level API for you. That is another helpful functionality.

Currently, I’m moving my previous project VWGen into one of Tsaotun’s plugin. Once I finish, everyone can just load the plugin and extend the power of Tsaotun.

Higher level API

Latest version released on PyPi Compatible on Linux Compatible on Mac Compatible on Windows

1 Main features

  • Run any commands docker can run on Tsaotun

  • All written in Python with love of API of docker

  • Simplify the process making your own implementation of docker command line tool

  • Many Addons are upcoming

2 Installation (All platforms)

2.1 pip

A universal installation method (that works on Windows, Mac OS X, Linux, and always provides the latest version) is to use pip:

# Make sure we have an up-to-date version of pip and setuptools:
$ pip install --upgrade pip setuptools

$ pip install --upgrade tsaotun

(If pip installation fails for some reason, you can try easy_install tsaotun as a fallback.)

2.2 Docker hub

Pull from dockerhub, or build it yourself:

$ docker build -t tsaotun .

Verify that now we have installed the latest version, for example:

$ tsaotun version
Client:
    Version:         0.8.1
    Python version:  2.7.13
    OS/Arch:         Darwin/x86_64

Server:
    Version:         1.13.0-rc7
    API version:     1.25 (minimum version 1.12)
    Go version:      go1.7.3
    Git commit:      48a9e53
    Built:           5 days ago
    OS/Arch:         linux/amd64
    Kernel version:  4.9.3-moby
    Experimental:    True

3 Usage

Hello World:

$ tsaotun [COMMAND]

Synopsis:

$ tsaotun [-h] [--console] [--color] [--debug] [--dry] [--host list]
          [--verbose]
          {version,info,inspect,container,image,network,volume,addon}
          ...

See also tsaotun --help.

4 Addon

Addon feature is testing right now, and each addon should has its own folder with __init__.py inside.

Addon folder struture shows like:

$HOME
└───Tsaotun
    └───addons
        ├── addon_A - __init__.py, ...
        ├── addon_B - __init__.py, ...
        └───__init__.py

4.1 Best practices (Sample addon to remove “ALL” containers at once, no matter it’s dead or alive)

__init__.py: To specify how to override the original command

"""Configuration file for this addon"""

from .Container import rm

__override__ = {'Container.rm': 'Rm'}
__argparse__ = [
    {
        'namespace': "Container",
        'position': "Child",
        'subcommand': "rm",
        'actions': [
            "add_argument('--clear',            \
                            action='store_true', \
                            dest='clear',        \
                            help='Remove all dead and alive containers. \
                                    You still need to give a whatever container ID.')",
        ],
    },
]

Container/rm.py

"""This module contains `docker container rm` class"""

from docker.errors import APIError
from tsaotun.lib.Docker.Container.command import Command
from tsaotun.cli import Tsaotun


class Rm(Command):
    """This class implements `docker container rm` command"""

    name = "container rm"
    require = []

    def __init__(self):
        Command.__init__(self)
        self.settings[self.name] = None

    def eval_command(self, args):
        try:
            containers = args["containers"]
            clear = args["clear"]
            del args["containers"]
            del args["clear"]
            Ids = []
            if clear:
                cli = Tsaotun()
                cli.send('ps -a --format {{Id}}')
                ress = cli.recv()
                if ress:
                    ress = ress.split('\n')
                    ress = [res[0:4] for res in ress]
                    for Id in ress:
                        Ids.append(Id)
                        args['container'] = Id
                        self.client.remove_container(**args)
            else:
                for Id in containers:
                    Ids.append(Id)
                    args['container'] = Id
                    self.client.remove_container(**args)
            self.settings[self.name] = '\n'.join(Ids)

        except APIError as e:
            raise e

    def final(self):
        return self.settings[self.name]

5 Licence

Apache License v2.0: LICENSE.

6 Author

Boik Su (@qazbnm456) created Tsaotun.

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

tsaotun-0.9.4.tar.gz (54.2 kB view details)

Uploaded Source

Built Distribution

tsaotun-0.9.4-py2.py3-none-any.whl (69.7 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file tsaotun-0.9.4.tar.gz.

File metadata

  • Download URL: tsaotun-0.9.4.tar.gz
  • Upload date:
  • Size: 54.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for tsaotun-0.9.4.tar.gz
Algorithm Hash digest
SHA256 43dab51e2e2ec9a8593655ae0bfeb6b82f9a0f7ce2bade226dbb95b3b56ce52e
MD5 5c128d391e906349501e3573b2985900
BLAKE2b-256 30a25f85137c990c875103da223418c1e23de35fd211f1bf080079e0bc4d8480

See more details on using hashes here.

File details

Details for the file tsaotun-0.9.4-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for tsaotun-0.9.4-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 1055c9eed53f8a9006e1d9c88571051f27bc1d72f149b7e3864f3d045d3ca86b
MD5 878321209aa2a97b1f29fc18220bd2a5
BLAKE2b-256 276e0ad6dc5fa121e0794eee8a9d0d0011bd7f5e95749ed19285e1b2d4775366

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