#!/bin/env fish begin set -l dir (status dirname) set -l domain "passwords" set -l source "$dir/docker-compose.secrets.yml" source "$dir/../service.fish" function installSW -V dir -V domain -V source set -l file "$dir/docker-compose.base.yml" set -l pw (nix-shell -p keepassxc --run "keepassxc-cli generate --length 32") set -l envKey ".services.vaultwarden.environment" set -l dbKey "$envKey.DATABASE_URL" set -l dbUrl (yq "$dbKey" "$source" | sed "s/^\(.*:\/\/.*:\).*\(@.*\/.*\)\$/\1$pw\2/") initializeServiceInstallation $argv URL="https://$domain.$(getMachineFQDN)" yq "$envKey.DOMAIN = env(URL)" "$file" | \ ADDRESS="noreply@$(getMachineFQDN)" yq "$envKey.SMTP_FROM = env(ADDRESS)" | \ sudo tee "$(getServiceRoot $argv)/$(basename "$file")" >/dev/null URL=$dbUrl yq "$dbKey = env(URL)" "$source" | \ PW=$pw yq ".services.db.environment.MARIADB_PASSWORD = env(PW)" | \ sudo tee (getServiceSecretsConfig $argv) >/dev/null installDockerService $argv end function configureSW -V dir configureDockerService $argv end function getServiceServers -V domain printf "%s\0" "$domain" "" end function getServiceLocations argparse -i "name=" -- $argv printf "%s\0" "$_flag_name" / end function getBackupArgs printf "%s\n" --hidden --no-ignore . --exclude "docker-compose.yml" (getServiceRoot $argv) end runInstaller --force $argv end