2023-04-09 00:06:28 +03:00
|
|
|
<?php
|
|
|
|
|
|
|
|
// Lock multi-thread execution
|
|
|
|
$semaphore = sem_get(crc32('crontab.cleaner'), 1);
|
|
|
|
|
|
|
|
if (false === sem_acquire($semaphore, true)) {
|
|
|
|
|
|
|
|
echo 'Process locked by another thread.' . PHP_EOL;
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Load system dependencies
|
|
|
|
require_once('../config/app.php');
|
|
|
|
require_once('../library/curl.php');
|
|
|
|
require_once('../library/robots.php');
|
|
|
|
require_once('../library/mysql.php');
|
|
|
|
|
|
|
|
// Connect database
|
|
|
|
$db = new MySQL(DB_HOST, DB_PORT, DB_NAME, DB_USERNAME, DB_PASSWORD);
|
|
|
|
|
|
|
|
// Debug
|
|
|
|
$timeStart = microtime(true);
|
|
|
|
|
2023-05-08 08:27:21 +03:00
|
|
|
$requestsTotal = 0;
|
|
|
|
$requestSizeTotal = 0;
|
|
|
|
$downloadSizeTotal = 0;
|
|
|
|
$requestsTotalTime = 0;
|
|
|
|
|
2023-05-06 08:45:37 +03:00
|
|
|
$hostsTotal = $db->getTotalHosts();
|
|
|
|
$manifestsTotal = $db->getTotalManifests();
|
|
|
|
$hostsUpdated = 0;
|
|
|
|
$hostsPagesDeleted = 0;
|
|
|
|
$hostsImagesDeleted = 0;
|
|
|
|
$manifestsDeleted = 0;
|
|
|
|
$hostPagesBansRemoved = 0;
|
|
|
|
$hostImagesBansRemoved = 0;
|
2023-04-09 00:06:28 +03:00
|
|
|
|
2023-05-05 05:26:53 +03:00
|
|
|
// Begin update
|
|
|
|
$db->beginTransaction();
|
2023-04-09 00:06:28 +03:00
|
|
|
|
2023-05-05 05:26:53 +03:00
|
|
|
try {
|
2023-04-09 00:06:28 +03:00
|
|
|
|
2023-05-05 05:26:53 +03:00
|
|
|
// Get cleaner queue
|
|
|
|
foreach ($db->getCleanerQueue(CLEAN_HOST_LIMIT, time() - CLEAN_HOST_SECONDS_OFFSET) as $host) {
|
2023-04-09 00:06:28 +03:00
|
|
|
|
2023-05-05 05:26:53 +03:00
|
|
|
// Parse host info
|
|
|
|
$hostURL = $host->scheme . '://' . $host->name . ($host->port ? ':' . $host->port : false);
|
2023-04-09 00:06:28 +03:00
|
|
|
|
2023-05-05 05:26:53 +03:00
|
|
|
// Get robots.txt if exists
|
|
|
|
$curl = new Curl($hostURL . '/robots.txt', CRAWL_CURLOPT_USERAGENT);
|
2023-04-09 00:06:28 +03:00
|
|
|
|
2023-05-08 08:27:21 +03:00
|
|
|
// Update curl stats
|
|
|
|
$requestsTotal++;
|
|
|
|
$requestSizeTotal += $curl->getSizeRequest();
|
|
|
|
$downloadSizeTotal += $curl->getSizeDownload();
|
|
|
|
$requestsTotalTime += $curl->getTotalTime();
|
|
|
|
|
2023-05-05 05:26:53 +03:00
|
|
|
if (200 == $curl->getCode() && false !== stripos($curl->getContent(), 'user-agent:')) {
|
|
|
|
$hostRobots = $curl->getContent();
|
|
|
|
} else {
|
|
|
|
$hostRobots = null;
|
|
|
|
}
|
2023-04-09 00:06:28 +03:00
|
|
|
|
|
|
|
// Update host data
|
|
|
|
$hostsUpdated += $db->updateHostRobots($host->hostId, $hostRobots, time());
|
|
|
|
|
2023-05-04 01:04:39 +03:00
|
|
|
// Apply host images limits
|
|
|
|
$totalHostImages = $db->getTotalHostImages($host->hostId);
|
|
|
|
|
|
|
|
if ($totalHostImages > $host->crawlImageLimit) {
|
|
|
|
|
|
|
|
foreach ((array) $db->getHostImagesByLimit($host->hostId, $totalHostImages - $host->crawlImageLimit) as $hostImage) {
|
|
|
|
|
|
|
|
// Delete foreign key relations
|
|
|
|
$db->deleteHostImageDescription($hostImage->hostImageId);
|
|
|
|
$db->deleteHostImageToHostPage($hostImage->hostImageId);
|
|
|
|
|
|
|
|
// Delete host image
|
|
|
|
$hostsImagesDeleted += $db->deleteHostImage($hostImage->hostImageId);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-04-09 00:06:28 +03:00
|
|
|
// Apply host pages limits
|
|
|
|
$totalHostPages = $db->getTotalHostPages($host->hostId);
|
|
|
|
|
|
|
|
if ($totalHostPages > $host->crawlPageLimit) {
|
|
|
|
|
2023-05-04 01:04:39 +03:00
|
|
|
foreach ((array) $db->getHostPagesByLimit($host->hostId, $totalHostPages - $host->crawlPageLimit) as $hostPage) {
|
|
|
|
|
|
|
|
// Delete foreign key relations
|
|
|
|
$db->deleteHostPageToHostImage($hostPage->hostPageId);
|
|
|
|
|
|
|
|
// Delete host page
|
|
|
|
$hostsPagesDeleted += $db->deleteHostPage($hostPage->hostPageId);
|
|
|
|
}
|
2023-04-09 00:06:28 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
// Apply new robots.txt rules
|
2023-05-03 04:17:58 +03:00
|
|
|
$robots = new Robots(($hostRobots ? (string) $hostRobots : (string) CRAWL_ROBOTS_DEFAULT_RULES) . PHP_EOL . ($host->robotsPostfix ? (string) $host->robotsPostfix : (string) CRAWL_ROBOTS_POSTFIX_RULES));
|
2023-04-09 00:06:28 +03:00
|
|
|
|
2023-05-06 08:45:37 +03:00
|
|
|
foreach ($db->getHostImages($host->hostId) as $hostImage) {
|
2023-05-04 01:04:39 +03:00
|
|
|
|
|
|
|
if (!$robots->uriAllowed($hostImage->uri)) {
|
|
|
|
|
|
|
|
// Delete foreign key relations
|
|
|
|
$db->deleteHostImageDescription($hostImage->hostImageId);
|
|
|
|
$db->deleteHostImageToHostPage($hostImage->hostImageId);
|
|
|
|
|
|
|
|
// Delete host image
|
|
|
|
$hostsImagesDeleted += $db->deleteHostImage($hostImage->hostImageId);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-05-06 08:45:37 +03:00
|
|
|
foreach ($db->getHostPages($host->hostId) as $hostPage) {
|
2023-04-09 00:06:28 +03:00
|
|
|
|
|
|
|
if (!$robots->uriAllowed($hostPage->uri)) {
|
|
|
|
|
2023-05-04 01:04:39 +03:00
|
|
|
// Delete foreign key relations
|
|
|
|
$db->deleteHostPageToHostImage($hostPage->hostPageId);
|
|
|
|
|
|
|
|
// Delete host page
|
2023-04-09 00:06:28 +03:00
|
|
|
$hostsPagesDeleted += $db->deleteHostPage($hostPage->hostPageId);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-05-04 01:04:39 +03:00
|
|
|
// Clean up host images unrelated to host pages
|
|
|
|
foreach ($db->getUnrelatedHostImages() as $hostImage) {
|
|
|
|
|
|
|
|
// Delete foreign key relations
|
|
|
|
$db->deleteHostImageDescription($hostImage->hostImageId);
|
|
|
|
$db->deleteHostImageToHostPage($hostImage->hostImageId);
|
|
|
|
|
|
|
|
// Delete host image
|
|
|
|
$hostsImagesDeleted += $db->deleteHostImage($hostImage->hostImageId);
|
|
|
|
}
|
2023-05-05 05:26:53 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
// Clean up deprecated manifests
|
|
|
|
foreach ($db->getManifests() as $manifest) {
|
|
|
|
|
|
|
|
$delete = false;
|
|
|
|
|
|
|
|
$curl = new Curl($manifest->url);
|
|
|
|
|
2023-05-08 08:27:21 +03:00
|
|
|
// Update curl stats
|
|
|
|
$requestsTotal++;
|
|
|
|
$requestSizeTotal += $curl->getSizeRequest();
|
|
|
|
$downloadSizeTotal += $curl->getSizeDownload();
|
|
|
|
$requestsTotalTime += $curl->getTotalTime();
|
|
|
|
|
2023-05-05 05:26:53 +03:00
|
|
|
// Skip processing non 200 code
|
|
|
|
if (200 != $curl->getCode()) {
|
|
|
|
|
|
|
|
continue; // Wait for reconnect
|
|
|
|
}
|
2023-05-04 01:04:39 +03:00
|
|
|
|
2023-05-05 05:26:53 +03:00
|
|
|
// Skip processing without returned data
|
|
|
|
if (!$remoteManifest = $curl->getContent()) {
|
2023-04-09 00:06:28 +03:00
|
|
|
|
2023-05-05 05:26:53 +03:00
|
|
|
$delete = true;
|
|
|
|
}
|
2023-04-09 00:06:28 +03:00
|
|
|
|
2023-05-05 05:26:53 +03:00
|
|
|
// Skip processing on json encoding error
|
|
|
|
if (!$remoteManifest = @json_decode($remoteManifest)) {
|
2023-04-09 00:06:28 +03:00
|
|
|
|
2023-05-05 05:26:53 +03:00
|
|
|
$delete = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Skip processing on required fields missed
|
|
|
|
if (empty($remoteManifest->status) ||
|
|
|
|
empty($remoteManifest->result->config->crawlUrlRegexp) ||
|
|
|
|
empty($remoteManifest->result->api->version)) {
|
|
|
|
|
|
|
|
$delete = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Skip processing on API version not compatible
|
|
|
|
if ($remoteManifest->result->api->version !== CRAWL_MANIFEST_API_VERSION) {
|
|
|
|
|
|
|
|
$delete = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Skip processing on crawlUrlRegexp does not match CRAWL_URL_REGEXP condition
|
|
|
|
if ($remoteManifest->result->config->crawlUrlRegexp !== CRAWL_URL_REGEXP) {
|
|
|
|
|
|
|
|
$delete = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($delete) {
|
|
|
|
|
|
|
|
$manifestsDeleted += $db->deleteManifest($manifest->manifestId);
|
|
|
|
}
|
2023-04-09 00:06:28 +03:00
|
|
|
}
|
2023-05-05 05:26:53 +03:00
|
|
|
|
2023-05-06 08:45:37 +03:00
|
|
|
// Reset banned pages
|
|
|
|
$hostPagesBansRemoved += $db->resetBannedHostPages(time() - CLEAN_PAGE_BAN_SECONDS_OFFSET);
|
|
|
|
|
|
|
|
// Reset banned images
|
|
|
|
$hostImagesBansRemoved += $db->resetBannedHostImages(time() - CLEAN_IMAGE_BAN_SECONDS_OFFSET);
|
|
|
|
|
2023-05-05 05:26:53 +03:00
|
|
|
$db->commit();
|
|
|
|
|
|
|
|
} catch(Exception $e){
|
|
|
|
|
|
|
|
var_dump($e);
|
|
|
|
|
|
|
|
$db->rollBack();
|
2023-04-09 00:06:28 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
// Debug
|
|
|
|
echo 'Hosts total: ' . $hostsTotal . PHP_EOL;
|
|
|
|
echo 'Hosts updated: ' . $hostsUpdated . PHP_EOL;
|
|
|
|
echo 'Hosts pages deleted: ' . $hostsPagesDeleted . PHP_EOL;
|
2023-05-04 01:04:39 +03:00
|
|
|
echo 'Hosts images deleted: ' . $hostsImagesDeleted . PHP_EOL;
|
2023-05-08 08:27:21 +03:00
|
|
|
|
2023-05-05 05:26:53 +03:00
|
|
|
echo 'Manifests total: ' . $manifestsTotal . PHP_EOL;
|
|
|
|
echo 'Manifests deleted: ' . $manifestsDeleted . PHP_EOL;
|
2023-05-08 08:27:21 +03:00
|
|
|
|
2023-05-06 08:45:37 +03:00
|
|
|
echo 'Host page bans removed: ' . $hostPagesBansRemoved . PHP_EOL;
|
|
|
|
echo 'Host images bans removed: ' . $hostImagesBansRemoved . PHP_EOL;
|
2023-05-08 08:27:21 +03:00
|
|
|
|
|
|
|
echo 'Requests total: ' . $requestsTotal . PHP_EOL;
|
|
|
|
echo 'Requests total size: ' . $requestSizeTotal . PHP_EOL;
|
|
|
|
echo 'Download total size: ' . $downloadSizeTotal . PHP_EOL;
|
|
|
|
echo 'Requests total time: ' . $requestsTotalTime / 1000000 . PHP_EOL;
|
|
|
|
|
|
|
|
echo 'Total time: ' . microtime(true) - $timeStart . PHP_EOL . PHP_EOL;
|