name: Create Release & Upload Assets on: push: # Sequence of patterns matched against refs/tags tags: - 'v*' # Push events to matching v*, i.e. v1.0, v20.15.10 jobs: ci: uses: smallstep/certificates/.github/workflows/ci.yml@master secrets: inherit create_release: name: Create Release needs: ci runs-on: ubuntu-latest outputs: is_prerelease: ${{ steps.is_prerelease.outputs.IS_PRERELEASE }} steps: - name: Is Pre-release id: is_prerelease run: | set +e echo ${{ github.ref }} | grep "\-rc.*" OUT=$? if [ $OUT -eq 0 ]; then IS_PRERELEASE=true; else IS_PRERELEASE=false; fi echo "IS_PRERELEASE=${IS_PRERELEASE}" >> ${GITHUB_OUTPUT} - name: Create Release id: create_release uses: actions/create-release@v1 env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} with: tag_name: ${{ github.ref }} release_name: Release ${{ github.ref }} draft: false prerelease: ${{ steps.is_prerelease.outputs.IS_PRERELEASE }} goreleaser: name: Upload Assets To Github w/ goreleaser runs-on: ubuntu-latest needs: create_release permissions: id-token: write contents: write steps: - name: Checkout uses: actions/checkout@v3 - name: Set up Go uses: actions/setup-go@v3 with: go-version: 1.19 check-latest: true - name: Install cosign uses: sigstore/cosign-installer@v2 with: cosign-release: 'v1.13.1' - name: Get Release Date id: release_date run: | RELEASE_DATE=$(date +"%y-%m-%d") echo "RELEASE_DATE=${RELEASE_DATE}" >> ${GITHUB_ENV} - name: Run GoReleaser uses: goreleaser/goreleaser-action@v3 with: version: 'latest' args: release --rm-dist env: GITHUB_TOKEN: ${{ secrets.GORELEASER_PAT }} RELEASE_DATE: ${RELEASE_DATE} COSIGN_EXPERIMENTAL: 1 build_upload_docker: name: Build & Upload Docker Images runs-on: ubuntu-latest needs: ci permissions: id-token: write contents: write steps: - name: Checkout uses: actions/checkout@v3 - name: Setup Go uses: actions/setup-go@v3 with: go-version: '1.19' check-latest: true - name: Install cosign uses: sigstore/cosign-installer@v2 with: cosign-release: 'v1.13.1' - name: Build id: build run: | PATH=$PATH:/usr/local/go/bin:/home/admin/go/bin make docker-artifacts env: DOCKER_USERNAME: ${{ secrets.DOCKER_USERNAME }} DOCKER_PASSWORD: ${{ secrets.DOCKER_PASSWORD }} - name: Cosign id: cosign run: | DIGEST=$(docker images --digests --format "{{.Digest}}" smallstep/step-ca | head -n 1 | tr -d '[:space:]') cosign sign -r smallstep/step-ca@${DIGEST} env: COSIGN_EXPERIMENTAL: 1