getprop("ro.product.device") == "equuleus" || abort("E3004: This package is for \"equuleus\" devices; this is a \"" + getprop("ro.product.device") + "\".");
ui_print("Source: Xiaomi/equuleus/equuleus:10/QKQ1.190828.002/V11.0.5.0.QECMIXM:user/release-keys");
ui_print("Target: Xiaomi/equuleus/equuleus:10/QKQ1.190828.002/V11.0.7.0.QECMIXM:user/release-keys");
ui_print("Verifying current system...");
getprop("ro.build.fingerprint") == "Xiaomi/equuleus/equuleus:10/QKQ1.190828.002/V11.0.5.0.QECMIXM:user/release-keys" ||
    getprop("ro.build.fingerprint") == "Xiaomi/equuleus/equuleus:10/QKQ1.190828.002/V11.0.7.0.QECMIXM:user/release-keys" ||
    abort("E3001: Package expects build fingerprint of Xiaomi/equuleus/equuleus:10/QKQ1.190828.002/V11.0.5.0.QECMIXM:user/release-keys or Xiaomi/equuleus/equuleus:10/QKQ1.190828.002/V11.0.7.0.QECMIXM:user/release-keys; this device has " + getprop("ro.build.fingerprint") + ".");
show_progress(0.100000, 10);
patch_partition_check("EMMC:/dev/block/bootdevice/by-name/boot:45307210:762fbb5c095699603eca1effd765a51a482f4c76",
                      "EMMC:/dev/block/bootdevice/by-name/boot:45303114:be478918af0ad51fe58cab42f3ded2b025f35580") ||
    abort("E3005: \"EMMC:/dev/block/bootdevice/by-name/boot:45307210:762fbb5c095699603eca1effd765a51a482f4c76\" or \"EMMC:/dev/block/bootdevice/by-name/boot:45303114:be478918af0ad51fe58cab42f3ded2b025f35580\" has unexpected contents.");
apply_patch_space(117989376) || abort("E3006: Not enough free space on /cache to apply patches.");
show_progress(0.100000, 70);
if (range_sha1("/dev/block/bootdevice/by-name/system", "130,1,539,698,712,744,751,753,754,1000,1005,1007,1008,1114,1115,1599,1600,2288,2289,2291,2293,2294,2295,2310,2311,2492,2493,3664,3665,3667,3668,3672,3673,3681,3682,3683,3684,8279,8412,9041,9042,9044,9045,9449,9450,9452,9453,9471,22344,22359,24991,25039,32770,32959,32960,33466,65537,66043,98306,98495,98496,99002,102513,102815,124074,124094,127359,128466,128467,128707,131073,131579,163842,164031,164032,164538,196609,197115,229378,229567,229568,230074,258307,258348,258392,258420,262145,262651,294914,295103,295104,295610,327681,328187,331125,331178,331224,331257,360449,360955,393217,393723,395978,395981,425985,426491,458753,459259,491521,492027,524289,524795,557057,557563,589825,590331,622593,623099,655361,655867,688129,688635,720897,721403,753665,754171,760413,774155,780254,780261,780669") == "857549cffd864c3f5d3901a55592f63dd650a150" || block_image_verify("/dev/block/bootdevice/by-name/system", package_extract_file("system.transfer.list"), "system.new.dat", "system.patch.dat")) then
ui_print("Verified system image...");
else
check_first_block("/dev/block/bootdevice/by-name/system");
ifelse (block_image_recover("/dev/block/bootdevice/by-name/system", "130,1,539,698,712,744,751,753,754,1000,1005,1007,1008,1114,1115,1599,1600,2288,2289,2291,2293,2294,2295,2310,2311,2492,2493,3664,3665,3667,3668,3672,3673,3681,3682,3683,3684,8279,8412,9041,9042,9044,9045,9449,9450,9452,9453,9471,22344,22359,24991,25039,32770,32959,32960,33466,65537,66043,98306,98495,98496,99002,102513,102815,124074,124094,127359,128466,128467,128707,131073,131579,163842,164031,164032,164538,196609,197115,229378,229567,229568,230074,258307,258348,258392,258420,262145,262651,294914,295103,295104,295610,327681,328187,331125,331178,331224,331257,360449,360955,393217,393723,395978,395981,425985,426491,458753,459259,491521,492027,524289,524795,557057,557563,589825,590331,622593,623099,655361,655867,688129,688635,720897,721403,753665,754171,760413,774155,780254,780261,780669") && block_image_verify("/dev/block/bootdevice/by-name/system", package_extract_file("system.transfer.list"), "system.new.dat", "system.patch.dat"), ui_print("system recovered successfully."), abort("E1004: system partition fails to recover"));
endif;
if (range_sha1("/dev/block/bootdevice/by-name/vendor", "66,1,220,570,578,588,671,735,736,738,749,754,755,757,758,766,767,1007,1033,2919,2920,2974,3024,3043,3348,3415,3416,3455,3461,4440,5992,6003,32770,32832,32833,33338,65537,66042,66433,66434,66707,66708,66743,66744,98306,98368,98369,98874,131073,131578,163842,163904,163905,164410,196609,197114,229378,229440,229441,229946,231718,231767,240878,258044,260078,260085,260209") == "fdc588b02c6a24549bade41e63617b05b3e12f5d" || block_image_verify("/dev/block/bootdevice/by-name/vendor", package_extract_file("vendor.transfer.list"), "vendor.new.dat", "vendor.patch.dat")) then
ui_print("Verified vendor image...");
else
check_first_block("/dev/block/bootdevice/by-name/vendor");
ifelse (block_image_recover("/dev/block/bootdevice/by-name/vendor", "66,1,220,570,578,588,671,735,736,738,749,754,755,757,758,766,767,1007,1033,2919,2920,2974,3024,3043,3348,3415,3416,3455,3461,4440,5992,6003,32770,32832,32833,33338,65537,66042,66433,66434,66707,66708,66743,66744,98306,98368,98369,98874,131073,131578,163842,163904,163905,164410,196609,197114,229378,229440,229441,229946,231718,231767,240878,258044,260078,260085,260209") && block_image_verify("/dev/block/bootdevice/by-name/vendor", package_extract_file("vendor.transfer.list"), "vendor.new.dat", "vendor.patch.dat"), ui_print("vendor recovered successfully."), abort("E2004: vendor partition fails to recover"));
endif;

# ---- start making changes here ----

ui_print("Patching boot image...");
show_progress(0.100000, 10);
patch_partition("EMMC:/dev/block/bootdevice/by-name/boot:45307210:762fbb5c095699603eca1effd765a51a482f4c76",
                "EMMC:/dev/block/bootdevice/by-name/boot:45303114:be478918af0ad51fe58cab42f3ded2b025f35580",
                package_extract_file("boot.img.p")) ||
    abort("E3008: Failed to apply patch to EMMC:/dev/block/bootdevice/by-name/boot:45303114:be478918af0ad51fe58cab42f3ded2b025f35580");

# ---- radio update tasks ----

ui_print("Patching firmware images...");
package_extract_file("firmware-update/abl.elf", "/dev/block/bootdevice/by-name/abl_a");
package_extract_file("firmware-update/abl.elf", "/dev/block/bootdevice/by-name/abl_b");
show_progress(0.600000, 600);
ui_print("Patching system image after verification.");
block_image_update("/dev/block/bootdevice/by-name/system", package_extract_file("system.transfer.list"), "system.new.dat", "system.patch.dat") ||
  abort("E1001: Failed to update system image.");
ui_print("Patching vendor image after verification.");
block_image_update("/dev/block/bootdevice/by-name/vendor", package_extract_file("vendor.transfer.list"), "vendor.new.dat", "vendor.patch.dat") ||
  abort("E2001: Failed to update vendor image.");
show_progress(0.100000, 2);

# ---- radio update tasks 2 ----

ui_print("Patching vbmeta dtbo logo binimages...");
package_extract_file("firmware-update/xbl_config.img", "/dev/block/bootdevice/by-name/xbl_config_a");
package_extract_file("firmware-update/aop.img", "/dev/block/bootdevice/by-name/aop_a");
package_extract_file("firmware-update/devcfg.img", "/dev/block/bootdevice/by-name/devcfg_a");
package_extract_file("firmware-update/qupfw.img", "/dev/block/bootdevice/by-name/qupfw_a");
package_extract_file("firmware-update/tz.img", "/dev/block/bootdevice/by-name/tz_a");
package_extract_file("firmware-update/storsec.img", "/dev/block/bootdevice/by-name/storsec_a");
package_extract_file("firmware-update/keymaster.img", "/dev/block/bootdevice/by-name/keymaster_a");
package_extract_file("firmware-update/bluetooth.img", "/dev/block/bootdevice/by-name/bluetooth");
package_extract_file("firmware-update/xbl.img", "/dev/block/bootdevice/by-name/xbl_a");
package_extract_file("firmware-update/modem.img", "/dev/block/bootdevice/by-name/modem");
package_extract_file("firmware-update/dsp.img", "/dev/block/bootdevice/by-name/dsp");
package_extract_file("firmware-update/logo.img", "/dev/block/bootdevice/by-name/logo");
package_extract_file("firmware-update/cmnlib64.img", "/dev/block/bootdevice/by-name/cmnlib64_a");
package_extract_file("firmware-update/cmnlib.img", "/dev/block/bootdevice/by-name/cmnlib_a");
package_extract_file("firmware-update/hyp.img", "/dev/block/bootdevice/by-name/hyp_a");
