Torrentio: Fixed ep list. #27
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: CI | |
on: | |
push: | |
branches: | |
- master | |
paths: | |
- '**' | |
- '!**.md' | |
- '!.github/**' | |
- '.github/scripts/**' | |
- '.github/workflows/build_push.yml' | |
concurrency: | |
group: ${{ github.workflow }} | |
cancel-in-progress: true | |
env: | |
CI_CHUNK_SIZE: 65 | |
jobs: | |
prepare: | |
name: Prepare job | |
runs-on: ubuntu-latest | |
outputs: | |
individualMatrix: ${{ steps.generate-matrices.outputs.individualMatrix }} | |
steps: | |
- name: Clone repo | |
uses: actions/checkout@v4 | |
with: | |
ref: master | |
token: ${{ secrets.ANIYOMIORG_BOT_PAT }} | |
- name: Find lib changes | |
id: modified-libs | |
uses: tj-actions/changed-files@v42 | |
with: | |
files: lib/ | |
files_ignore: lib/**.md | |
files_separator: " " | |
safe_output: false | |
- name: Import GPG key | |
uses: crazy-max/[email protected] | |
with: | |
gpg_private_key: ${{ secrets.GPG_PRIVATE_KEY }} | |
passphrase: ${{ secrets.GPG_PASSPHRASE }} | |
git_user_signingkey: true | |
git_commit_gpgsign: true | |
- name: Bump extensions that uses a modified lib | |
if: steps.modified-libs.outputs.any_changed == 'true' | |
run: | | |
./.github/scripts/bump-versions.py ${{ steps.modified-libs.outputs.all_changed_files }} | |
- name: Validate Gradle Wrapper | |
uses: gradle/wrapper-validation-action@v2 | |
- name: Get number of modules | |
run: | | |
set -x | |
projects=(src/*/*) | |
echo "NUM_INDIVIDUAL_MODULES=${#projects[@]}" >> $GITHUB_ENV | |
- id: generate-matrices | |
name: Create output matrices | |
uses: actions/github-script@v7 | |
with: | |
script: | | |
const numIndividualModules = process.env.NUM_INDIVIDUAL_MODULES; | |
const chunkSize = process.env.CI_CHUNK_SIZE; | |
const numIndividualChunks = Math.ceil(numIndividualModules / chunkSize); | |
console.log(`Individual modules: ${numIndividualModules} (${numIndividualChunks} chunks of ${chunkSize})`); | |
core.setOutput('individualMatrix', { 'chunk': [...Array(numIndividualChunks).keys()] }); | |
build_individual: | |
name: Build individual modules | |
needs: prepare | |
runs-on: ubuntu-latest | |
strategy: | |
matrix: ${{ fromJSON(needs.prepare.outputs.individualMatrix) }} | |
steps: | |
- name: Checkout master branch | |
uses: actions/checkout@v4 | |
with: | |
ref: master | |
- name: Set up JDK | |
uses: actions/setup-java@v4 | |
with: | |
java-version: 17 | |
distribution: temurin | |
- name: Prepare signing key | |
run: | | |
echo ${{ secrets.SIGNING_KEY }} | base64 -d > signingkey.jks | |
- name: Set up Gradle | |
uses: gradle/actions/setup-gradle@v3 | |
- name: Build extensions (chunk ${{ matrix.chunk }}) | |
env: | |
CI_CHUNK_NUM: ${{ matrix.chunk }} | |
ALIAS: ${{ secrets.ALIAS }} | |
KEY_STORE_PASSWORD: ${{ secrets.KEY_STORE_PASSWORD }} | |
KEY_PASSWORD: ${{ secrets.KEY_PASSWORD }} | |
run: chmod +x ./gradlew && ./gradlew -p src assembleRelease | |
- name: Upload APKs (chunk ${{ matrix.chunk }}) | |
uses: actions/upload-artifact@v4 | |
if: "github.repository == 'ni3x/aniyomi-extensions'" | |
with: | |
name: "individual-apks-${{ matrix.chunk }}" | |
path: "**/*.apk" | |
retention-days: 1 | |
- name: Clean up CI files | |
run: rm signingkey.jks | |
publish_repo: | |
name: Publish repo | |
needs: | |
- build_individual | |
if: "github.repository == 'ni3x/aniyomi-extensions'" | |
runs-on: ubuntu-latest | |
steps: | |
- name: Download APK artifacts | |
uses: actions/download-artifact@v4 | |
with: | |
path: ~/apk-artifacts | |
- name: Set up JDK | |
uses: actions/setup-java@v4 | |
with: | |
java-version: 17 | |
distribution: temurin | |
- name: Checkout master branch | |
uses: actions/checkout@v4 | |
with: | |
ref: master | |
path: master | |
- name: Create repo artifacts | |
run: | | |
cd master | |
python ./.github/scripts/move-apks.py | |
INSPECTOR_LINK="$(curl -s "https://api.github.com/repos/aniyomiorg/aniyomi-extensions-inspector/releases/latest" | jq -r '.assets[0].browser_download_url')" | |
curl -L "$INSPECTOR_LINK" -o ./Inspector.jar | |
java -jar ./Inspector.jar "repo/apk" "output.json" "tmp" | |
python ./.github/scripts/create-repo.py | |
- name: Checkout repo branch | |
uses: actions/checkout@v4 | |
with: | |
repository: ni3x/aniyomi-extensions | |
token: ${{ secrets.ANIYOMIORG_BOT_PAT }} | |
ref: repo | |
path: repo | |
- name: Import GPG key | |
uses: crazy-max/[email protected] | |
with: | |
gpg_private_key: ${{ secrets.GPG_PRIVATE_KEY }} | |
passphrase: ${{ secrets.GPG_PASSPHRASE }} | |
git_user_signingkey: true | |
git_commit_gpgsign: true | |
workdir: repo | |
- name: Grant execute permission for commit-repo.sh | |
run: chmod +x master/.github/scripts/commit-repo.sh | |
- name: Deploy repo | |
run: | | |
cd repo | |
../master/.github/scripts/commit-repo.sh |