name: release
on:
push:
tags: ['v*']
jobs:
publish:
name: Publish to crates.io
runs-on: ubuntu-latest
environment: crates-io
permissions:
id-token: write
steps:
- uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd
- uses: dtolnay/rust-toolchain@stable
- uses: Swatinem/rust-cache@c19371144df3bb44fab255c43d04cbc2ab54d1c4
- name: Verify Cargo.toml version matches tag
run: |
tag="${GITHUB_REF_NAME#v}"
cargover=$(cargo metadata --format-version=1 --no-deps | jq -r '.packages[0].version')
if [ "$tag" != "$cargover" ]; then
echo "::error::tag $GITHUB_REF_NAME (parsed as $tag) does not match Cargo.toml version $cargover"
exit 1
fi
- name: Authenticate to crates.io via OIDC
id: auth
uses: rust-lang/crates-io-auth-action@bbd81622f20ce9e2dd9622e3218b975523e45bbe
- name: Dry-run publish
run: cargo publish --dry-run --locked
env:
CARGO_REGISTRY_TOKEN: ${{ steps.auth.outputs.token }}
- name: Publish to crates.io
run: cargo publish --locked
env:
CARGO_REGISTRY_TOKEN: ${{ steps.auth.outputs.token }}