name: Release Build on: # push: # branches: # - master # paths: # - 'CHANGELOG.md' workflow_dispatch: jobs: prepare: runs-on: ubuntu-latest if: github.event_name != 'pull_request' && github.ref == 'refs/heads/master' outputs: version: ${{ steps.set-ver.outputs.version }} play: ${{ steps.check.outputs.play }} sign: ${{ steps.check.outputs.sign }} steps: - id: set-ver run: | echo "version=$(date -d "8 hour" -u +3.%y.%m%d%H)" >> $GITHUB_OUTPUT - id: check run: | if [ ! -z "${{ secrets.RELEASE_KEY_STORE }}" ]; then echo "sign=yes" >> $GITHUB_OUTPUT fi if [ ! -z "${{ secrets.SERVICE_ACCOUNT_JSON }}" ]; then echo "play=yes" >> $GITHUB_OUTPUT fi build: needs: prepare if: ${{ needs.prepare.outputs.sign }} strategy: matrix: product: [ app, google ] fail-fast: false runs-on: ubuntu-latest env: product: ${{ matrix.product }} VERSION: ${{ needs.prepare.outputs.version }} play: ${{ needs.prepare.outputs.play }} steps: - uses: actions/checkout@v3 with: fetch-depth: 1 - name: Release Apk Sign run: | # not use this output # echo "KeyStore=yes" >> $GITHUB_OUTPUT echo RELEASE_KEY_ALIAS='${{ secrets.RELEASE_KEY_ALIAS }}' >> gradle.properties echo RELEASE_KEY_PASSWORD='${{ secrets.RELEASE_KEY_PASSWORD }}' >> gradle.properties echo RELEASE_STORE_PASSWORD='${{ secrets.RELEASE_STORE_PASSWORD }}' >> gradle.properties echo RELEASE_STORE_FILE='./key.jks' >> gradle.properties echo ${{ secrets.RELEASE_KEY_STORE }} | base64 --decode > $GITHUB_WORKSPACE/app/key.jks - name: Unify Version Name run: | echo "统一版本号" sed "/def version/c def version = \"${{ env.VERSION }}\"" $GITHUB_WORKSPACE/app/build.gradle -i - name: Set up Gradle uses: gradle/gradle-build-action@v2 - name: Build With Gradle run: | echo "开始进行${{ env.product }}构建" chmod +x gradlew ./gradlew assemble${{ env.product }}release --build-cache --parallel --daemon --warning-mode all - name: Organize the Files run: | mkdir -p ${{ github.workspace }}/apk/ cp -rf ${{ github.workspace }}/app/build/outputs/apk/*/*/*.apk ${{ github.workspace }}/apk/ - name: Upload App To Artifact uses: actions/upload-artifact@v3 with: name: legado_${{ env.product }} path: ${{ github.workspace }}/apk/*.apk - name: Release if: ${{ env.product == 'app' }} uses: softprops/action-gh-release@de2c0eb89ae2a093876385947365aca7b0e5f844 with: name: legado_app_${{ env.VERSION }} tag_name: ${{ env.VERSION }} body_path: ${{ github.workspace }}/CHANGELOG.md draft: false prerelease: false files: ${{ github.workspace }}/apk/legado_app_*.apk env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - name: Prepare For GooglePlay if: env.product == 'google' && env.play == 'yes' run: | mkdir -p ReleaseNotes ln -s ${{ github.workspace }}/CHANGELOG.md ReleaseNotes/whatsnew-en-US ln -s ${{ github.workspace }}/CHANGELOG.md ReleaseNotes/whatsnew-zh-CN - name: Release To GooglePlay if: env.product == 'google' && env.play == 'yes' uses: r0adkll/upload-google-play@v1 with: serviceAccountJsonPlainText: ${{ secrets.SERVICE_ACCOUNT_JSON }} packageName: io.legado.play releaseFiles: ${{ github.workspace }}/apk/legado_google_*.apk track: production whatsNewDirectory: ${{ github.workspace }}/ReleaseNotes - name: Push Assets To "release" Branch if: ${{ github.actor == 'gedoor' }} run: | cd $GITHUB_WORKSPACE/apk/ git init git checkout -b release git config --global user.name "github-actions[bot]" git config --global user.email "41898282+github-actions[bot]@users.noreply.github.com" git remote add origin "https://${{ github.actor }}:${{ secrets.ACTIONS_TOKEN }}@github.com/${{ github.actor }}/release" git add *.apk git commit -m "${{ env.VERSION }}" git push -f -u origin release - name: Purge Jsdelivr Cache if: ${{ github.actor == 'gedoor' }} run: | result=$(curl -s https://purge.jsdelivr.net/gh/${{ github.actor }}/release@release/) if echo $result |grep -q 'success.*true'; then echo "jsdelivr缓存更新成功" else echo $result fi