getprop("ro.product.device") == "eros-p1" || abort("E3004: This package is for \"eros-p1\" devices; this is a \"" + getprop("ro.product.device") + "\".");
assert_boot_version(0);
ui_print("Source: Allwinner/eros_p1/eros-p1:10/QP1A.191105.004/eng.zhshs.20251202.085809:user/test-keys");
ui_print("Target: Allwinner/eros_p1/eros-p1:10/QP1A.191105.004/eng.zhshs.20260427.171556:user/test-keys");
ui_print("Verifying current system...");
getprop("ro.build.fingerprint") == "Allwinner/eros_p1/eros-p1:10/QP1A.191105.004/eng.zhshs.20251202.085809:user/test-keys" ||
    getprop("ro.build.fingerprint") == "Allwinner/eros_p1/eros-p1:10/QP1A.191105.004/eng.zhshs.20260427.171556:user/test-keys" ||
    abort("E3001: Package expects build fingerprint of Allwinner/eros_p1/eros-p1:10/QP1A.191105.004/eng.zhshs.20251202.085809:user/test-keys or Allwinner/eros_p1/eros-p1:10/QP1A.191105.004/eng.zhshs.20260427.171556:user/test-keys; this device has " + getprop("ro.build.fingerprint") + ".");
patch_partition_check("EMMC:/dev/block/by-name/boot:33554432:dd832a1b5e234db62abc60b4fbfffc9e4d32efcf",
                      "EMMC:/dev/block/by-name/boot:33554432:6b715c9f7e5eab5d67d39345e7c6bb8d9829f553") ||
    abort("E3005: \"EMMC:/dev/block/by-name/boot:33554432:dd832a1b5e234db62abc60b4fbfffc9e4d32efcf\" or \"EMMC:/dev/block/by-name/boot:33554432:6b715c9f7e5eab5d67d39345e7c6bb8d9829f553\" has unexpected contents.");
apply_patch_space(114827264) || abort("E3006: Not enough free space on /cache to apply patches.");
if (range_sha1(map_partition("system"), "134,1,117,378,390,392,393,491,492,970,971,973,975,976,977,992,993,1130,1131,1946,1947,1949,1950,1953,1954,1961,1962,1963,1964,6221,6222,6224,6225,6506,6507,6509,6510,7063,7065,13004,13005,13138,13139,15618,15620,21520,21521,21523,21525,21584,32770,32849,37716,38331,38332,38340,38342,38348,38349,38385,38387,38409,38410,39306,39308,39565,39567,39584,39585,39790,39792,39799,39800,40400,40404,40423,40424,40478,40480,40487,40488,40493,40497,40503,40504,40597,40599,40607,40608,45331,45333,47338,47339,47373,47375,47381,47382,47644,47648,47658,47659,47695,47697,47703,47704,47778,47780,47787,47788,49474,49476,49494,49495,49614,49616,49624,67709,76308,76310,77469,98306,98385,163842,163921,229378,229457,294914,294993,295006,295015,326554,327540,332731,332812,332813") == "f6abf6ca36579cb4d5a41e26b1175b978578ed70" || block_image_verify(map_partition("system"), package_extract_file("system.transfer.list"), "system.new.dat", "system.patch.dat")) then
ui_print("Verified system image...");
else
check_first_block(map_partition("system"));
ifelse (block_image_recover(map_partition("system"), "134,1,117,378,390,392,393,491,492,970,971,973,975,976,977,992,993,1130,1131,1946,1947,1949,1950,1953,1954,1961,1962,1963,1964,6221,6222,6224,6225,6506,6507,6509,6510,7063,7065,13004,13005,13138,13139,15618,15620,21520,21521,21523,21525,21584,32770,32849,37716,38331,38332,38340,38342,38348,38349,38385,38387,38409,38410,39306,39308,39565,39567,39584,39585,39790,39792,39799,39800,40400,40404,40423,40424,40478,40480,40487,40488,40493,40497,40503,40504,40597,40599,40607,40608,45331,45333,47338,47339,47373,47375,47381,47382,47644,47648,47658,47659,47695,47697,47703,47704,47778,47780,47787,47788,49474,49476,49494,49495,49614,49616,49624,67709,76308,76310,77469,98306,98385,163842,163921,229378,229457,294914,294993,295006,295015,326554,327540,332731,332812,332813") && block_image_verify(map_partition("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(map_partition("vendor"), "36,1,45,645,646,1751,1752,1753,1754,1777,1778,1793,1794,1799,1800,1804,1805,1931,1932,2099,2100,2411,2412,2413,2744,2903,3228,5300,5343,5507,32770,32779,38928,39049,39672,39695,39696") == "ec5490c82ae0026a8084c5ae2857cb1a649cb56a" || block_image_verify(map_partition("vendor"), package_extract_file("vendor.transfer.list"), "vendor.new.dat", "vendor.patch.dat")) then
ui_print("Verified vendor image...");
else
check_first_block(map_partition("vendor"));
ifelse (block_image_recover(map_partition("vendor"), "36,1,45,645,646,1751,1752,1753,1754,1777,1778,1793,1794,1799,1800,1804,1805,1931,1932,2099,2100,2411,2412,2413,2744,2903,3228,5300,5343,5507,32770,32779,38928,39049,39672,39695,39696") && block_image_verify(map_partition("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;
if (range_sha1(map_partition("product"), "58,1,2,8,26,513,515,531,532,1794,1798,1821,1822,3237,3241,3258,3259,3264,3265,3269,3272,17186,17188,17190,17191,17195,17197,17202,17203,17419,17420,17424,17426,17431,17433,17439,17440,17446,17448,17454,17455,17952,17954,17970,17971,19566,19568,19586,19587,24447,24449,24492,24493,24526,24528,24608,25003,25022,25023") == "5da209f3682075cd9d95376ae01bd22a875a0484" || block_image_verify(map_partition("product"), package_extract_file("product.transfer.list"), "product.new.dat", "product.patch.dat")) then
ui_print("Verified product image...");
else
ifelse (block_image_recover(map_partition("product"), "58,1,2,8,26,513,515,531,532,1794,1798,1821,1822,3237,3241,3258,3259,3264,3265,3269,3272,17186,17188,17190,17191,17195,17197,17202,17203,17419,17420,17424,17426,17431,17433,17439,17440,17446,17448,17454,17455,17952,17954,17970,17971,19566,19568,19586,19587,24447,24449,24492,24493,24526,24528,24608,25003,25022,25023") && block_image_verify(map_partition("product"), package_extract_file("product.transfer.list"), "product.new.dat", "product.patch.dat"), ui_print("product recovered successfully."), abort("E2004: product partition fails to recover"));
endif;

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


# --- Start patching dynamic partitions ---


# Update dynamic partition metadata

assert(update_dynamic_partitions(package_extract_file("dynamic_partitions_op_list")));

# Patch partition product

ui_print("Patching product image after verification.");
block_image_update(map_partition("product"), package_extract_file("product.transfer.list"), "product.new.dat", "product.patch.dat") ||
  abort("E2001: Failed to update product image.");

# Patch partition vendor

ui_print("Patching vendor image after verification.");
show_progress(0.100000, 0);
block_image_update(map_partition("vendor"), package_extract_file("vendor.transfer.list"), "vendor.new.dat", "vendor.patch.dat") ||
  abort("E2001: Failed to update vendor image.");

# Patch partition system

ui_print("Patching system image after verification.");
show_progress(0.800000, 0);
block_image_update(map_partition("system"), package_extract_file("system.transfer.list"), "system.new.dat", "system.patch.dat") ||
  abort("E1001: Failed to update system image.");

# --- End patching dynamic partitions ---

ui_print("Patching boot image...");
show_progress(0.100000, 10);
patch_partition("EMMC:/dev/block/by-name/boot:33554432:dd832a1b5e234db62abc60b4fbfffc9e4d32efcf",
                "EMMC:/dev/block/by-name/boot:33554432:6b715c9f7e5eab5d67d39345e7c6bb8d9829f553",
                package_extract_file("boot.img.p")) ||
    abort("E3008: Failed to apply patch to EMMC:/dev/block/by-name/boot:33554432:6b715c9f7e5eab5d67d39345e7c6bb8d9829f553");
ui_print("Updating boot-resource.fex into bootloader partition...");
package_extract_file("boot-resource.fex","/dev/block/by-name/bootloader");
ui_print("Updating env.fex into env partition...");
package_extract_file("env.fex","/dev/block/by-name/env");
ui_print("Updating vbmeta.img into vbmeta partition...");
package_extract_file("vbmeta.img","/dev/block/by-name/vbmeta");
ui_print("Updating vbmeta_system.img into vbmeta_system partition...");
package_extract_file("vbmeta_system.img","/dev/block/by-name/vbmeta_system");
ui_print("Updating vbmeta_vendor.img into vbmeta_vendor partition...");
package_extract_file("vbmeta_vendor.img","/dev/block/by-name/vbmeta_vendor");
ui_print("Updating boot...");
burnboot();
set_progress(1.000000);
