From 31838415b3fd176acecdfcaaa7cc0b51e5de1c37 Mon Sep 17 00:00:00 2001 From: ralf Date: Mon, 16 Sep 2024 13:38:03 +0200 Subject: [PATCH] if async ID would be longer than 64 chars truncate it to 32 chars plus md5 hash of all data take care of being able to read old, just truncated IDs too --- .../class.importexport_schedule_ui.inc.php | 25 +++++++++++++------ 1 file changed, 18 insertions(+), 7 deletions(-) diff --git a/importexport/inc/class.importexport_schedule_ui.inc.php b/importexport/inc/class.importexport_schedule_ui.inc.php index cc56803c93..b96cc0ff41 100644 --- a/importexport/inc/class.importexport_schedule_ui.inc.php +++ b/importexport/inc/class.importexport_schedule_ui.inc.php @@ -267,9 +267,16 @@ class importexport_schedule_ui } /** - * Generate a async key - */ - public static function generate_id($data) + * Generate an unique async key + * + * If the id is longer than 64 chars (supported in current DB schema), we use the first 32 chars + * plus a md5 hash of the whole data. + * + * @param array $data + * @param bool $old false: generate new id with md5 hash, if otherwise to long, true: generate old, to 64 chars truncated, id + * @return false|string + */ + public static function generate_id($data, $old=false) { $query = array( @@ -280,7 +287,11 @@ class importexport_schedule_ui $definition_list = ((array)$definitions->get_definitions()); $id = 'importexport.'.$definition_list[0].'.'.$data['target']; - return substr($id, 0, 64); + if (strlen($id) <= 64 || $old) + { + return substr($id, 0, 64); + } + return substr($id, 0, 32).md5($id); } /** @@ -645,12 +656,12 @@ class importexport_schedule_ui { $id = self::generate_id($data); $async = new Api\Asyncservice(); - $jobs = $async->read($id); - $job = $jobs[$id]; + $jobs = $async->read($id) ?: $async->read($old_id=self::generate_id($data, true)) ?: []; + $job = array_shift($jobs); if(is_array($job)) { - $async->cancel_timer($id); + $async->cancel_timer($old_id ?? $id); $result = $async->set_timer( $job['times'], $id,