| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879 |
- name: Update Nix Hashes
- permissions:
- contents: write
- on:
- workflow_dispatch:
- push:
- paths:
- - "bun.lock"
- - "package.json"
- - "packages/*/package.json"
- pull_request:
- paths:
- - "bun.lock"
- - "package.json"
- - "packages/*/package.json"
- jobs:
- update:
- runs-on: ubuntu-latest
- env:
- SYSTEM: x86_64-linux
- steps:
- - name: Checkout repository
- uses: actions/checkout@v4
- with:
- token: ${{ secrets.GITHUB_TOKEN }}
- fetch-depth: 0
- - name: Setup Nix
- uses: DeterminateSystems/nix-installer-action@v20
- - name: Configure git
- run: |
- git config --global user.email "[email protected]"
- git config --global user.name "Github Action"
- - name: Update node_modules hash
- run: |
- set -euo pipefail
- nix/scripts/update-hashes.sh
- - name: Commit hash changes
- env:
- TARGET_BRANCH: ${{ github.head_ref || github.ref_name }}
- run: |
- set -euo pipefail
- summarize() {
- local status="$1"
- {
- echo "### Nix Hash Update"
- echo ""
- echo "- ref: ${GITHUB_REF_NAME}"
- echo "- status: ${status}"
- } >> "$GITHUB_STEP_SUMMARY"
- if [ -n "${GITHUB_SERVER_URL:-}" ] && [ -n "${GITHUB_REPOSITORY:-}" ] && [ -n "${GITHUB_RUN_ID:-}" ]; then
- echo "- run: ${GITHUB_SERVER_URL}/${GITHUB_REPOSITORY}/actions/runs/${GITHUB_RUN_ID}" >> "$GITHUB_STEP_SUMMARY"
- fi
- echo "" >> "$GITHUB_STEP_SUMMARY"
- }
- FILES=(flake.nix nix/node-modules.nix nix/hashes.json)
- STATUS="$(git status --short -- "${FILES[@]}" || true)"
- if [ -z "$STATUS" ]; then
- summarize "no changes"
- echo "No changes to tracked Nix files. Hashes are already up to date."
- exit 0
- fi
- git add "${FILES[@]}"
- git commit -m "Update Nix hashes"
- BRANCH="${TARGET_BRANCH:-${GITHUB_REF_NAME}}"
- git push origin HEAD:"$BRANCH"
- summarize "committed $(git rev-parse --short HEAD)"
|