This GitHub Actions workflow allows you to automatically extract and release specific files from a ROM URL.
The following inputs are required when triggering the workflow:
-
ROM_URL
: The URL of the ROM file to be extracted and released. -
DEVICE_NAME
: The name of the device for which the ROM is intended. -
ROM_NAME
: The name of the ROM. -
EXTRACTED_FILES
: A comma-separated list of files to be extracted from the ROM and included in the release. Available files may include:- "boot.img" - The boot image, which contains the kernel and recovery.
- "dtbo.img" - The device tree binary image, which contains information about the device's hardware.
- "product.img" - The product image, which contains the system's product-specific properties.
- "system.img" - The system image, which contains the system partition.
- "system_ext.img" - The system_ext image, which contains the system_ext partition.
- "vbmeta.img" - The vbmeta image, which contains verified boot metadata.
- "vbmeta_system.img" - The vbmeta_system image, which contains verified boot metadata for the system partition.
- "vendor.img" - The vendor image, which contains the vendor partition.
- "vendor_boot.img" - The vendor boot image, which contains the vendor-specific kernel and ramdisk.
The workflow is composed of the following steps:
- Checkout code: check out the repository code.
- Download file: download the file specified by the ROM_URL input.
- Unzip file: unzip the downloaded file to a directory named "extracted_files/".
- Setup Python: set up a version of Python.
- Install OTA Extractor: download and install the OTA Extractor package.
- Extract Payload: extract payload from the downloaded file and output it to the current directory.
- Upload to Release: upload the specified files (EXTRACTED_FILES input) to a GitHub release with a name that includes the DEVICE_NAME and run_id, a tag with the run_id, and a body that includes information about the device, ROM, and extracted files.
To use this workflow, create a new GitHub Actions workflow in your repository and copy the contents of main.yml into the file. Update the inputs with your desired values, and configure any necessary secrets. You can then trigger the workflow manually using the "workflow_dispatch" event.
The OTA Extractor package that is used in this workflow is taken from https://github.com/sakshiagrwal/OTAExtractor, it is cloned, a specific version of protobuf library is installed, and HEAD~1
is reset to avoid breaking changes. So you can be sure that the package version you are using is compatible with the script.
Additionally, it is important to note that in order to use the Upload to Release
step, you need to have the GITHUB_TOKEN
available as a secret in your repository.