mirror of
https://git.selfprivacy.org/kherel/selfprivacy.org.app.git
synced 2025-01-24 09:46:42 +00:00
add fdroid nightlies
This commit is contained in:
parent
3c37985db8
commit
2eab9a969d
17
.drone.yml
17
.drone.yml
|
@ -15,14 +15,25 @@ steps:
|
||||||
SONARQUBE_TOKEN:
|
SONARQUBE_TOKEN:
|
||||||
from_secret: SONARQUBE_TOKEN
|
from_secret: SONARQUBE_TOKEN
|
||||||
|
|
||||||
- name: Build Linux Target
|
- name: Build Nightly Linux Release Artifact (Binary)
|
||||||
commands:
|
commands:
|
||||||
- ./ci.py --ci-build-linux
|
- ./ci.py --ci-build-linux
|
||||||
|
|
||||||
- name: Build APK Target
|
- name: Build Nightly Release Artifact (.APK)
|
||||||
commands:
|
commands:
|
||||||
- ./ci.py --ci-build-apk
|
- ./ci.py --ci-build-apk
|
||||||
|
|
||||||
|
- name: Sign and Deploy Nightly Android Release Artifact (.APK) for F-Droid Repository
|
||||||
|
commands:
|
||||||
|
- ./ci.py --sign-apk-fdroid-nightly
|
||||||
|
environment:
|
||||||
|
STANDALONE_KEYSTORE_PASS:
|
||||||
|
from_secret: STANDALONE_KEYSTORE_PASS
|
||||||
|
FDROID_KEYSTORE_PASS:
|
||||||
|
from_secret: FDROID_KEYSTORE_PASS
|
||||||
|
GOOGLE_KEYSTORE_PASS:
|
||||||
|
from_secret: GOOGLE_KEYSTORE_PASS
|
||||||
|
|
||||||
trigger:
|
trigger:
|
||||||
event:
|
event:
|
||||||
- push
|
- push
|
||||||
|
@ -89,7 +100,7 @@ steps:
|
||||||
GOOGLE_KEYSTORE_PASS:
|
GOOGLE_KEYSTORE_PASS:
|
||||||
from_secret: GOOGLE_KEYSTORE_PASS
|
from_secret: GOOGLE_KEYSTORE_PASS
|
||||||
|
|
||||||
- name: Sign Android Release Artifact (.APK) for F-Droid Repository
|
- name: Sign and Deploy Android Release Artifact (.APK) for F-Droid Repository
|
||||||
commands:
|
commands:
|
||||||
- ./ci.py --sign-apk-fdroid
|
- ./ci.py --sign-apk-fdroid
|
||||||
environment:
|
environment:
|
||||||
|
|
14
ci.py
14
ci.py
|
@ -10,9 +10,11 @@ HOST_HOME = "/var/lib/drone-runner-exec"
|
||||||
CONTAINER_HOME = "/tmp/builder"
|
CONTAINER_HOME = "/tmp/builder"
|
||||||
|
|
||||||
APP_NAME = "org.selfprivacy.app"
|
APP_NAME = "org.selfprivacy.app"
|
||||||
|
APP_NAME_NIGHTLY = "org.selfprivacy.app.nightly"
|
||||||
APP_VERSION_FULL = yaml.safe_load(open("pubspec.yaml", "r"))['version']
|
APP_VERSION_FULL = yaml.safe_load(open("pubspec.yaml", "r"))['version']
|
||||||
APP_SEMVER = APP_VERSION_FULL[:APP_VERSION_FULL.find("+")]
|
APP_SEMVER = APP_VERSION_FULL[:APP_VERSION_FULL.find("+")]
|
||||||
APP_BUILD_ID = APP_VERSION_FULL[APP_VERSION_FULL.find("+"):][1::]
|
APP_BUILD_ID = APP_VERSION_FULL[APP_VERSION_FULL.find("+"):][1::]
|
||||||
|
APP_BUILD_ID_NIGHTLY = subprocess.run(["git", "rev-list", "--first-parent", "--count", "HEAD"], check=True, stdout=subprocess.PIPE).stdout.decode()
|
||||||
|
|
||||||
HOST_MOUNTED_VOLUME = f"{HOST_HOME}/.local/share/containers/storage/volumes/release/_data"
|
HOST_MOUNTED_VOLUME = f"{HOST_HOME}/.local/share/containers/storage/volumes/release/_data"
|
||||||
|
|
||||||
|
@ -72,6 +74,15 @@ def sign_apk_fdroid():
|
||||||
podman_offline(f"{CONTAINER_HOME}/fdroid", "fdroid publish")
|
podman_offline(f"{CONTAINER_HOME}/fdroid", "fdroid publish")
|
||||||
podman_offline(f"{CONTAINER_HOME}/fdroid", "fdroid update")
|
podman_offline(f"{CONTAINER_HOME}/fdroid", "fdroid update")
|
||||||
|
|
||||||
|
def sign_apk_fdroid_nightly():
|
||||||
|
podman_offline(f"{CONTAINER_HOME}/fdroid", f"rm -rf {CONTAINER_HOME}/fdroid/unsigned/*")
|
||||||
|
podman_offline(f"{CONTAINER_HOME}/fdroid",
|
||||||
|
f"test ! -f {CONTAINER_HOME}/fdroid/repo/{APP_NAME_NIGHTLY}_{APP_BUILD_ID_NIGHTLY}.apk",
|
||||||
|
"&& cp ../src/build/app/outputs/flutter-apk/app-nightly-release.apk",
|
||||||
|
f"unsigned/{APP_NAME_NIGHTLY}_{APP_BUILD_ID_NIGTLY}.apk || echo exist")
|
||||||
|
podman_offline(f"{CONTAINER_HOME}/fdroid", "fdroid publish")
|
||||||
|
podman_offline(f"{CONTAINER_HOME}/fdroid", "fdroid update")
|
||||||
|
|
||||||
def sign_bundle():
|
def sign_bundle():
|
||||||
podman_offline(f"{CONTAINER_HOME}/src",
|
podman_offline(f"{CONTAINER_HOME}/src",
|
||||||
f"jarsigner -sigalg SHA256withRSA -digestalg SHA-256 -keystore {CONTAINER_HOME}/google-keystore -signedjar {APP_NAME}-{APP_SEMVER}.aab -storepass:env GOOGLE_KEYSTORE_PASS build/app/outputs/bundle/productionRelease/app-production-release.aab google")
|
f"jarsigner -sigalg SHA256withRSA -digestalg SHA-256 -keystore {CONTAINER_HOME}/google-keystore -signedjar {APP_NAME}-{APP_SEMVER}.aab -storepass:env GOOGLE_KEYSTORE_PASS build/app/outputs/bundle/productionRelease/app-production-release.aab google")
|
||||||
|
@ -126,6 +137,7 @@ if __name__ == "__main__":
|
||||||
group.add_argument("--build-bundle", action="store_true")
|
group.add_argument("--build-bundle", action="store_true")
|
||||||
group.add_argument("--sign-apk-standalone", action="store_true", help="depends on $STANDALONE_KEYSTORE_PASS")
|
group.add_argument("--sign-apk-standalone", action="store_true", help="depends on $STANDALONE_KEYSTORE_PASS")
|
||||||
group.add_argument("--sign-apk-fdroid", action="store_true", help="depends on $FDROID_KEYSTORE_PASS")
|
group.add_argument("--sign-apk-fdroid", action="store_true", help="depends on $FDROID_KEYSTORE_PASS")
|
||||||
|
group.add_argument("--sign-apk-fdroid-nightly", action="store_true", help="depends on $FDROID_KEYSTORE_PASS")
|
||||||
group.add_argument("--sign-bundle", action="store_true", help="depends on $GOOGLE_KEYSTORE_PASS")
|
group.add_argument("--sign-bundle", action="store_true", help="depends on $GOOGLE_KEYSTORE_PASS")
|
||||||
group.add_argument("--package-linux-appimage", action="store_true")
|
group.add_argument("--package-linux-appimage", action="store_true")
|
||||||
group.add_argument("--package-linux-flatpak", action="store_true")
|
group.add_argument("--package-linux-flatpak", action="store_true")
|
||||||
|
@ -147,6 +159,8 @@ elif args.sign_apk_standalone:
|
||||||
sign_apk_standalone()
|
sign_apk_standalone()
|
||||||
elif args.sign_apk_fdroid:
|
elif args.sign_apk_fdroid:
|
||||||
sign_apk_fdroid()
|
sign_apk_fdroid()
|
||||||
|
elif args.sign_apk_fdroid_nightly:
|
||||||
|
sign_apk_fdroid_nightly()
|
||||||
elif args.sign_bundle:
|
elif args.sign_bundle:
|
||||||
sign_bundle()
|
sign_bundle()
|
||||||
elif args.package_linux_appimage:
|
elif args.package_linux_appimage:
|
||||||
|
|
Loading…
Reference in a new issue