Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/gogoadl/github-action-release-apk
Github action to publish signed android APK file and make github releases automatically
https://github.com/gogoadl/github-action-release-apk
android android-ci github-actions
Last synced: about 1 month ago
JSON representation
Github action to publish signed android APK file and make github releases automatically
- Host: GitHub
- URL: https://github.com/gogoadl/github-action-release-apk
- Owner: gogoadl
- Created: 2023-06-27T12:19:04.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2023-07-06T09:14:09.000Z (over 1 year ago)
- Last Synced: 2024-10-13T02:40:59.099Z (3 months ago)
- Topics: android, android-ci, github-actions
- Homepage:
- Size: 25.4 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# github-action-release-apk
Composite action to publish signed android APK file and make github releases automatically
## ⌨️ Usage
Follow the code below to use this workflow
this workflow does the following.
+ Always debug build, upload artifact when push or pull-request on main branch.
+ Perform a release build, upload artifact and upload signed release apk on tags created in ``'v*.*.*'`` format
+ This workflow was used for projects
[compose-cocktail-recipes](https://github.com/gogoadl/compose-cocktail-recipes)## 🎹 Inputs
``asset-name`` : asset name
``github-token`` : for using create github Releases and upload assets
``base64-keystore`` : to signing apk on github action, you should make your base64 encoded keystore file
``key-file`` : it is name that the keystore file
``keystore-password`` : keystore password
``keystore-alias`` : keystore alias
``key-password`` : key password
## 🎸 How to make encoded keyStore
first,
generate keystore on your android app``Android Studio > Build > Generate Signed Bundle or APK > APK > Create New or Choose Existing``
second,
base64 make encoded text file that your keystore file``openssl base64 -in [keystore file] -out [text file name]``
last,
make your encoded text to github secrets!move to `` repository Settings > Security > Secrets and variables > Actions > New Repository Secrets ``
copy your encoded text and paste to secrets body!
## 🎮 Example
```
name: Android CIon:
push:
branches:
- main
tags:
- 'v*.*.*'
pull_request:
branches:
- mainjobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3- name: set up JDK 11
uses: actions/setup-java@v3
with:
java-version: '11'
distribution: 'temurin'
cache: gradle- name: Grant execute permission for gradlew
run: chmod +x gradlew- name: Set output
id: vars
run: echo "tag=${GITHUB_REF#refs/*/}" >> $GITHUB_OUTPUT
- name: Check output
env:
RELEASE_VERSION: ${{ steps.vars.outputs.tag }}
run: |
echo $RELEASE_VERSION
echo ${{ steps.vars.outputs.tag }}- name: Bump version
uses: chkfung/[email protected]
with:
gradlePath: app/build.gradle # or app/build.gradle.kts
versionCode: ${{github.run_number}}
versionName: ${{env.RELEASE_VERSION}}- name: Build Debug APK
run: ./gradlew assembleDebug- name: Upload artifact Debug APK
uses: actions/upload-artifact@v3
with:
name: apk
path: app/build/outputs/apk/debug/*.apkrelease:
permissions:
contents: write
needs: build
if: startsWith(github.ref, 'refs/tags/v')
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3 # Necessary to access local action
- name: github-action-release-apk
uses: gogoadl/[email protected]
with:
asset-name: 'Cocktails.apk'
github-token: ${{ secrets.GITHUB_TOKEN }}
base64-keystore: ${{ secrets.APP_KEYSTORE_BASE64 }}
key-file: ${{ secrets.APP_KEY_FILE }}
keystore-password: ${{ secrets.APP_KEYSTORE_PASSWORD }}
keystore-alias: ${{ secrets.APP_KEYSTORE_ALIAS }}
key-password: ${{ secrets.APP_KEY_PASSWORD }}
```