2021-12-14 18:32:47 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
declare(strict_types=1);
|
2018-07-19 19:55:28 +01:00
|
|
|
|
2023-01-10 22:44:09 +00:00
|
|
|
namespace Shimmie2;
|
|
|
|
|
2024-01-11 00:55:05 +00:00
|
|
|
use Symfony\Component\Console\Command\Command;
|
|
|
|
|
|
|
|
use Symfony\Component\Console\Input\{InputInterface,InputArgument};
|
|
|
|
use Symfony\Component\Console\Output\OutputInterface;
|
|
|
|
|
2023-08-17 18:09:38 +01:00
|
|
|
if (
|
|
|
|
// kill these glitched requests immediately
|
2020-01-26 16:43:41 +00:00
|
|
|
!empty($_SERVER["REQUEST_URI"])
|
2020-10-25 19:31:58 +00:00
|
|
|
&& str_contains(@$_SERVER["REQUEST_URI"], "/http")
|
|
|
|
&& str_contains(@$_SERVER["REQUEST_URI"], "paheal.net")
|
2019-05-28 17:59:38 +01:00
|
|
|
) {
|
|
|
|
die("No");
|
|
|
|
}
|
|
|
|
|
|
|
|
class Rule34 extends Extension
|
|
|
|
{
|
2024-01-15 11:52:35 +00:00
|
|
|
public function onImageDeletion(ImageDeletionEvent $event): void
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
|
|
|
global $database;
|
2020-10-03 12:54:27 +00:00
|
|
|
$database->notify("shm_image_bans", $event->image->hash);
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
|
|
|
|
2024-01-15 11:52:35 +00:00
|
|
|
public function onImageInfoSet(ImageInfoSetEvent $event): void
|
2020-02-08 00:24:13 +00:00
|
|
|
{
|
|
|
|
global $cache;
|
|
|
|
$cache->delete("thumb-block:{$event->image->id}");
|
|
|
|
}
|
|
|
|
|
2024-01-15 11:52:35 +00:00
|
|
|
public function onAdminBuilding(AdminBuildingEvent $event): void
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
|
|
|
global $page;
|
|
|
|
$html = make_form(make_link("admin/cache_purge"), "POST");
|
|
|
|
$html .= "<textarea type='text' name='hash' placeholder='Enter image URL or hash' cols='80' rows='5'></textarea>";
|
|
|
|
$html .= "<br><input type='submit' value='Purge from caches'>";
|
|
|
|
$html .= "</form>\n";
|
|
|
|
$page->add_block(new Block("Cache Purger", $html));
|
|
|
|
}
|
|
|
|
|
2024-01-15 11:52:35 +00:00
|
|
|
public function onCliGen(CliGenEvent $event): void
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
2024-01-11 00:55:05 +00:00
|
|
|
$event->app->register('wipe-thumb-cache')
|
|
|
|
->addArgument('tags', InputArgument::REQUIRED)
|
|
|
|
->setDescription('Delete cached thumbnails for images matching the given tags')
|
|
|
|
->setCode(function (InputInterface $input, OutputInterface $output): int {
|
|
|
|
global $cache;
|
|
|
|
$tags = Tag::explode($input->getArgument('tags'));
|
|
|
|
foreach (Search::find_images_iterable(0, null, $tags) as $image) {
|
2024-01-19 18:38:18 +00:00
|
|
|
$output->writeln((string)$image->id);
|
2024-01-11 00:55:05 +00:00
|
|
|
$cache->delete("thumb-block:{$image->id}");
|
|
|
|
}
|
|
|
|
return Command::SUCCESS;
|
|
|
|
});
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
|
|
|
|
2024-01-15 11:52:35 +00:00
|
|
|
public function onSourceSet(SourceSetEvent $event): void
|
2019-08-27 00:09:35 +01:00
|
|
|
{
|
|
|
|
// Maybe check for 404?
|
|
|
|
if (empty($event->source)) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (!preg_match("/^(https?:\/\/)?[a-zA-Z0-9\.\-]+(\/.*)?$/", $event->source)) {
|
|
|
|
throw new SCoreException("Invalid source URL");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-01-15 11:52:35 +00:00
|
|
|
public function onRobotsBuilding(RobotsBuildingEvent $event): void
|
2023-03-30 20:36:58 +01:00
|
|
|
{
|
|
|
|
// robots should only check the canonical site, not mirrors
|
|
|
|
if ($_SERVER['HTTP_HOST'] != "rule34.paheal.net") {
|
|
|
|
$event->add_disallow("");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-01-15 11:52:35 +00:00
|
|
|
public function onPageRequest(PageRequestEvent $event): void
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
|
|
|
global $database, $page, $user;
|
|
|
|
|
2023-02-12 12:26:55 +00:00
|
|
|
# Database might not be connected at this point...
|
2023-06-25 13:39:03 +01:00
|
|
|
#$database->set_timeout(null); // deleting users can take a while
|
2019-05-28 17:59:38 +01:00
|
|
|
|
2023-12-26 13:08:50 +00:00
|
|
|
$page->add_html_header("<meta name='theme-color' content='#7EB977'>");
|
|
|
|
$page->add_html_header("<meta name='juicyads-site-verification' content='20d309e193510e130c3f8a632f281335'>");
|
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
if ($event->page_matches("tnc_agreed")) {
|
|
|
|
setcookie("ui-tnc-agreed", "true", 0, "/");
|
2019-06-18 20:58:28 -05:00
|
|
|
$page->set_mode(PageMode::REDIRECT);
|
2020-03-27 19:41:34 +00:00
|
|
|
$page->set_redirect(referer_or("/"));
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if ($event->page_matches("admin/cache_purge")) {
|
2019-07-09 09:10:21 -05:00
|
|
|
if (!$user->can(Permissions::MANAGE_ADMINTOOLS)) {
|
2019-05-28 17:59:38 +01:00
|
|
|
$this->theme->display_permission_denied();
|
|
|
|
} else {
|
|
|
|
if ($user->check_auth_token()) {
|
|
|
|
$all = $_POST["hash"];
|
|
|
|
$matches = [];
|
|
|
|
if (preg_match_all("/([a-fA-F0-9]{32})/", $all, $matches)) {
|
|
|
|
$matches = $matches[0];
|
|
|
|
foreach ($matches as $hash) {
|
2019-12-15 19:47:18 +00:00
|
|
|
$page->flash("Cleaning {$hash}");
|
2019-05-28 17:59:38 +01:00
|
|
|
if (strlen($hash) != 32) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
log_info("admin", "Cleaning {$hash}");
|
2019-06-15 11:18:52 -05:00
|
|
|
@unlink(warehouse_path(Image::IMAGE_DIR, $hash));
|
|
|
|
@unlink(warehouse_path(Image::THUMBNAIL_DIR, $hash));
|
2020-10-03 12:54:27 +00:00
|
|
|
$database->notify("shm_image_bans", $hash);
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-06-18 20:58:28 -05:00
|
|
|
$page->set_mode(PageMode::REDIRECT);
|
2019-06-14 13:16:58 +01:00
|
|
|
$page->set_redirect(make_link("admin"));
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2018-07-19 19:55:28 +01:00
|
|
|
}
|