/ .github / workflows / guix-nix-policy.yml
guix-nix-policy.yml
 1  name: Guix/Nix Package Policy
 2  on: [push, pull_request]
 3  jobs:
 4    check:
 5      runs-on: ubuntu-latest
 6      steps:
 7        - uses: actions/checkout@v6
 8        - name: Enforce Guix primary / Nix fallback
 9          run: |
10            # Check for package manager files
11            HAS_GUIX=$(find . -name "*.scm" -o -name ".guix-channel" -o -name "guix.scm" 2>/dev/null | head -1)
12            HAS_NIX=$(find . -name "*.nix" 2>/dev/null | head -1)
13            
14            # Block new package-lock.json, yarn.lock, Gemfile.lock, etc.
15            NEW_LOCKS=$(git diff --name-only --diff-filter=A HEAD~1 2>/dev/null | grep -E 'package-lock\.json|yarn\.lock|Gemfile\.lock|Pipfile\.lock|poetry\.lock|cargo\.lock' || true)
16            if [ -n "$NEW_LOCKS" ]; then
17              echo "⚠️ Lock files detected. Prefer Guix manifests for reproducibility."
18            fi
19            
20            # Prefer Guix, fallback to Nix
21            if [ -n "$HAS_GUIX" ]; then
22              echo "✅ Guix package management detected (primary)"
23            elif [ -n "$HAS_NIX" ]; then
24              echo "✅ Nix package management detected (fallback)"
25            else
26              echo "ℹ️ Consider adding guix.scm or flake.nix for reproducible builds"
27            fi
28            
29            echo "✅ Package policy check passed"