diff options
| author | Fernando Serboncini <fserb@tailscale.com> | 2026-04-20 16:42:34 -0400 |
|---|---|---|
| committer | Fernando Serboncini <fserb@tailscale.com> | 2026-04-20 16:45:37 -0400 |
| commit | 97c6e9a2702152a6a5ce6ae65c12078ad5ebfb32 (patch) | |
| tree | 93f84c56fd6f8586f9fc428d7e652c09bb6fa07c | |
| parent | 514d7d28e799a4ef5d829c4d966c8fff6c3e7cdb (diff) | |
| download | tailscale-fserb/signed-off-check.tar.xz tailscale-fserb/signed-off-check.zip | |
.github/workflows: require Signed-off-by trailer on commit messagesfserb/signed-off-check
Add a workflow that checks each commit in a PR contains a Signed-off-by
trailer, as required by the DCO.
Updates tailscale/corp#40584
Change-Id: I2f6ca287c06ac4b53742b4eb15138b140e7052cd
Signed-off-by: Fernando Serboncini <fserb@tailscale.com>
| -rw-r--r-- | .github/workflows/signed-off-by.yml | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/.github/workflows/signed-off-by.yml b/.github/workflows/signed-off-by.yml new file mode 100644 index 000000000..11faf2934 --- /dev/null +++ b/.github/workflows/signed-off-by.yml @@ -0,0 +1,37 @@ +# Require that each commit contain a Signed-off-by trailer, as required by +# the Developer Certificate of Origin (DCO, https://developercertificate.org/). +# By adding the trailer, the committer certifies that they have the right to +# submit the contribution under the project's open source license. +# Contributors can add the trailer with `git commit -s`. +name: Signed-off-by + +permissions: read-all + +on: + pull_request: + +concurrency: + group: ${{ github.workflow }}-$${{ github.head_ref || github.run_id }} + cancel-in-progress: true + +jobs: + check-signed-off-by: + runs-on: ubuntu-latest + if: github.actor != 'dependabot[bot]' + steps: + - uses: octokit/request-action@dad4362715b7fb2ddedf9772c8670824af564f0d # v2.4.0 + id: get_pr_commits + with: + route: GET /repos/tailscale/tailscale/pulls/${{ github.event.number }}/commits + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + - name: check commit messages + run: | + jq ' + .[] | + (.commit.message | test("\nSigned-off-by: .+ <.+@.+>(\n|$)"; "m")) + // error("Commit \(.sha) is missing Signed-off-by (and maybe others) + Use `git commit -s` (or `git rebase -i` with `--signoff`) to add the trailer.") + ' >/dev/null << 'END_GITHUB_API_JSON' + ${{ steps.get_pr_commits.outputs.data }} + END_GITHUB_API_JSON |
