Metadata-Version: 2.4
Name: docky
Version: 9.0.3
Summary: Make developpement with docker simply
Home-page: https://github.com/akretion/docky/
Author: Akretion
Author-email: contact@akretion.com
License: AGPLv3+
Classifier: Programming Language :: Python :: 3
Classifier: Operating System :: POSIX :: Linux
License-File: LICENSE
Requires-Dist: python-on-whales
Requires-Dist: plumbum
Requires-Dist: rainbow_logging_handler
Requires-Dist: python-slugify
Requires-Dist: requests
Requires-Dist: importlib-metadata
Requires-Dist: PyYAML>=6.0.1
Dynamic: author
Dynamic: author-email
Dynamic: classifier
Dynamic: description
Dynamic: home-page
Dynamic: license
Dynamic: license-file
Dynamic: requires-dist
Dynamic: summary

Introduction
=================

docky is a dev tool to set up and run multiple odoo projects.


History & motivation
--------------------

This project was initially created for building Odoo environments without effort based on docker-compose and docker.


Main features
---------------

Simplify docker-compose CLI with few short cuts.


Requirements
------------

docker-ce : https://docs.docker.com/install/ (or podman)


Installation
------------

Docky is available from pypi

.. code-block:: shell

    pip install docky
    # or with pipx : pipx install docky --include-deps


Update Docky
-------------

.. code-block:: shell

    pip install docky --upgrade
    # or with pipx : pipx upgrade docky --include-deps


Usage: labels
-------------

The label docky.main.service and docky.user

.. code-block:: shell

    docky.main.service: odoo
    docky.user: odoo

Allows you to define the main service of your docker-compose.yml file, and to specify the command line user for the container when you run for example 'docky run'.


Usage: recommendations
----------------------

* Use `ak <https://github.com/akretion/ak>`_ to build your project.
* When developing, if you are on several projects at once, it quickly becomes a mess to manage different ports of your containers. We recommend usage of Traefik. Here is an example docker-compose.yml file for local development purposes:

.. code-block:: yaml

    version: "3.7"
    services:
        traefik:
        image: "traefik:v2.1"
        restart: always
        container_name: "traefik"
        command:
            - "--api.insecure=true"
            - "--providers.docker=true"
            - "--providers.docker.exposedbydefault=false"
            - "--entrypoints.web.address=:80"
        ports:
            - "127.0.0.1:80:80"
            - "127.0.0.1:8080:8080"
        volumes:
            - "/var/run/docker.sock:/var/run/docker.sock:ro"
        networks:
        - traefik

    networks:
        traefik:
            name: traefik

More info about Traefik config on this repo: https://github.com/akretion/traefik-template


Troubleshooting
---------------

To avoid issues with line wrapping with "docky open" please use a version of docker > to  18.06.0-ce
see : https://github.com/docker/compose/issues/6151


Changelog
----------
version 9.0.0
- Migration from docker-compose to docker compose

version 8.0.0
- remove docky init

version 7.0.7
- update copier depency
- adapt readme

version 7.0.6
- update copier dep to 6.0.0a9
- remove dead code (old template)

version 7.0.5
- fix requirements.txt

version 7.0.4
- use `copier` for managing the template
- drop python 3.5 support

version 7.0.0

- remove the need of docky config file in $HOME
- use .env to be more compatible with docker-compose
- improve templates
- create init command
- heavy refactoring


version 6.0.0

- refactor remove proxy code and use traefik
- remove docky.yml now you must use labels on services (see doc)
- add option "--service=myservice" on docky run and docky open

version 5.0.0:

- Resolve mac compatibility by remove proxy code that use a mounted version of etc/hosts
  now you need to install dnsmasq.
  This should also solve windows compatibilty by using the local dns https://stackoverflow.com/questions/138162/wildcards-in-a-windows-hosts-file?answertab=votes#tab-top
- Solve issue with project name in multi user env (the name is based on user + directory name)
- Add possibility to specify the service for run, open, logs, kill, down, restart, start cmd
  for example now you can do "docky open db" to open a terminal on the db server
  or you can restart a service like "docky restart varnish"
- Solve issue with missing aliases name
- Solve issue with missing environment variable with docky open (now we use a monkey-pacthed version of docker-compose exec)
- Fix documentation build
- Improve docky none specific cmd to a project to be run without project.
  For example, you can use docky help, docky proxy outside of a directory project
