2007-10-22 00:13:57 +00:00
|
|
|
<?php
|
2009-08-20 23:37:17 +01:00
|
|
|
/*
|
2007-10-22 00:13:57 +00:00
|
|
|
* Name: Image Hash Ban
|
2007-12-04 18:20:46 +00:00
|
|
|
* Author: ATravelingGeek <atg@atravelinggeek.com>
|
2007-10-22 00:13:57 +00:00
|
|
|
* Link: http://atravelinggeek.com/
|
|
|
|
* License: GPLv2
|
|
|
|
* Description: Ban images based on their hash
|
|
|
|
* Based on the ResolutionLimit and IPban extensions by Shish
|
2009-08-20 23:37:17 +01:00
|
|
|
* Version 0.1, October 21, 2007
|
2007-10-22 00:13:57 +00:00
|
|
|
*/
|
2009-01-04 11:18:37 -08:00
|
|
|
|
2007-10-22 00:13:57 +00:00
|
|
|
// RemoveImageHashBanEvent {{{
|
|
|
|
class RemoveImageHashBanEvent extends Event {
|
|
|
|
var $hash;
|
|
|
|
|
|
|
|
public function RemoveImageHashBanEvent($hash) {
|
|
|
|
$this->hash = $hash;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// }}}
|
|
|
|
// AddImageHashBanEvent {{{
|
2009-01-04 11:18:37 -08:00
|
|
|
class AddImageHashBanEvent extends Event {
|
2007-10-22 00:13:57 +00:00
|
|
|
var $hash;
|
|
|
|
var $reason;
|
|
|
|
|
|
|
|
public function AddImageHashBanEvent($hash, $reason) {
|
|
|
|
$this->hash = $hash;
|
|
|
|
$this->reason = $reason;
|
|
|
|
}
|
|
|
|
}
|
2008-04-06 16:43:09 +00:00
|
|
|
// }}}
|
2010-05-28 13:36:36 +01:00
|
|
|
class ImageBan extends SimpleExtension {
|
2010-05-28 02:07:33 +01:00
|
|
|
public function onInitExt(InitExtEvent $event) {
|
|
|
|
global $config, $database;
|
|
|
|
if($config->get_int("ext_imageban_version") < 1) {
|
|
|
|
$database->create_table("image_bans", "
|
|
|
|
id SCORE_AIPK,
|
|
|
|
hash CHAR(32) NOT NULL,
|
|
|
|
date DATETIME DEFAULT SCORE_NOW,
|
|
|
|
reason TEXT NOT NULL
|
|
|
|
");
|
|
|
|
$config->set_int("ext_imageban_version", 1);
|
2007-10-22 00:13:57 +00:00
|
|
|
}
|
2010-05-28 02:07:33 +01:00
|
|
|
}
|
2008-04-06 16:47:05 +00:00
|
|
|
|
2010-05-28 02:07:33 +01:00
|
|
|
public function onDataUpload(DataUploadEvent $event) {
|
|
|
|
global $database;
|
|
|
|
$row = $database->db->GetRow("SELECT * FROM image_bans WHERE hash = ?", $event->hash);
|
|
|
|
if($row) {
|
|
|
|
log_info("image_hash_ban", "Blocked image ({$event->hash})");
|
|
|
|
throw new UploadException("Image ".html_escape($row["hash"])." has been banned, reason: ".format_text($row["reason"]));
|
2007-10-22 00:13:57 +00:00
|
|
|
}
|
2010-05-28 02:07:33 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public function onPageRequest(PageRequestEvent $event) {
|
|
|
|
global $config, $database, $page, $user;
|
2008-04-06 16:47:05 +00:00
|
|
|
|
2010-05-28 02:07:33 +01:00
|
|
|
if($event->page_matches("image_hash_ban")) {
|
2009-05-11 07:04:33 -07:00
|
|
|
if($user->is_admin()) {
|
2007-10-22 00:13:57 +00:00
|
|
|
if($event->get_arg(0) == "add") {
|
|
|
|
if(isset($_POST['hash']) && isset($_POST['reason'])) {
|
|
|
|
send_event(new AddImageHashBanEvent($_POST['hash'], $_POST['reason']));
|
|
|
|
|
|
|
|
$page->set_mode("redirect");
|
2009-05-11 07:48:18 -07:00
|
|
|
$page->set_redirect(make_link("image_hash_ban/list/1"));
|
2007-10-22 00:13:57 +00:00
|
|
|
}
|
2008-07-27 15:55:45 +00:00
|
|
|
if(isset($_POST['image_id'])) {
|
2009-05-11 07:04:33 -07:00
|
|
|
$image = Image::by_id(int_escape($_POST['image_id']));
|
2008-07-27 15:55:45 +00:00
|
|
|
if($image) {
|
|
|
|
send_event(new ImageDeletionEvent($image));
|
2009-05-11 07:04:33 -07:00
|
|
|
$page->set_mode("redirect");
|
|
|
|
$page->set_redirect(make_link("post/list"));
|
2008-07-27 15:55:45 +00:00
|
|
|
}
|
|
|
|
}
|
2007-10-22 00:13:57 +00:00
|
|
|
}
|
|
|
|
else if($event->get_arg(0) == "remove") {
|
|
|
|
if(isset($_POST['hash'])) {
|
|
|
|
send_event(new RemoveImageHashBanEvent($_POST['hash']));
|
|
|
|
|
|
|
|
$page->set_mode("redirect");
|
2009-05-11 07:48:18 -07:00
|
|
|
$page->set_redirect(make_link("image_hash_ban/list/1"));
|
2007-10-22 00:13:57 +00:00
|
|
|
}
|
|
|
|
}
|
2008-12-12 19:23:42 +00:00
|
|
|
else if($event->get_arg(0) == "list") {
|
2008-12-14 15:57:26 -08:00
|
|
|
$page_num = 0;
|
|
|
|
if($event->count_args() == 2) {
|
|
|
|
$page_num = int_escape($event->get_arg(1));
|
|
|
|
}
|
2010-01-05 17:31:25 +00:00
|
|
|
$page_size = 100;
|
|
|
|
$page_count = ceil($database->db->getone("SELECT COUNT(id) FROM image_bans")/$page_size);
|
|
|
|
$this->theme->display_Image_hash_Bans($page, $page_num, $page_count, $this->get_image_hash_bans($page_num, $page_size));
|
2008-12-12 19:23:42 +00:00
|
|
|
}
|
2007-10-22 00:13:57 +00:00
|
|
|
}
|
|
|
|
}
|
2010-05-28 02:07:33 +01:00
|
|
|
}
|
2008-04-06 16:47:05 +00:00
|
|
|
|
2010-05-28 02:07:33 +01:00
|
|
|
public function onUserBlockBuilding(UserBlockBuildingEvent $event) {
|
|
|
|
global $user;
|
|
|
|
if($user->is_admin()) {
|
|
|
|
$event->add_link("Image Bans", make_link("image_hash_ban/list/1"));
|
2007-10-22 00:13:57 +00:00
|
|
|
}
|
2010-05-28 02:07:33 +01:00
|
|
|
}
|
2007-10-22 00:13:57 +00:00
|
|
|
|
2010-05-28 02:07:33 +01:00
|
|
|
public function onAddImageHashBan(AddImageHashBanEvent $event) {
|
|
|
|
$this->add_image_hash_ban($event->hash, $event->reason);
|
|
|
|
}
|
2008-04-06 16:47:05 +00:00
|
|
|
|
2010-05-28 02:07:33 +01:00
|
|
|
public function onRemoveImageHashBan(RemoveImageHashBanEvent $event) {
|
|
|
|
$this->remove_image_hash_ban($event->hash);
|
2007-10-22 00:13:57 +00:00
|
|
|
}
|
2008-04-06 16:47:05 +00:00
|
|
|
|
2010-05-28 02:07:33 +01:00
|
|
|
public function onImageAdminBlockBuilding(ImageAdminBlockBuildingEvent $event) {
|
|
|
|
global $user;
|
|
|
|
if($user->is_admin()) {
|
|
|
|
$event->add_part($this->theme->get_buttons_html($event->image));
|
|
|
|
}
|
2007-10-22 00:13:57 +00:00
|
|
|
}
|
2008-04-06 16:47:05 +00:00
|
|
|
|
2007-10-22 00:13:57 +00:00
|
|
|
// DB funness
|
2008-04-06 16:47:05 +00:00
|
|
|
|
2010-01-05 17:31:25 +00:00
|
|
|
public function get_image_hash_bans($page, $size=100) {
|
2007-10-22 00:13:57 +00:00
|
|
|
// FIXME: many
|
2008-12-14 15:57:26 -08:00
|
|
|
$size_i = int_escape($size);
|
2009-01-14 23:25:50 +00:00
|
|
|
$offset_i = int_escape($page-1)*$size_i;
|
2007-10-22 00:13:57 +00:00
|
|
|
global $database;
|
2009-01-14 23:25:50 +00:00
|
|
|
$bans = $database->get_all("SELECT * FROM image_bans ORDER BY id DESC LIMIT $size_i OFFSET $offset_i");
|
2007-10-22 00:13:57 +00:00
|
|
|
if($bans) {return $bans;}
|
|
|
|
else {return array();}
|
|
|
|
}
|
|
|
|
|
|
|
|
public function add_image_hash_ban($hash, $reason) {
|
|
|
|
global $database;
|
|
|
|
$database->Execute(
|
|
|
|
"INSERT INTO image_bans (hash, reason, date) VALUES (?, ?, now())",
|
|
|
|
array($hash, $reason));
|
|
|
|
}
|
|
|
|
|
|
|
|
public function remove_image_hash_ban($hash) {
|
|
|
|
global $database;
|
|
|
|
$database->Execute("DELETE FROM image_bans WHERE hash = ?", array($hash));
|
|
|
|
}
|
2008-04-06 16:47:05 +00:00
|
|
|
|
2010-05-28 02:07:33 +01:00
|
|
|
// in before resolution limit plugin
|
|
|
|
public function get_priority() {return 30;}
|
2007-10-22 00:13:57 +00:00
|
|
|
}
|
2007-12-04 18:20:46 +00:00
|
|
|
?>
|