mirror of
https://github.com/cmclark00/TetriStats.git
synced 2025-05-18 15:15:21 +01:00
Add APK signing configuration for valid package installation
Some checks failed
Build and Release Android APK / build (push) Has been cancelled
Some checks failed
Build and Release Android APK / build (push) Has been cancelled
This commit is contained in:
parent
5af491a65c
commit
dcd389c3f2
2 changed files with 33 additions and 3 deletions
21
.github/workflows/build.yml
vendored
21
.github/workflows/build.yml
vendored
|
@ -36,6 +36,23 @@ jobs:
|
||||||
echo "VERSION_NAME=$VERSION_NAME" >> $GITHUB_ENV
|
echo "VERSION_NAME=$VERSION_NAME" >> $GITHUB_ENV
|
||||||
echo "APP_VERSION=$VERSION_NAME" >> $GITHUB_OUTPUT
|
echo "APP_VERSION=$VERSION_NAME" >> $GITHUB_OUTPUT
|
||||||
|
|
||||||
|
# Setup keystore directory
|
||||||
|
- name: Setup keystore directory
|
||||||
|
run: mkdir -p app/keystore
|
||||||
|
|
||||||
|
# Generate a keystore for signing
|
||||||
|
- name: Generate keystore
|
||||||
|
run: |
|
||||||
|
keytool -genkey -v -keystore app/keystore/release.keystore -storepass android -alias release -keypass android -keyalg RSA -keysize 2048 -validity 10000 -dname "CN=TetriStats,O=Accidental Productions,L=Unknown,C=US"
|
||||||
|
|
||||||
|
# Set environment variables for signing
|
||||||
|
- name: Set signing environment variables
|
||||||
|
run: |
|
||||||
|
echo "KEYSTORE_PASSWORD=android" >> $GITHUB_ENV
|
||||||
|
echo "KEY_ALIAS=release" >> $GITHUB_ENV
|
||||||
|
echo "KEY_PASSWORD=android" >> $GITHUB_ENV
|
||||||
|
|
||||||
|
# Build a signed release APK
|
||||||
- name: Build Release APK
|
- name: Build Release APK
|
||||||
run: ./gradlew assembleRelease
|
run: ./gradlew assembleRelease
|
||||||
|
|
||||||
|
@ -46,13 +63,13 @@ jobs:
|
||||||
if: startsWith(github.ref, 'refs/tags/')
|
if: startsWith(github.ref, 'refs/tags/')
|
||||||
run: |
|
run: |
|
||||||
mkdir -p renamed_apk
|
mkdir -p renamed_apk
|
||||||
cp app/build/outputs/apk/release/app-universal-release-unsigned.apk renamed_apk/TetriStats-${{ env.VERSION_NAME }}.apk
|
cp app/build/outputs/apk/release/app-universal-release.apk renamed_apk/TetriStats-${{ env.VERSION_NAME }}.apk
|
||||||
|
|
||||||
- name: Rename APK for push release
|
- name: Rename APK for push release
|
||||||
if: ${{ !startsWith(github.ref, 'refs/tags/') && github.event_name == 'push' }}
|
if: ${{ !startsWith(github.ref, 'refs/tags/') && github.event_name == 'push' }}
|
||||||
run: |
|
run: |
|
||||||
mkdir -p renamed_apk
|
mkdir -p renamed_apk
|
||||||
cp app/build/outputs/apk/release/app-universal-release-unsigned.apk renamed_apk/TetriStats-${{ env.VERSION_NAME }}-${{ github.run_number }}.apk
|
cp app/build/outputs/apk/release/app-universal-release.apk renamed_apk/TetriStats-${{ env.VERSION_NAME }}-${{ github.run_number }}.apk
|
||||||
|
|
||||||
- name: Upload APK as artifact for tag release
|
- name: Upload APK as artifact for tag release
|
||||||
if: startsWith(github.ref, 'refs/tags/')
|
if: startsWith(github.ref, 'refs/tags/')
|
||||||
|
|
|
@ -27,6 +27,16 @@ android {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
signingConfigs {
|
||||||
|
create("release") {
|
||||||
|
// These values will be replaced during the GitHub Actions build
|
||||||
|
storeFile = file("keystore/release.keystore")
|
||||||
|
storePassword = System.getenv("KEYSTORE_PASSWORD") ?: "android"
|
||||||
|
keyAlias = System.getenv("KEY_ALIAS") ?: "release"
|
||||||
|
keyPassword = System.getenv("KEY_PASSWORD") ?: "android"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
buildTypes {
|
buildTypes {
|
||||||
release {
|
release {
|
||||||
isMinifyEnabled = false
|
isMinifyEnabled = false
|
||||||
|
@ -34,7 +44,10 @@ android {
|
||||||
getDefaultProguardFile("proguard-android-optimize.txt"),
|
getDefaultProguardFile("proguard-android-optimize.txt"),
|
||||||
"proguard-rules.pro"
|
"proguard-rules.pro"
|
||||||
)
|
)
|
||||||
// Make release version debuggable for now (helps with troubleshooting)
|
isDebuggable = false
|
||||||
|
signingConfig = signingConfigs.getByName("release")
|
||||||
|
}
|
||||||
|
debug {
|
||||||
isDebuggable = true
|
isDebuggable = true
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue