assert(getprop("ro.product.device") == "casuarina" || getprop("ro.build.product") == "casuarina" || abort("E3004: This package is for device: casuarina; this device is " + getprop("ro.product.device") + "."););
ui_print("Target: vsmart/casuarina_open/casuarina:10/QKQ1.200311.002/V430A_OPN_U_B15_211112:user/release-keys");
package_extract_dir("install", "/tmp/install");
set_metadata_recursive("/tmp/install", "uid", 0, "gid", 0, "dmode", 0755, "fmode", 0644);
set_metadata_recursive("/tmp/install/bin", "uid", 0, "gid", 0, "dmode", 0755, "fmode", 0755);
run_program("/tmp/install/bin/backuptool.sh", "backup", "/dev/block/by-name/system", "ext4");
ui_print("Patching system image unconditionally...");
show_progress(0.800000, 0);
block_image_update("/dev/block/by-name/system", package_extract_file("system.transfer.list"), "system.new.dat.br", "system.patch.dat") ||
  abort("E1001: Failed to update system image.");
ui_print("Patching vendor image unconditionally...");
show_progress(0.100000, 0);
block_image_update("/dev/block/by-name/vendor", package_extract_file("vendor.transfer.list"), "vendor.new.dat.br", "vendor.patch.dat") ||
  abort("E2001: Failed to update vendor image.");
show_progress(0.020000, 10);
run_program("/tmp/install/bin/backuptool.sh", "restore", "/dev/block/by-name/system", "ext4");
package_extract_file("boot.img", "/dev/block/bootdevice/by-name/boot");
show_progress(0.100000, 10);
ui_print("Patching dtbo image unconditionally...");
package_extract_file("dtbo.img", "/dev/block/bootdevice/by-name/dtbo");
ui_print("Patching vbmeta image unconditionally...");
package_extract_file("vbmeta.img", "/dev/block/bootdevice/by-name/vbmeta");
ui_print("Patching aboot image unconditionally...");
package_extract_file("aboot.mbn", "/dev/block/bootdevice/by-name/aboot");
ui_print("Patching cmnlib image unconditionally...");
package_extract_file("cmnlib.mbn", "/dev/block/bootdevice/by-name/cmnlib");
ui_print("Patching cmnlib64 image unconditionally...");
package_extract_file("cmnlib64.mbn", "/dev/block/bootdevice/by-name/cmnlib64");
ui_print("Patching devcfg image unconditionally...");
package_extract_file("devcfg.mbn", "/dev/block/bootdevice/by-name/devcfg");
ui_print("Patching dsp image unconditionally...");
package_extract_file("dsp.bin", "/dev/block/bootdevice/by-name/dsp");
ui_print("Patching keymaster image unconditionally...");
package_extract_file("keymaster.mbn", "/dev/block/bootdevice/by-name/keymaster");
ui_print("Patching lksecapp image unconditionally...");
package_extract_file("lksecapp.mbn", "/dev/block/bootdevice/by-name/lksecapp");
ui_print("Patching modem image unconditionally...");
package_extract_file("modem.bin", "/dev/block/bootdevice/by-name/modem");
ui_print("Patching rpm image unconditionally...");
package_extract_file("rpm.mbn", "/dev/block/bootdevice/by-name/rpm");
ui_print("Patching sbl1 image unconditionally...");
package_extract_file("sbl1.mbn", "/dev/block/bootdevice/by-name/sbl1");
ui_print("Patching splash image unconditionally...");
package_extract_file("splash.img", "/dev/block/bootdevice/by-name/splash");
ui_print("Patching tz image unconditionally...");
package_extract_file("tz.mbn", "/dev/block/bootdevice/by-name/tz");
set_progress(1.000000);
