lineage-updater/README.md

77 lines
3.0 KiB
Markdown

## This is a bare minimum OTA server for Lineage
## Quickstart
1. Create a configuration file named `.lineageupdaterrc` in the home
directory of the web server user, usually `/var/www`. This is a
simple key=value file. Required keys are:
* _directory_: the local directory where OTA zip files are stored.
* _baseurl_: the web accessible URL to the same directory.
2. Create a rewrite rule on the web server to translate the "pretty"
path to CGI parameters. This works for lighttpd:
$HTTP["host"] == "ota.example.com" {
url.rewrite = (
"^/api/v1/([^/]+)/([^/]+)/([^/]+)$" => "/cgi-bin/lineage-updater?device=$1&type=$2&incr=$3"
)
}
## Usage
The script expects OTA files to be named as follows:
_project_\__device_-ota-_version_-_buildtype_-_incremental_.zip
Where:
* _project_ is the project/ROM name, eg. "lineage".
* _device_ is the device name, eg. "mako".
* _version_ is the project/ROM version, eg. "16.0".
* _buildtype_ is the buildtype, eg. "unofficial".
* _incremental_ is the incremental version, eg. "eng.user.20200807.162000".
The default OTA and target-files file names include all of these fields
except _incremental_. This is the value of `ro.build.version.incremental`
in the system build properties. It is different from `ro.build.date.utc`.
They are __not__ interchangeable.
Example: lineage_mako-ota-16.0-unofficial-eng.user.20200807.162000.zip
The OTA directory may contain subdirectories of arbitrary depth.
## Time stamps
Clients determine whether an update is newer than the currently running
version by comparing the local `ro.build.date.utc` property with the
`datetime` on each OTA file. The script uses the file modification
time as the `datetime`. Therefore, you should ensure that these values
match for each available OTA file.
One way to do this is to set the file modification time on your build
server as shown below. You then only need to ensure that the file
modification time is preserved when you copy it to its destination on
your web server.
t=$(grep "ro.build.date.utc" "out/target/product/$device/system/build.prop" | cut -d'=' -f2)
touch -d "@$t" $filename
Another way to do this is to set the file modification time after copying
to your web server.
t=$(unzip -c $filename "META-INF/com/android/metadata" | grep "^post-timestamp=" | cut -d"=" -f2)
touch -d "@$t" $filename
## Caching
The script creates and uses a cache file named `.cache` in the OTA
directory. This is a simple JSON file describing the results of the
last walk through the OTA directory. If the script does not have
permission to write to this file, caching will fail and the script will
be exceptionally slow.
The cache entry for a given OTA file is updated if the file size or
modification time changes.
Cache entries for files that no longer exist are pruned.
The cache file is updated at most once per minute. If you do not see
new files immediately, wait 60 seconds and try again.
The cache file is locked during access to ensure its integrity.