mirror of
https://github.com/OpenXE-org/OpenXE.git
synced 2025-01-07 04:20:28 +01:00
135 lines
3.9 KiB
PHP
135 lines
3.9 KiB
PHP
|
<?php
|
||
|
|
||
|
namespace Xentral\Modules\SuperSearch\SystemHealth;
|
||
|
|
||
|
use DateInterval;
|
||
|
use DateTime;
|
||
|
use DateTimeImmutable;
|
||
|
use Exception;
|
||
|
use Xentral\Components\Database\Database;
|
||
|
|
||
|
final class SuperSearchHealthChecker
|
||
|
{
|
||
|
/** @var Database $db */
|
||
|
private $db;
|
||
|
|
||
|
/**
|
||
|
* @param Database $database
|
||
|
*/
|
||
|
public function __construct(Database $database)
|
||
|
{
|
||
|
$this->db = $database;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @return array
|
||
|
*/
|
||
|
public function getHealthStatus()
|
||
|
{
|
||
|
$sql =
|
||
|
'SELECT
|
||
|
sig.id, sig.name, sig.title, sig.module,
|
||
|
IFNULL(sig.last_diff_update, sig.last_full_update) AS `last_cron_run`,
|
||
|
MIN(IFNULL(sii.updated_at, sii.created_at)) AS `oldest_index_item`
|
||
|
FROM `supersearch_index_group` AS sig
|
||
|
LEFT JOIN `supersearch_index_item` AS sii ON sig.name = sii.index_name AND sii.outdated = 0
|
||
|
WHERE sig.active = 1
|
||
|
GROUP BY sig.name';
|
||
|
$indexes = $this->db->fetchAll($sql);
|
||
|
|
||
|
$outdatedTime = new DateTime('now');
|
||
|
$outdatedTime->sub(new DateInterval('PT48H'));
|
||
|
|
||
|
foreach ($indexes as $index) {
|
||
|
$lastCronRun = $this->tryCreateDateTimeObject($index['last_cron_run']);
|
||
|
if ($lastCronRun === null) {
|
||
|
// Prozessstarter ist für diesen Index nie gelaufen
|
||
|
return $this->buildResultForNotRunningSheduler($index['name']);
|
||
|
}
|
||
|
if ($lastCronRun !== null) {
|
||
|
if ($lastCronRun < $outdatedTime) {
|
||
|
// Prozessstarter ist für diesen Index seit mehr als 48 Stunden nicht mehr gelaufen
|
||
|
return $this->buildResultForOutdatedShedulerRunDate($index['name']);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
$oldestIndexItem = $this->tryCreateDateTimeObject($index['oldest_index_item']);
|
||
|
if ($oldestIndexItem !== null) {
|
||
|
if ($oldestIndexItem < $outdatedTime) {
|
||
|
// Such-Index enthält Einträge die seit mehr als 48 Stunden nicht mehr aktualisiert wurden
|
||
|
return $this->buildResultForOutdatedIndexItem($index['name']);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Wenn Code bis hierhin gelauf ist, ist alles in Ordnung
|
||
|
return [
|
||
|
'type' => 'ok', // string [ok|warning|error]
|
||
|
'message' => null, // string|null
|
||
|
];
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param string $indexName
|
||
|
*
|
||
|
* @return array
|
||
|
*/
|
||
|
private function buildResultForNotRunningSheduler($indexName)
|
||
|
{
|
||
|
return [
|
||
|
'type' => 'error',
|
||
|
'message' => sprintf(
|
||
|
'Befüllung für Such-Index "%s" wurde noch nie ausgeführt.', $indexName
|
||
|
),
|
||
|
];
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param string $indexName
|
||
|
*
|
||
|
* @return array
|
||
|
*/
|
||
|
private function buildResultForOutdatedShedulerRunDate($indexName)
|
||
|
{
|
||
|
return [
|
||
|
'type' => 'error',
|
||
|
'message' => sprintf(
|
||
|
'Befüllung des Such-Index "%s" wurde seit mehr als 48 Stunden nicht mehr ausgeführt.', $indexName
|
||
|
),
|
||
|
];
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param string $indexName
|
||
|
*
|
||
|
* @return array
|
||
|
*/
|
||
|
private function buildResultForOutdatedIndexItem($indexName)
|
||
|
{
|
||
|
return [
|
||
|
'type' => 'warning',
|
||
|
'message' => sprintf(
|
||
|
'Der Such-Index "%s" enthält Einträge die seit mehr als 48 Stunden nicht mehr aktualisiert wurden.',
|
||
|
$indexName
|
||
|
),
|
||
|
];
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param string|null $dateTimeString
|
||
|
*
|
||
|
* @return DateTimeImmutable|null
|
||
|
*/
|
||
|
private function tryCreateDateTimeObject($dateTimeString = null)
|
||
|
{
|
||
|
try {
|
||
|
if (!empty($dateTimeString)) {
|
||
|
return new DateTimeImmutable($dateTimeString);
|
||
|
}
|
||
|
} catch (Exception $exception) {
|
||
|
}
|
||
|
|
||
|
return null;
|
||
|
}
|
||
|
}
|