Go to file
2024-01-20 17:34:58 +02:00
res New translations (#77) 2024-01-20 17:34:58 +02:00
src/com/crdroid/updater Updater: Show the correct percentage during package installation 2023-08-04 06:26:24 +00:00
.gitignore Updater: Android Studio support 2018-01-23 22:41:40 +01:00
Android.bp Updater: Change package name to avoid conflict 2022-09-03 22:22:32 +05:30
AndroidManifest.xml Updater: Change package name to avoid conflict 2022-09-03 22:22:32 +05:30
build.gradle Updater: update dependencies 2022-02-10 20:53:39 +00:00
crowdin.yml Update Crowdin configuration file 2022-09-03 22:22:32 +05:30
gen-keystore.sh gen-keystore.sh: Don't pass the passwords as args 2018-04-11 00:33:05 +02:00
gradle.properties Updater: Move to AndroidX 2019-09-07 19:11:27 +02:00
keystore.properties.sample Updater: Android Studio support 2018-01-23 22:41:40 +01:00
privapp_whitelist_com.crdroid.updater.xml Updater: Change package name to avoid conflict 2022-09-03 22:22:32 +05:30
proguard.flags Updater: Change package name to avoid conflict 2022-09-03 22:22:32 +05:30
push-update.sh Updater: Change package name to avoid conflict 2022-09-03 22:22:32 +05:30
README.md Updater: README: Update android studio instructions 2022-08-24 19:39:45 +02:00

Updater

Simple application to download and apply OTA packages.

Server requirements

The app sends GET requests to the URL defined by the updater_server_url resource (or the lineage.updater.uri system property) and expects as response a JSON with the following structure:

{
  "response": [
    {
      "datetime": 1230764400,
      "filename": "ota-package.zip",
      "id": "5eb63bbbe01eeed093cb22bb8f5acdc3",
      "romtype": "nightly",
      "size": 314572800,
      "url": "https://example.com/ota-package.zip",
      "version": "15.1"
    }
  ]
}

The datetime attribute is the build date expressed as UNIX timestamp.
The filename attribute is the name of the file to be downloaded.
The id attribute is a string that uniquely identifies the update.
The romtype attribute is the string to be compared with the ro.lineage.releasetype property.
The size attribute is the size of the update expressed in bytes.
The url attribute is the URL of the file to be downloaded.
The version attribute is the string to be compared with the ro.lineage.build.version property.

Additional attributes are ignored.

Build with Android Studio

Updater needs access to the system API, therefore it can't be built only using the public SDK. You first need to generate the libraries with all the needed classes. The application also needs elevated privileges, so you need to sign it with the right key to update the one in the system partition. To do this:

  • Place this directory anywhere in the Android source tree
  • Generate a keystore and keystore.properties using gen-keystore.sh
  • Build the dependencies by running m framework from the root of the Android source tree.
  • Create system_libs/ directory in Updater repo and copy classes.jar file from out/target/common/obj/JAVA_LIBRARIES/framework_intermediates/ into it.

You need to do the above once, unless Android Studio can't find some symbol. In this case, rebuild the system libraries with m framework.