Replace Containerfile with Forgejo Actions
Some checks failed
Update flake.lock / update (push) Failing after 1s

This commit is contained in:
Casper V. Kristensen 2024-03-29 22:55:01 +01:00
parent b829d0ebea
commit a9cca038a9
2 changed files with 39 additions and 22 deletions

View file

@ -0,0 +1,39 @@
name: Update flake.lock
on:
push: # TODO
# https://forgejo.org/docs/latest/user/actions/#onschedule
schedule:
- cron: "23 17 * * 1"
jobs:
update:
runs-on: docker
container:
image: docker.io/nixos/nix:2.21.0
steps:
- name: Configure SSH
run: |
mkdir ~/.ssh/
echo "git.caspervk.net ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIAvPxSg6XN6znT1T4H0U1lzJBsGY7Uann+TBisWD3Drd" > ~/.ssh/known_hosts
echo "${{ secrets.SNOWFLAKE_SSH_PRIVATE_KEY }}" > ~/.ssh/id_ed25519
chmod 0600 ~/.ssh/id_ed25519
- name: Configure Git
run: |
git config user.email "snowflake@caspervk.net"
git config user.name "snowflake"
- name: Checkout repository
run: |
git clone git@git.caspervk.net:caspervk/nixos.git
cd nixos/
- name: Update flake.lock
run: |
nix --extra-experimental-features nix-command --extra-experimental-features flakes flake update --commit-lock-file
- name: Push
run: |
git push

View file

@ -1,22 +0,0 @@
# Automatic NixOS upgrades (modules/server/system.nix) requires updating
# flake.lock in the repository periodically. This repository is hosted on
# Gitea, which doesn't have good support for CI. Instead, this Containerfile
# is run on a server. This requires a Gitea access token[1] with repository
# read/write permissions. Note that we must use an account-wide access token to
# be able to clone through HTTPS (and utilise certificates rather than blindly
# trusting SSH keys), as repository deploy keys can only be used through
# SSH. The token should be passed as the GIT_PASSWORD environment variable.
# [1] https://git.caspervk.net/user/settings/applications
FROM nixos/nix:latest
CMD git clone https://caspervk:$GIT_PASSWORD@git.caspervk.net/caspervk/nixos.git && \
cd nixos/ && \
git config user.email "snowflake@caspervk.net" && \
git config user.name "snowflake" && \
# store in /dev/shm tmpfs to avoid an ever-growing nix store in the container
nix --extra-experimental-features nix-command --extra-experimental-features flakes flake update --commit-lock-file --store /dev/shm && \
git push && \
cd .. && \
rm -rf nixos/ && \
sleep 7d # Run again in a week. Requires `restart: unless-stopped`