#!/bin/env fish begin set -l dir (status dirname) set -l source "$dir/docker-compose.templates.yml" source "$dir/../service.fish" set -l environments \ forgejo mydrone "" \ github drone "" function installSW -V dir -V environments -V source set -l root (getServiceRoot $argv) set -l config "$root/docker-compose.base.yml" set -l secrets (getServiceSecretsConfig $argv) set -l ciTemplate (yq (getServiceKey ci-template) "$source") set -l dockerTemplate (yq (getServiceKey docker-template) "$source") set -l sshTemplate (yq (getServiceKey ssh-template) "$source") initializeServiceInstallation $argv echo "{}" | sudo tee "$config" >/dev/null echo "{}" | sudo tee "$secrets" >/dev/null cp "$dir"/{ci.Dockerfile,.dockerignore} "$root" echo "DRONE_JSONNET_ENABLED=true" | sudo tee "$root/server.common.env" >/dev/null echo "DRONE_RUNNER_CAPACITY=2" | sudo tee "$root/runner.common.env" >/dev/null for i in (seq 1 3 (count $environments)) set -l name $environments[$i] set -l domain $environments[(math $i + 2)] set -l subdomain $environments[(math $i + 1)] set -l user $environments[(math $i + 3)] set -l secret (openssl rand -hex 16) set -l runners ssh docker set -l services ci $runners set -l tmpConfig (mktemp) set -l tmpSecrets (mktemp) set -l ciName "$name-ci" set -l sshName "$name-ssh-runner" set -l dockerName "$name-docker-runner" set -l ciEnv set -l sshEnv set -l dockerEnv cp "$config" "$tmpConfig" cp "$secrets" "$tmpSecrets" for serviceName in $services set -l file (mktemp) set -l nameVar "$serviceName""Name" set -l serviceKey ".services.[\"$$nameVar\"]" set "$serviceName""Key" "$serviceKey" set "$serviceName""Env" "$serviceKey.environment" end CI_NAME=$ciName \ SECRET_ENV="$name.secret.env" \ RUNNER_ENV="$name.runner.env" begin begin printf "%s\n" \ DRONE_RPC_PROTO=http \ "DRONE_RPC_HOST=$name-ci" end | sudo tee "$root/$RUNNER_ENV" >/dev/null echo "DRONE_RPC_SECRET=$secret" | sudo tee "$root/$SECRET_ENV" >/dev/null yq "$ciKey = $ciTemplate" "$tmpConfig" | \ ENTRY="./data/$name:/data" yq "$ciKey.volumes = [ env.ENTRY ]" | \ yq "$ciKey.env_file |= . + [ env.SECRET_ENV ]" | \ PROTO=https yq "$ciEnv.DRONE_SERVER_PROTO = env.PROTO" | \ HOST=(getServiceDomain "$subdomain" "$domain") yq "$ciEnv.DRONE_SERVER_HOST = env.HOST" | \ yq "$dockerKey = $dockerTemplate" | \ yq "$sshKey = $sshTemplate" | \ yq "$dockerKey.depends_on = [ env.CI_NAME ]" | \ yq -y "." | \ sudo tee "$config" >/dev/null for key in $dockerKey $sshKey set -l file (mktemp) yq "$key.depends_on = [ env.CI_NAME ]" "$config" | \ yq "$key.env_file |= . + [ env.RUNNER_ENV, env.SECRET_ENV ]" | \ yq -y "." | \ tee "$file" >/dev/null sudo cp "$file" "$config" rm "$file" end PORT="127.0.0.1:1337:80" yq "$ciKey.ports = [ env.PORT ]" "$tmpSecrets" | \ yq -y "." | \ sudo tee "$secrets" >/dev/null end end installDockerService $argv end function configureSW -V dir configureDockerService $argv end function getServiceServers -V environments argparse -i "name=" -- $argv set -l name "$_flag_name" for i in (seq 1 3 (count $environments)) set -l domain $environments[(math $i + 2)] set -l subdomain $environments[(math $i + 1)] printf "%s\0" "$subdomain" "$domain" end end function getServiceLocations -a index -V environments set -l i (math (math (math $index - 1) / 2 "*" 3) + 1) set -l name $environments[$i] printf "%s\0" "$name-ci" / end function getBackupArgs printf "%s\n" --hidden --no-ignore "data|\.secrets?\." (getServiceRoot $argv) end runInstaller --force $argv end