#!/bin/bash -e # cyche-build [--self] # # (Re)build and deploy docker services using the files associated with . # # In the typical case, this is a straightforward process and `docker compose up` # can properly recreate/start containers for the guest service. However, when # rebuilding cychedelic itself, --self must be given, to instruct this file to # modify its behavior to support self-upgrade of the running compose service. # # In `--self` mode, we prepare and start the cychedelic service under an # alternate project name each time, before taking down the existing (old) # services. This is necessary because running `docker compose up` terminates # old containers before starting new one. Termination of the ACID service # interrupts the `compose up` process before it can start the replacements. # Normally, `docker compose down` is then not needed. # # We take (from cyche-source) so we may commit it to the cache iff the # deployment is successful. # # This file exits early on any failure (non-zero). On a successful run in # `--self` mode, this file does not exit (we are killed by `compose down`). cd "/services/$1" if [ "$3" == "--self" ]; then prev=$(cat '.git/previous_slug') [ -n "$prev" ] && prev="--project-name $prev" slug=$(echo -n "$1-"; tr -dc a-z .git/previous_hash if [ "$3" == "--self" ]; then echo "$slug" >.git/previous_slug docker compose down docker compose $prev down fi