From a19b160e1ef8b9a5247a83e2cd11ca3cf521ec8a Mon Sep 17 00:00:00 2001 From: Jun Kurihara Date: Wed, 11 Oct 2023 20:48:50 +0900 Subject: [PATCH] feat: automatic draft release --- .github/workflows/docker_build_push.yml | 2 + .github/workflows/release.yml | 72 ++++++++++++++++++++++--- CHANGELOG.md | 8 +++ rpxy-bin/Cargo.toml | 2 +- rpxy-lib/Cargo.toml | 2 +- 5 files changed, 78 insertions(+), 8 deletions(-) diff --git a/.github/workflows/docker_build_push.yml b/.github/workflows/docker_build_push.yml index c158cbe7..c3cba7b6 100644 --- a/.github/workflows/docker_build_push.yml +++ b/.github/workflows/docker_build_push.yml @@ -4,6 +4,8 @@ on: branches: - "develop" - "main" + tags: + - "*.*.*" pull_request: types: [synchronize, opened] diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index a6a252cd..7c43ce2f 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -33,23 +33,55 @@ jobs: platform: linux/arm64 tags-suffix: "-slim" - - target: "gnu-s2n" + - target: "gnu" + build-feature: "-s2n" platform: linux/amd64 tags-suffix: "-s2n" - - target: "gnu-s2n" + - target: "gnu" + build-feature: "-s2n" platform: linux/arm64 tags-suffix: "-s2n" + - target: "gnu" + build-feature: "-native-roots" + platform: linux/amd64 + tags-suffix: "-native-roots" + + - target: "gnu" + build-feature: "-native-roots" + platform: linux/arm64 + tags-suffix: "-native-roots" + + - target: "musl" + build-feature: "-native-roots" + platform: linux/amd64 + tags-suffix: "-slim-native-roots" + + - target: "musl" + build-feature: "-native-roots" + platform: linux/arm64 + tags-suffix: "-slim-native-roots" + + - target: "gnu" + build-feature: "-s2n-native-roots" + platform: linux/amd64 + tags-suffix: "-s2n-native-roots" + + - target: "gnu" + build-feature: "-s2n-native-roots" + platform: linux/arm64 + tags-suffix: "-s2n-native-roots" + steps: - run: "echo 'The relese triggering workflows passed'" - name: "set env" - #if [ ${{ github.ref_name == 'develop' }} ];then BUILD_NAME="-nightly";else BUILD_NAME="";fi + #if [ ${{ github.ref_name == 'develop' }} ];then BUILD_NAME="rpxy-nightly";else BUILD_NAME="rpxy";fi run: | if [ ${{ matrix.platform }} = "linux/amd64" ];then PLATFORM_MAP="x86_64";else PLATFORM_MAP="aarch64";fi echo "PLATFORM_MAP=${PLATFORM_MAP}" >> $GITHUB_ENV - echo "TARGET_NAME=rpxy-nightly-${PLATFORM_MAP}-unknown-linux-${{ matrix.target }}" >> $GITHUB_ENV + echo "TARGET_NAME=rpxy-${PLATFORM_MAP}-unknown-linux-${{ matrix.target }}${{ matrix.build-feature }}" >> $GITHUB_ENV - name: "docker pull and extract binary from docker image" id: "extract-binary" @@ -57,17 +89,45 @@ jobs: CONTAINER_ID=`docker create --platform=${{ matrix.platform }} ghcr.io/junkurihara/rust-rpxy:nightly${{ matrix.tags-suffix }}` docker cp ${CONTAINER_ID}:/rpxy/bin/rpxy /tmp/${TARGET_NAME} cd /tmp - tar zcvf ${TARGET_NAME}.tar.gz ${TARGET_NAME} echo "artifact=${TARGET_NAME}" >> $GITHUB_OUTPUT - name: "upload artifacts" uses: actions/upload-artifact@v3 with: name: ${{ steps.extract-binary.outputs.artifact }} - path: "/tmp/${{ steps.extract-binary.outputs.artifact }}.tar.gz" + path: "/tmp/${{ steps.extract-binary.outputs.artifact }}" # on-failure: # runs-on: ubuntu-latest # if: ${{ github.event.workflow_run.conclusion == 'failure' }} # steps: # - run: echo 'The release triggering workflows failed' + + release: + runs-on: ubuntu-latest + needs: on-success + steps: + - name: checkout + uses: actions/checkout@v4 + + - name: download artifacts + uses: actions/download-artifact@v3 + with: + path: /tmp/rpxy + + - name: unzip all and make tar.gz + run: | + cd /tmp/rpxy + for i in `ls *.zip`;do unzip $i;done + for i in `ls rpxy-*`;do tar cvfz $i.tar.gz $i;done + ls -lha + + # - name: release + # uses: softprops/action-gh-release@v1 + # if: startsWith(github.ref, 'refs/tags/') + # with: + # files: /tmp/rpxy/*.tar.gz + # tag_name: ${{ github.ref }} + # draft: true + # prerelease: false + # generate_release_notes: true diff --git a/CHANGELOG.md b/CHANGELOG.md index a7c171f0..20ac6790 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,6 +2,14 @@ ## 0.7.0 (unreleased) +## 0.6.2 + +### Improvement + +- Feat: Add a build feature of `native-roots` to use the system's default root cert store. +- Feat: Add binary release in addition to container release +- Refactor: lots of minor improvements + ## 0.6.1 ### Bugfix diff --git a/rpxy-bin/Cargo.toml b/rpxy-bin/Cargo.toml index 98ff827c..fbe14dc2 100644 --- a/rpxy-bin/Cargo.toml +++ b/rpxy-bin/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "rpxy" -version = "0.6.1" +version = "0.6.2" authors = ["Jun Kurihara"] homepage = "https://github.com/junkurihara/rust-rpxy" repository = "https://github.com/junkurihara/rust-rpxy" diff --git a/rpxy-lib/Cargo.toml b/rpxy-lib/Cargo.toml index 0b0d3ee9..c7cce09b 100644 --- a/rpxy-lib/Cargo.toml +++ b/rpxy-lib/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "rpxy-lib" -version = "0.6.1" +version = "0.6.2" authors = ["Jun Kurihara"] homepage = "https://github.com/junkurihara/rust-rpxy" repository = "https://github.com/junkurihara/rust-rpxy"