comin, ci: Add confirmation and rollback functionality to deployments

This commit is contained in:
SebastianStork 2026-03-06 18:55:05 +01:00
parent eb021286a5
commit 09e9cd5811
Signed by: SebastianStork
SSH key fingerprint: SHA256:tRrGdjYOwgHxpSc/wTOZQZEjxcb15P0tyXRsbAfd+2Q
2 changed files with 78 additions and 6 deletions

View file

@ -73,22 +73,72 @@ jobs:
useDaemon: false
- name: Build server
run: nix build .#nixosConfigurations.${{ matrix.server }}.config.system.build.toplevel --print-build-logs
deploy:
trigger-deploy:
needs: [build-check, build-server]
runs-on: ubuntu-latest
outputs:
previous-sha: ${{ steps.previous-sha.outputs.sha }}
permissions:
contents: write
steps:
- uses: actions/checkout@v5
- name: Get previous deploy SHA
id: previous-sha
run: |
sha=$(git ls-remote origin deploy | cut -f1)
printf "sha=%s" "$sha" >> "$GITHUB_OUTPUT"
- name: Push to deploy branch
run: git push --force origin HEAD:refs/heads/deploy
await-deploy:
name: ${{ matrix.server }}
needs: [parse-flake, trigger-deploy]
runs-on: ubuntu-latest
strategy:
fail-fast: false
matrix:
server: ${{ fromJson(needs.parse-flake.outputs.servers) }}
steps:
- name: Wait for deployment
timeout-minutes: 5
run: |
repo_url="https://github.com/${{ github.repository }}.git"
expected_sha="${{ github.sha }}"
branch="deployed/${{ matrix.server }}"
while true; do
deployed_sha=$(git ls-remote "$repo_url" "$branch" | cut -f1)
if [[ "$deployed_sha" == "$expected_sha" ]]; then
echo "✅ ${{ matrix.server }} deployed $expected_sha"
exit 0
else
echo "⏳ ${{ matrix.server }}: deployed ${deployed_sha::7}, waiting for ${expected_sha::7}..."
fi
sleep 5
done
rollback-deploy:
if: needs.await-deploy.result == 'failure'
needs: [trigger-deploy, await-deploy]
runs-on: ubuntu-latest
permissions:
contents: write
steps:
- uses: actions/checkout@v5
- name: Push to deploy branch
run: git push origin HEAD:deploy --force
with:
fetch-depth: 0
- name: Rollback deploy branch
run: |
previous_sha="${{ needs.trigger-deploy.outputs.previous-sha }}"
echo "Rolling back deploy branch to $previous_sha"
git push --force origin "$previous_sha:refs/heads/deploy"
notify:
if: always()
needs: [deploy]
needs: [await-deploy]
runs-on: ubuntu-latest
steps:
- name: Notify success
if: needs.deploy.result == 'success'
if: needs.await-deploy.result == 'success'
run: |
curl -s \
-H "Title: CI: Deploy succeeded" \
@ -99,7 +149,7 @@ jobs:
-d "Commit \`${GITHUB_SHA::7}\` deployed successfully." \
https://ntfy.sh/splitleaf
- name: Notify failure
if: needs.deploy.result == 'failure'
if: needs.await-deploy.result == 'failure'
run: |
curl -s \
-H "Title: CI: Deploy failed" \

View file

@ -1,11 +1,32 @@
{
config,
inputs,
pkgs,
lib,
...
}:
let
cfg = config.custom.services.comin;
postDeploymentScript =
pkgs.writeShellApplication {
name = "comin-post-deployment";
runtimeInputs = [ pkgs.git ];
text = ''
if [[ "$COMIN_STATUS" != "done" ]]; then
echo "Deployment not successful (status: $COMIN_STATUS), skipping branch update"
exit 0
fi
token=$(cat "''${CREDENTIALS_DIRECTORY}/git-push-token")
repo_url="https://x-access-token:$token@github.com/SebastianStork/nixos-config.git"
git push --force "$repo_url" "$COMIN_GIT_SHA:refs/heads/deployed/$COMIN_HOSTNAME"
echo "Updated deployed/$COMIN_HOSTNAME to $COMIN_GIT_SHA"
'';
}
|> lib.getExe;
in
{
imports = [ inputs.comin.nixosModules.comin ];
@ -35,6 +56,7 @@ in
listen_address = "127.0.0.1";
port = cfg.metricsPort;
};
postDeploymentCommand = postDeploymentScript;
};
};
}