infrastructure/workflows/npins-update.nix
catvayor c705ba8176
All checks were successful
Check meta / check_meta (pull_request) Successful in 24s
Build all the nodes / netcore01 (pull_request) Successful in 29s
Build all the nodes / netaccess01 (pull_request) Successful in 30s
Check meta / check_dns (pull_request) Successful in 36s
Build all the nodes / netcore02 (pull_request) Successful in 39s
Build all the nodes / ap01 (pull_request) Successful in 45s
Check workflows / check_workflows (pull_request) Successful in 56s
Run pre-commit on all files / pre-commit (pull_request) Successful in 32s
Build the shell / build-shell (pull_request) Successful in 50s
Build all the nodes / build01 (pull_request) Successful in 1m40s
Build all the nodes / hypervisor03 (pull_request) Successful in 1m46s
Build all the nodes / hypervisor01 (pull_request) Successful in 1m46s
Build all the nodes / bridge01 (pull_request) Successful in 1m50s
Build all the nodes / geo01 (pull_request) Successful in 1m55s
Build all the nodes / storage01 (pull_request) Successful in 1m54s
Build all the nodes / hypervisor02 (pull_request) Successful in 1m58s
Build all the nodes / geo02 (pull_request) Successful in 2m7s
Build all the nodes / rescue01 (pull_request) Successful in 2m6s
Build all the nodes / tower01 (pull_request) Successful in 1m57s
Build all the nodes / web02 (pull_request) Successful in 1m54s
Build all the nodes / web03 (pull_request) Successful in 1m55s
Build all the nodes / compute01 (pull_request) Successful in 2m27s
Build all the nodes / vault01 (pull_request) Successful in 2m22s
Build all the nodes / web01 (pull_request) Successful in 2m26s
Check workflows / check_workflows (push) Successful in 29s
Build all the nodes / netaccess01 (push) Successful in 30s
Build all the nodes / ap01 (push) Successful in 1m15s
Build all the nodes / netcore02 (push) Successful in 36s
Build all the nodes / netcore01 (push) Successful in 51s
Build the shell / build-shell (push) Successful in 34s
Build all the nodes / bridge01 (push) Successful in 1m55s
Build all the nodes / geo01 (push) Successful in 1m56s
Run pre-commit on all files / pre-commit (push) Successful in 49s
Build all the nodes / geo02 (push) Successful in 2m16s
Build all the nodes / hypervisor03 (push) Successful in 2m3s
Build all the nodes / build01 (push) Successful in 2m26s
Build all the nodes / hypervisor01 (push) Successful in 2m9s
Build all the nodes / compute01 (push) Successful in 2m33s
Build all the nodes / hypervisor02 (push) Successful in 2m19s
Build all the nodes / tower01 (push) Successful in 2m12s
Build all the nodes / rescue01 (push) Successful in 2m16s
Build all the nodes / vault01 (push) Successful in 2m7s
Build all the nodes / web03 (push) Successful in 2m4s
Build all the nodes / storage01 (push) Successful in 2m25s
Build all the nodes / web02 (push) Successful in 2m22s
Build all the nodes / web01 (push) Successful in 2m40s
fix(nix-actions): now steps are under lib
2025-03-09 21:39:35 +01:00

93 lines
2.7 KiB
Nix

# SPDX-FileCopyrightText: 2024 Tom Hubrecht <tom.hubrecht@dgnum.eu>
#
# SPDX-License-Identifier: EUPL-1.2
{ lib, nix-actions, ... }:
let
inherit (nix-actions.lib) secret;
inherit (lib) genAttrs mapAttrs' nameValuePair;
dependencies = builtins.attrNames (import ../npins);
in
{
name = "Update dependencies";
on.schedule = [
# Run every 24h
{ cron = "15 12 * * *"; }
];
# Global environment, necessary for rebases and commits
env = rec {
GIT_AUTHOR_NAME = "HT Chores";
GIT_AUTHOR_EMAIL = "chores@mail.hubrecht.ovh";
GIT_COMMITTER_NAME = GIT_AUTHOR_NAME;
GIT_COMMITTER_EMAIL = GIT_AUTHOR_EMAIL;
};
jobs = mapAttrs' (name: nameValuePair (builtins.replaceStrings [ "." ] [ "_" ] name)) (
genAttrs dependencies (name: {
runs-on = "nix";
steps = [
(nix-actions.lib.steps.checkout {
fetch-depth = 0;
token = secret "TEA_DGNUM_CHORES_TOKEN";
})
{
env.GIT_UPDATE_BRANCH = "npins-updates/${name}";
name = "Switch to a new branch";
run = # bash
''
if git ls-remote --exit-code --heads origin "refs/heads/$GIT_UPDATE_BRANCH"; then
git switch "$GIT_UPDATE_BRANCH"
git rebase main
echo "EXISTING_BRANCH=1" >> $GITHUB_ENV
else
git switch -C "$GIT_UPDATE_BRANCH"
fi
'';
}
{
env = {
GIT_UPDATE_BRANCH = "npins-updates/${name}";
COMMIT_MESSAGE = "chore(npins): Update ${name}";
};
name = "Open a PR if updates are present";
run = # bash
''
npins update ${name}
if [ ! -z "$(git diff --name-only)" ]; then
echo "[+] Changes detected, pushing updates."
git add npins
if [ -n "$EXISTING_BRANCH" ]; then
git commit --amend --no-edit
git push --force
else
git commit --message "$COMMIT_MESSAGE"
git push -u origin "$GIT_UPDATE_BRANCH"
fi
# Connect to the server with the cli
tea login add -n dgnum-chores -t "${secret "TEA_DGNUM_CHORES_TOKEN"}" -u https://git.dgnum.eu
# Create a pull request if needed
# i.e. no PR with the same title exists
if [ -z $(tea pr ls -f='title,author' -o simple | grep "$COMMIT_MESSAGE dgnum-chores") ]; then
tea pr create --description "Automatic npins update" --title "$COMMIT_MESSAGE" --head "$GIT_UPDATE_BRANCH"
fi
fi
'';
}
];
})
);
}