You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
hmz007 f861dd32ff
android: apps: Add org.lineageos.updater
11 months ago
..
res android: apps: Add org.lineageos.updater 11 months ago
src/org/lineageos/updater android: apps: Add org.lineageos.updater 11 months ago
.gitignore android: apps: Add org.lineageos.updater 11 months ago
Android.mk android: apps: Add org.lineageos.updater 11 months ago
AndroidManifest.xml android: apps: Add org.lineageos.updater 11 months ago
README.md android: apps: Add org.lineageos.updater 11 months ago
build.gradle android: apps: Add org.lineageos.updater 11 months ago
gen-keystore.sh android: apps: Add org.lineageos.updater 11 months ago
gradle.properties android: apps: Add org.lineageos.updater 11 months ago
keystore.properties.sample android: apps: Add org.lineageos.updater 11 months ago
privapp_whitelist_org.lineageos.updater.xml android: apps: Add org.lineageos.updater 11 months ago
proguard.flags android: apps: Add org.lineageos.updater 11 months ago
push-update.sh android: apps: Add org.lineageos.updater 11 months ago

README.md

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 running make UpdaterStudio from the root of the Android source tree. This command will add the needed libraries in system_libraries/.

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