2021-12-14 18:32:47 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
declare(strict_types=1);
|
2009-01-04 11:18:37 -08:00
|
|
|
|
2023-01-10 22:44:09 +00:00
|
|
|
namespace Shimmie2;
|
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
class RemoveReportedImageEvent extends Event
|
|
|
|
{
|
2021-03-14 23:43:50 +00:00
|
|
|
public int $id;
|
2019-05-28 17:59:38 +01:00
|
|
|
|
|
|
|
public function __construct(int $id)
|
|
|
|
{
|
2020-01-26 13:19:35 +00:00
|
|
|
parent::__construct();
|
2019-05-28 17:59:38 +01:00
|
|
|
$this->id = $id;
|
|
|
|
}
|
2007-10-24 21:45:38 +00:00
|
|
|
}
|
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
class AddReportedImageEvent extends Event
|
|
|
|
{
|
2021-03-14 23:43:50 +00:00
|
|
|
public ImageReport $report;
|
2016-07-30 15:04:34 +01:00
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
public function __construct(ImageReport $report)
|
|
|
|
{
|
2020-01-26 13:19:35 +00:00
|
|
|
parent::__construct();
|
2019-05-28 17:59:38 +01:00
|
|
|
$this->report = $report;
|
|
|
|
}
|
2016-07-30 15:04:34 +01:00
|
|
|
}
|
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
class ImageReport
|
|
|
|
{
|
2021-03-14 23:43:50 +00:00
|
|
|
public int $user_id;
|
|
|
|
public int $image_id;
|
|
|
|
public string $reason;
|
2019-05-28 17:59:38 +01:00
|
|
|
|
|
|
|
public function __construct(int $image_id, int $user_id, string $reason)
|
|
|
|
{
|
|
|
|
$this->image_id = $image_id;
|
|
|
|
$this->user_id = $user_id;
|
|
|
|
$this->reason = $reason;
|
|
|
|
}
|
2007-10-24 21:45:38 +00:00
|
|
|
}
|
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
class ReportImage extends Extension
|
|
|
|
{
|
2020-02-04 00:46:36 +00:00
|
|
|
/** @var ReportImageTheme */
|
2023-06-27 15:56:49 +01:00
|
|
|
protected Themelet $theme;
|
2020-02-04 00:46:36 +00:00
|
|
|
|
2024-01-15 11:52:35 +00:00
|
|
|
public function onPageRequest(PageRequestEvent $event): void
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
|
|
|
global $page, $user;
|
|
|
|
if ($event->page_matches("image_report")) {
|
|
|
|
if ($event->get_arg(0) == "add") {
|
|
|
|
if (!empty($_POST['image_id']) && !empty($_POST['reason'])) {
|
|
|
|
$image_id = int_escape($_POST['image_id']);
|
|
|
|
send_event(new AddReportedImageEvent(new ImageReport($image_id, $user->id, $_POST['reason'])));
|
2019-06-18 20:58:28 -05:00
|
|
|
$page->set_mode(PageMode::REDIRECT);
|
2019-05-28 17:59:38 +01:00
|
|
|
$page->set_redirect(make_link("post/view/$image_id"));
|
|
|
|
} else {
|
2020-10-26 10:21:35 -05:00
|
|
|
$this->theme->display_error(500, "Missing input", "Missing post ID or report reason");
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
|
|
|
} elseif ($event->get_arg(0) == "remove") {
|
|
|
|
if (!empty($_POST['id'])) {
|
2019-07-09 09:10:21 -05:00
|
|
|
if ($user->can(Permissions::VIEW_IMAGE_REPORT)) {
|
2020-01-26 22:58:59 +00:00
|
|
|
send_event(new RemoveReportedImageEvent(int_escape($_POST['id'])));
|
2019-06-18 20:58:28 -05:00
|
|
|
$page->set_mode(PageMode::REDIRECT);
|
2019-05-28 17:59:38 +01:00
|
|
|
$page->set_redirect(make_link("image_report/list"));
|
|
|
|
}
|
|
|
|
} else {
|
2020-10-26 10:21:35 -05:00
|
|
|
$this->theme->display_error(500, "Missing input", "Missing post ID");
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
|
|
|
} elseif ($event->get_arg(0) == "remove_reports_by" && $user->check_auth_token()) {
|
2019-07-09 09:10:21 -05:00
|
|
|
if ($user->can(Permissions::VIEW_IMAGE_REPORT)) {
|
2019-05-28 17:59:38 +01:00
|
|
|
$this->delete_reports_by(int_escape($_POST['user_id']));
|
2019-06-18 20:58:28 -05:00
|
|
|
$page->set_mode(PageMode::REDIRECT);
|
2019-05-28 17:59:38 +01:00
|
|
|
$page->set_redirect(make_link());
|
|
|
|
}
|
|
|
|
} elseif ($event->get_arg(0) == "list") {
|
2019-07-09 09:10:21 -05:00
|
|
|
if ($user->can(Permissions::VIEW_IMAGE_REPORT)) {
|
2019-05-28 17:59:38 +01:00
|
|
|
$this->theme->display_reported_images($page, $this->get_reported_images());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-01-15 11:52:35 +00:00
|
|
|
public function onAddReportedImage(AddReportedImageEvent $event): void
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
2019-10-02 10:49:32 +01:00
|
|
|
global $cache, $database;
|
2020-10-09 13:47:42 +01:00
|
|
|
log_info("report_image", "Adding report of >>{$event->report->image_id} with reason '{$event->report->reason}'");
|
2020-10-25 21:34:52 +00:00
|
|
|
$database->execute(
|
2019-05-28 17:59:38 +01:00
|
|
|
"INSERT INTO image_reports(image_id, reporter_id, reason)
|
2019-11-27 11:22:46 +00:00
|
|
|
VALUES (:image_id, :reporter_id, :reason)",
|
2023-11-11 21:49:12 +00:00
|
|
|
['image_id' => $event->report->image_id, 'reporter_id' => $event->report->user_id, 'reason' => $event->report->reason]
|
2019-05-28 17:59:38 +01:00
|
|
|
);
|
2019-10-02 10:49:32 +01:00
|
|
|
$cache->delete("image-report-count");
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
|
|
|
|
2024-01-15 11:52:35 +00:00
|
|
|
public function onRemoveReportedImage(RemoveReportedImageEvent $event): void
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
2019-10-02 10:49:32 +01:00
|
|
|
global $cache, $database;
|
2023-11-11 21:49:12 +00:00
|
|
|
$database->execute("DELETE FROM image_reports WHERE id = :id", ["id" => $event->id]);
|
2019-10-02 10:49:32 +01:00
|
|
|
$cache->delete("image-report-count");
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
|
|
|
|
2024-01-15 11:52:35 +00:00
|
|
|
public function onUserPageBuilding(UserPageBuildingEvent $event): void
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
|
|
|
global $user;
|
2019-07-09 09:10:21 -05:00
|
|
|
if ($user->can(Permissions::VIEW_IMAGE_REPORT)) {
|
2019-05-28 17:59:38 +01:00
|
|
|
$this->theme->get_nuller($event->display_user);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-01-15 11:52:35 +00:00
|
|
|
public function onDisplayingImage(DisplayingImageEvent $event): void
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
|
|
|
global $user;
|
2019-07-09 09:10:21 -05:00
|
|
|
if ($user->can(Permissions::CREATE_IMAGE_REPORT)) {
|
2019-05-28 17:59:38 +01:00
|
|
|
$reps = $this->get_reports($event->image);
|
|
|
|
$this->theme->display_image_banner($event->image, $reps);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-08-02 14:54:48 -05:00
|
|
|
|
2024-01-15 11:52:35 +00:00
|
|
|
public function onPageSubNavBuilding(PageSubNavBuildingEvent $event): void
|
2019-08-02 14:54:48 -05:00
|
|
|
{
|
|
|
|
global $user;
|
2023-11-11 21:49:12 +00:00
|
|
|
if ($event->parent === "system") {
|
2019-08-02 14:54:48 -05:00
|
|
|
if ($user->can(Permissions::VIEW_IMAGE_REPORT)) {
|
|
|
|
$count = $this->count_reported_images();
|
|
|
|
$h_count = $count > 0 ? " ($count)" : "";
|
|
|
|
|
2020-10-26 10:21:35 -05:00
|
|
|
$event->add_nav_link("image_report", new Link('image_report/list'), "Reported Posts$h_count");
|
2019-08-02 14:54:48 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-01-15 11:52:35 +00:00
|
|
|
public function onUserBlockBuilding(UserBlockBuildingEvent $event): void
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
|
|
|
global $user;
|
2019-07-09 09:10:21 -05:00
|
|
|
if ($user->can(Permissions::VIEW_IMAGE_REPORT)) {
|
2019-05-28 17:59:38 +01:00
|
|
|
$count = $this->count_reported_images();
|
|
|
|
$h_count = $count > 0 ? " ($count)" : "";
|
2020-10-26 10:21:35 -05:00
|
|
|
$event->add_link("Reported Posts$h_count", make_link("image_report/list"));
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-01-15 11:52:35 +00:00
|
|
|
public function onImageDeletion(ImageDeletionEvent $event): void
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
2019-10-02 10:49:32 +01:00
|
|
|
global $cache, $database;
|
2023-11-11 21:49:12 +00:00
|
|
|
$database->execute("DELETE FROM image_reports WHERE image_id = :image_id", ["image_id" => $event->image->id]);
|
2019-10-02 10:49:32 +01:00
|
|
|
$cache->delete("image-report-count");
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
|
|
|
|
2024-01-15 11:52:35 +00:00
|
|
|
public function onUserDeletion(UserDeletionEvent $event): void
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
|
|
|
$this->delete_reports_by($event->id);
|
|
|
|
}
|
|
|
|
|
2024-01-15 11:52:35 +00:00
|
|
|
public function onSetupBuilding(SetupBuildingEvent $event): void
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
2020-10-26 10:13:28 -05:00
|
|
|
$sb = $event->panel->create_new_block("Post Reports");
|
2019-05-28 17:59:38 +01:00
|
|
|
|
|
|
|
$opts = [
|
|
|
|
"Reporter Only" => "user",
|
|
|
|
"Reason Only" => "reason",
|
|
|
|
"Both" => "both",
|
|
|
|
"None" => "none",
|
|
|
|
];
|
|
|
|
$sb->add_choice_option("report_image_publicity", $opts, "Show publicly: ");
|
|
|
|
}
|
|
|
|
|
|
|
|
public function delete_reports_by(int $user_id)
|
|
|
|
{
|
2019-10-02 10:49:32 +01:00
|
|
|
global $cache, $database;
|
2023-11-11 21:49:12 +00:00
|
|
|
$database->execute("DELETE FROM image_reports WHERE reporter_id=:reporter_id", ['reporter_id' => $user_id]);
|
2019-10-02 10:49:32 +01:00
|
|
|
$cache->delete("image-report-count");
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
|
|
|
|
2024-01-15 11:52:35 +00:00
|
|
|
public function onDatabaseUpgrade(DatabaseUpgradeEvent $event): void
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
2020-01-26 13:19:35 +00:00
|
|
|
global $database;
|
2019-05-28 17:59:38 +01:00
|
|
|
|
2019-11-03 19:49:52 +00:00
|
|
|
if ($this->get_version("ext_report_image_version") < 1) {
|
2019-05-28 17:59:38 +01:00
|
|
|
$database->create_table("image_reports", "
|
2009-01-22 04:05:55 -08:00
|
|
|
id SCORE_AIPK,
|
2009-01-22 05:03:51 -08:00
|
|
|
image_id INTEGER NOT NULL,
|
|
|
|
reporter_id INTEGER NOT NULL,
|
|
|
|
reason TEXT NOT NULL,
|
|
|
|
FOREIGN KEY (image_id) REFERENCES images(id) ON DELETE CASCADE,
|
|
|
|
FOREIGN KEY (reporter_id) REFERENCES users(id) ON DELETE CASCADE
|
2009-01-22 04:05:55 -08:00
|
|
|
");
|
2019-11-03 19:49:52 +00:00
|
|
|
$this->set_version("ext_report_image_version", 1);
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2024-01-06 21:28:06 +00:00
|
|
|
* @return ImageReport[]
|
2019-05-28 17:59:38 +01:00
|
|
|
*/
|
|
|
|
public function get_reports(Image $image): array
|
|
|
|
{
|
|
|
|
global $database;
|
|
|
|
|
|
|
|
$rows = $database->get_all("
|
2016-07-30 15:04:34 +01:00
|
|
|
SELECT *
|
2012-02-12 06:41:10 +00:00
|
|
|
FROM image_reports
|
|
|
|
WHERE image_reports.image_id = :image_id
|
2019-05-28 17:59:38 +01:00
|
|
|
", ["image_id" => $image->id]);
|
|
|
|
$reps = [];
|
|
|
|
foreach ($rows as $row) {
|
|
|
|
$reps[] = new ImageReport($row["image_id"], $row["reporter_id"], $row["reason"]);
|
|
|
|
}
|
|
|
|
return $reps;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function get_reported_images(): array
|
|
|
|
{
|
|
|
|
global $database;
|
|
|
|
|
|
|
|
$all_reports = $database->get_all("
|
2008-08-12 02:37:48 +00:00
|
|
|
SELECT image_reports.*, users.name AS reporter_name
|
|
|
|
FROM image_reports
|
2018-11-10 12:03:05 +00:00
|
|
|
JOIN users ON reporter_id = users.id
|
|
|
|
ORDER BY image_reports.id DESC");
|
2019-05-28 17:59:38 +01:00
|
|
|
if (is_null($all_reports)) {
|
|
|
|
$all_reports = [];
|
|
|
|
}
|
|
|
|
|
|
|
|
$reports = [];
|
|
|
|
foreach ($all_reports as $report) {
|
2020-01-26 19:44:36 +00:00
|
|
|
$image_id = (int)$report['image_id'];
|
2019-05-28 17:59:38 +01:00
|
|
|
$image = Image::by_id($image_id);
|
|
|
|
if (is_null($image)) {
|
2020-01-26 19:44:36 +00:00
|
|
|
send_event(new RemoveReportedImageEvent((int)$report['id']));
|
2019-05-28 17:59:38 +01:00
|
|
|
continue;
|
|
|
|
}
|
|
|
|
$report['image'] = $image;
|
|
|
|
$reports[] = $report;
|
|
|
|
}
|
|
|
|
|
|
|
|
return $reports;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function count_reported_images(): int
|
|
|
|
{
|
2023-12-14 17:06:54 +00:00
|
|
|
global $database;
|
2019-05-28 17:59:38 +01:00
|
|
|
|
2023-12-14 17:06:54 +00:00
|
|
|
return (int)cache_get_or_set(
|
|
|
|
"image-report-count",
|
|
|
|
fn () => $database->get_one("SELECT count(*) FROM image_reports"),
|
|
|
|
600
|
|
|
|
);
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
2007-10-24 21:45:38 +00:00
|
|
|
}
|