Fix E2EE decryption issue and duplicate webhook insertion

This commit is contained in:
Hamza-Ayed
2026-05-22 17:35:26 +03:00
parent 814b1b5caa
commit 5478fbbae6
3 changed files with 88 additions and 18 deletions

View File

@@ -30,6 +30,25 @@ class MessageLog extends BaseModel
$data['media_url'] = Security::encrypt($data['media_url']);
}
return self::create($data);
try {
return self::create($data);
} catch (\PDOException $e) {
// Handle duplicate entry gracefully
if ($e->getCode() === '23000' || strpos($e->getMessage(), '1062') !== false) {
error_log("[MessageLog] Duplicate whatsapp_message_id: " . ($data['whatsapp_message_id'] ?? 'unknown'));
// Retrieve and return existing log record
if (!empty($data['whatsapp_message_id'])) {
$existing = \App\Core\Database::select(
"SELECT * FROM " . static::$table . " WHERE whatsapp_message_id = ? LIMIT 1",
[$data['whatsapp_message_id']]
);
if (!empty($existing)) {
return $existing[0];
}
}
return null;
}
throw $e;
}
}
}