<?php
/*
 * Name: Report Images
 * Author: ATravelingGeek <atg@atravelinggeek.com>
 * Link: http://atravelinggeek.com/
 * License: GPLv2
 * Description: Report images as dupes/illegal/etc
 * Version 0.3a - See changelog in main.php
 * November 06, 2007
 *
 * NOTE: This is for Shimmie2 SVN Trunk. Use the other main.php.use... for Shimmie2 RCx.
 *
 */
 
class RemoveReportedImageEvent extends Event {
	var $id;

	public function RemoveReportedImageEvent($id) {
		$this->id = $id;
	}
}

class AddReportedImageEvent extends Event { 
	var $reporter_name;
	var $image_id;
	var $reason_type;
	var $reason;
	public function AddReportedImageEvent($image_id, $reporter_name, $reason_type, $reason) {
		$this->reporter_name = $reporter_name;
		$this->image_id = $image_id;
		$this->reason_type = $reason_type;
		$this->reason = $reason;
	}
}

class report_image extends Extension {
	var $theme;
	
	public function receive_event($event) {
	
	if(is_null($this->theme)) $this->theme = get_theme_object("report_image", "ReportImageTheme");
	
	if(is_a($event, 'InitExtEvent')) {
			global $config;
			if($config->get_int("ext_ReportImage_version") < 1) {
				$this->install();
			}
		}
		
		if(is_a($event, 'PageRequestEvent') && ($event->page_name == "ReportImage")) {
			global $user;
				if($event->get_arg(0) == "add") {
					if(isset($_POST['image_id']) && isset($_POST['reason_type']) && isset($_POST['reason'])) {
						send_event(new AddReportedImageEvent($_POST['image_id'], $event->user->name, $_POST['reason_type'], $_POST['reason']));
						global $page;
						$page->set_mode("redirect");
						$page->set_redirect(make_link("post/view/".int_escape($_POST['image_id'])));
					}
				}
				else if($event->get_arg(0) == "remove") {
					if(isset($_POST['id'])) {
						if($event->user->is_admin()) {
							send_event(new RemoveReportedImageEvent($_POST['id']));
							global $page;
							$page->set_mode("redirect");
							$page->set_redirect(make_link("ReportImage/list"));
						}
					}
				}
				else if($event->get_arg(0) == "list") {
					if($event->user->is_admin()) {
						global $page;
						$this->theme->display_reported_images($page, $this->get_reported_images());
					}
				}
		}
		
//		if(is_a($event, 'AdminBuildingEvent')) {
//			global $page;
//			$this->theme->display_reported_images($page, $this->get_reported_images());
//		}
		
		if(is_a($event, 'AddReportedImageEvent')) {
			$this->add_reported_image($event->image_id, $event->reporter_name, $event->reason_type, $event->reason);
		}

		if(is_a($event, 'RemoveReportedImageEvent')) {
			$this->remove_reported_image($event->id);
		}
		
		if(is_a($event, 'DisplayingImageEvent')) {
			global $user;
			global $config;
			if(!$config->get_bool('report_image_anon') && $user->is_anonymous()) {
				// Show nothing
			} else {
				$this->theme->display_image_banner($event->page, $event->image->id);
			}
		}

		if(is_a($event, 'SetupBuildingEvent')) {
			$sb = new SetupBlock("Report Image Options");
			$sb->add_bool_option("report_image_anon", "Allow anonymous image reporting: ");
			$sb->add_label("<br>");
			$sb->add_bool_option("report_image_show_thumbs", "Show thumbnails in admin panel: ");
			$event->panel->add_block($sb);
		}
		
		if(is_a($event, 'UserBlockBuildingEvent')) {
			if($event->user->is_admin()) {
				$event->add_link("Reported Images", make_link("ReportImage/list"));
			}
		}
		
	}
	
	protected function install() {
		global $database;
		global $config;
		if($config->get_int("ext_ReportImage_version") < 1) {
			$database->Execute("CREATE TABLE ReportImage (
				id int(11) NOT NULL auto_increment,
				image_id int(11) default NULL,
				reporter_name varchar(32) default NULL,
				reason_type varchar(255) default NULL,
				reason varchar(255) default NULL,
				PRIMARY KEY (id)
			)");
			$config->set_int("ext_ReportImage_version", 1);
		}
	}

	
	// DB funness
	
		public function get_reported_images() {
		// FIXME: many
		global $database;
		$reportedimages = $database->get_all("SELECT * FROM ReportImage");
		if($reportedimages) {return $reportedimages;}
		else {return array();}
		}
		
		public function get_reported_image($id) {
		global $database;
		return $database->db->GetRow("SELECT * FROM ReportImage WHERE id = ?", array($id));
	}

	public function add_reported_image($image_id, $reporter_name, $reason_type, $reason) {
		global $database;
		$database->Execute(
				"INSERT INTO ReportImage (image_id, reporter_name, reason_type, reason) VALUES (?, ?, ?, ?)",
				array($image_id, $reporter_name, $reason_type, $reason));
	}

	public function remove_reported_image($id) {
		global $database;
		$database->Execute("DELETE FROM ReportImage WHERE id = ?", array($id));
	}
		
}
add_event_listener(new report_image(), 29); // Not sure what I'm in before.

//  ===== Changelog =====
// * Version 0.3a / 0.3a_rc - 11/06/07 - I can no longer use the same theme.php file for both SVN and RCx. Sorry.
// *   Same deal with theme.php as it is with main.php
// * Version 0.3 / 0.3_rc - 11/06/07 - Added the option to display thumbnails, moved the reported image list to it's
//     own page, and checked to make sure the user is an admin before letting them delete / view reported images.
// * Version 0.2c_rc2 - 10/27/07 - Now (really!) supports Shimmie2 RC2!
// * Version 0.2b - 10/27/07 - Now supports Shimmie2 RC2!
// * Version 0.2a - 10/24/07 - Fixed some SQL issues. I will make sure to test before commiting :)
// * Version 0.2 - 10/24/07 - First public release.

?>