|
38 | 38 | echo |
39 | 39 | sed -n '\#^<!-- /Retired keys -->$#,$p' README.md |
40 | 40 | } | diff README.md - |
| 41 | +
|
| 42 | + lint-pubring: |
| 43 | + if: github.event.pull_request.draft == false |
| 44 | + runs-on: ubuntu-latest |
| 45 | + steps: |
| 46 | + - uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 |
| 47 | + with: |
| 48 | + fetch-depth: 0 # We need 0 to validate the git commit signatures. |
| 49 | + persist-credentials: false |
| 50 | + - name: Export pubring content |
| 51 | + run: | |
| 52 | + for dir in gpg gpg-only-active-keys; do |
| 53 | + gpg --no-default-keyring --keyring "$dir/pubring.kbx" --list-keys --with-colons > "$dir/all-keys.list" |
| 54 | + gpg --no-default-keyring --keyring "$dir/pubring.kbx" --export --armor > "$dir/all-keys.asc" |
| 55 | + git add "$dir/all-keys.list" "$dir/all-keys.asc" |
| 56 | + done |
| 57 | + - name: Re-generate gpg folders |
| 58 | + run: | |
| 59 | + ./generate-gpg-dir.sh |
| 60 | + for dir in gpg gpg-only-active-keys; do |
| 61 | + gpg --no-default-keyring --keyring "$dir/pubring.kbx" --list-keys --with-colons > "$dir/all-keys.list" |
| 62 | + gpg --no-default-keyring --keyring "$dir/pubring.kbx" --export --armor > "$dir/all-keys.asc" |
| 63 | + done |
| 64 | + - run: git diff --exit-code -- gpg/all-keys.list gpg/all-keys.asc gpg-only-active-keys/all-keys.list gpg-only-active-keys/all-keys.asc |
| 65 | + |
| 66 | + - name: Verify if there are any keyring changes |
| 67 | + id: keyring-changes |
| 68 | + run: | |
| 69 | + git diff --exit-code --quiet ${{ github.event.before || 'HEAD^' }} -- gpg/ || echo "HAS_CHANGED=true" >> "$GITHUB_OUTPUT" |
| 70 | + git diff --exit-code --quiet ${{ github.event.before || 'HEAD^' }} -- gpg-only-active-keys/ || echo "HAS_ACTIVE_CHANGED=true" >> "$GITHUB_OUTPUT" |
| 71 | +
|
| 72 | + - name: Validate that all non-v0.x releases can be verified using the keyring |
| 73 | + if: steps.keyring-changes.outputs.HAS_CHANGED == 'true' |
| 74 | + run: | |
| 75 | + curl https://nodejs.org/dist/index.json \ |
| 76 | + | jq -r '.[].version | select(startswith("v0.") | not)' \ |
| 77 | + | while read -r VERSION; do |
| 78 | + echo "Checking $VERSION..." |
| 79 | + curl --silent "https://nodejs.org/dist/${VERSION}/SHASUMS256.txt.asc" \ |
| 80 | + | gpgv --keyring="gpg/pubring.kbx" |
| 81 | + done |
0 commit comments