This repository has been archived on 2024-09-05. You can view files and clone it, but cannot push or open issues or pull requests.
shimmie2/contrib/pools/main.php

687 lines
19 KiB
PHP
Raw Normal View History

2009-12-24 07:36:09 +00:00
<?php
/**
2009-12-30 08:09:31 +00:00
* Name: Pools System
2009-12-24 07:36:09 +00:00
* Author: Sein Kraft <mail@seinkraft.info>
* License: GPLv2
2009-12-30 08:09:31 +00:00
* Description: Allow users to create groups of images
2009-12-24 07:36:09 +00:00
* Documentation:
*/
2010-05-04 20:10:37 +01:00
class PoolCreationException extends SCoreException {
}
2009-12-24 07:36:09 +00:00
class Pools extends SimpleExtension {
public function onInitExt($event) {
2009-12-25 23:05:57 +00:00
global $config, $database;
if ($config->get_int("ext_pools_version") < 1){
2009-12-24 07:36:09 +00:00
$database->create_table("pools", "
2009-12-25 23:05:57 +00:00
id SCORE_AIPK,
user_id INTEGER NOT NULL,
public SCORE_BOOL NOT NULL DEFAULT SCORE_BOOL_N,
title VARCHAR(255) NOT NULL,
description TEXT,
date DATETIME NOT NULL,
posts INTEGER NOT NULL DEFAULT 0,
INDEX (id)
");
2009-12-24 07:36:09 +00:00
$database->create_table("pool_images", "
2009-12-25 23:05:57 +00:00
pool_id INTEGER NOT NULL,
image_id INTEGER NOT NULL,
image_order INTEGER NOT NULL DEFAULT 0
");
2009-12-24 07:36:09 +00:00
$database->create_table("pool_history", "
2009-12-25 23:05:57 +00:00
id SCORE_AIPK,
pool_id INTEGER NOT NULL,
user_id INTEGER NOT NULL,
action INTEGER NOT NULL,
images TEXT,
count INTEGER NOT NULL DEFAULT 0,
date DATETIME NOT NULL,
INDEX (id)
");
2009-12-24 07:36:09 +00:00
$config->set_int("ext_pools_version", 1);
2009-12-25 23:05:57 +00:00
$config->set_int("poolsMaxImportResults", 1000);
$config->set_int("poolsImagesPerPage", 20);
2009-12-24 07:36:09 +00:00
$config->set_int("poolsListsPerPage", 20);
$config->set_int("poolsUpdatedPerPage", 20);
$config->set_bool("poolsInfoOnViewImage", "N");
2009-12-30 07:07:10 +00:00
$config->set_bool("poolsAdderOnViewImage", "N");
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
log_info("pools", "extension installed");
}
}
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
public function onSetupBuilding(SetupBuildingEvent $event) {
$sb = new SetupBlock("Pools");
$sb->add_int_option("poolsMaxImportResults", "Max results on import: ");
$sb->add_int_option("poolsImagesPerPage", "<br>Images per page: ");
$sb->add_int_option("poolsListsPerPage", "<br>Index list items per page: ");
$sb->add_int_option("poolsUpdatedPerPage", "<br>Updated list items per page: ");
$sb->add_bool_option("poolsInfoOnViewImage", "<br>Show pool info on image: ");
2009-12-30 08:11:24 +00:00
//$sb->add_bool_option("poolsAdderOnViewImage", "<br>Show pool adder on image: ");
2009-12-24 07:36:09 +00:00
$event->panel->add_block($sb);
}
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
public function onPageRequest($event) {
global $config, $page, $user;
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
if($event->page_matches("pool")) {
switch($event->get_arg(0)) {
case "list": //index
2009-12-26 00:56:53 +00:00
$this->list_pools($page, int_escape($event->get_arg(1)));
2009-12-24 07:36:09 +00:00
break;
2009-12-26 00:56:53 +00:00
2009-12-24 07:36:09 +00:00
case "new": // Show form
if(!$user->is_anonymous()){
$this->theme->new_pool_composer($page);
} else {
$errMessage = "You must be registered and logged in to create a new pool.";
$this->theme->display_error($errMessage);
}
break;
2009-12-26 00:56:53 +00:00
2009-12-24 07:36:09 +00:00
case "create": // ADD _POST
2010-05-04 20:10:37 +01:00
try {
2009-12-25 23:05:57 +00:00
$newPoolID = $this->add_pool();
$page->set_mode("redirect");
2009-12-26 00:56:53 +00:00
$page->set_redirect(make_link("pool/view/".$newPoolID));
2010-05-04 20:10:37 +01:00
}
catch(PoolCreationException $pce) {
$this->theme->display_error($pce->getMessage());
2009-12-25 23:05:57 +00:00
}
2009-12-24 07:36:09 +00:00
break;
2009-12-26 00:56:53 +00:00
2009-12-24 07:36:09 +00:00
case "view":
2009-12-26 00:31:02 +00:00
$poolID = int_escape($event->get_arg(1));
2009-12-24 07:36:09 +00:00
$this->get_posts($event, $poolID);
break;
2009-12-26 00:56:53 +00:00
2009-12-24 07:36:09 +00:00
case "updated":
2009-12-26 00:56:53 +00:00
$this->get_history(int_escape($event->get_arg(1)));
2009-12-24 07:36:09 +00:00
break;
2009-12-26 00:56:53 +00:00
2009-12-24 07:36:09 +00:00
case "revert":
2009-12-25 23:05:57 +00:00
if(!$user->is_anonymous()) {
2009-12-26 00:31:02 +00:00
$historyID = int_escape($event->get_arg(1));
2009-12-25 23:05:57 +00:00
$this->revert_history($historyID);
$page->set_mode("redirect");
$page->set_redirect(make_link("pool/updated"));
}
break;
2009-12-26 00:56:53 +00:00
2009-12-24 07:36:09 +00:00
case "edit":
2009-12-26 00:31:02 +00:00
$poolID = int_escape($event->get_arg(1));
2009-12-24 07:36:09 +00:00
$pools = $this->get_pool($poolID);
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
foreach($pools as $pool) {
2009-12-26 00:56:53 +00:00
// if the pool is public and user is logged OR if the user is admin OR the user is the owner
2009-12-24 07:36:09 +00:00
if(($pool['public'] == "Y" && !$user->is_anonymous()) || $user->is_admin() || $user->id == $pool['user_id']) {
2009-12-25 23:05:57 +00:00
$this->theme->edit_pool($page, $this->get_pool($poolID), $this->edit_posts($poolID));
} else {
2009-12-24 07:36:09 +00:00
$page->set_mode("redirect");
2009-12-26 00:31:02 +00:00
$page->set_redirect(make_link("pool/view/".$poolID));
2009-12-25 23:05:57 +00:00
}
2009-12-24 07:36:09 +00:00
}
break;
2009-12-26 00:56:53 +00:00
2009-12-24 07:36:09 +00:00
case "order":
2009-12-30 07:07:10 +00:00
if($_SERVER["REQUEST_METHOD"] == "GET") {
$poolID = int_escape($event->get_arg(1));
$pools = $this->get_pool($poolID);
foreach($pools as $pool) {
//if the pool is public and user is logged OR if the user is admin
if(($pool['public'] == "Y" && !$user->is_anonymous()) || $user->is_admin() || $user->id == $pool['user_id']) {
$this->theme->edit_order($page, $this->get_pool($poolID), $this->edit_order($poolID));
} else {
$page->set_mode("redirect");
$page->set_redirect(make_link("pool/view/".$poolID));
}
}
}
else {
$pool_id = int_escape($_POST["pool_id"]);
$pool = $this->get_single_pool($pool_id);
2009-12-25 23:05:57 +00:00
if(($pool['public'] == "Y" && !$user->is_anonymous()) || $user->is_admin() || $user->id == $pool['user_id']) {
2009-12-30 07:07:10 +00:00
$this->order_posts();
2009-12-25 23:05:57 +00:00
$page->set_mode("redirect");
2009-12-30 07:07:10 +00:00
$page->set_redirect(make_link("pool/view/".$pool_id));
} else {
$this->theme->display_error("Permssion denied.");
2009-12-25 23:05:57 +00:00
}
}
2009-12-24 07:36:09 +00:00
break;
2009-12-26 00:56:53 +00:00
case "import":
2009-12-25 23:05:57 +00:00
$pool_id = int_escape($_POST["pool_id"]);
$pool = $this->get_single_pool($pool_id);
2009-12-24 07:36:09 +00:00
2009-12-25 23:05:57 +00:00
if(($pool['public'] == "Y" && !$user->is_anonymous()) || $user->is_admin() || $user->id == $pool['user_id']) {
2009-12-26 00:56:53 +00:00
$this->import_posts();
2009-12-25 23:05:57 +00:00
} else {
$this->theme->display_error("Permssion denied.");
}
break;
2009-12-26 00:56:53 +00:00
case "add_posts":
2009-12-25 23:05:57 +00:00
$pool_id = int_escape($_POST["pool_id"]);
$pool = $this->get_single_pool($pool_id);
if(($pool['public'] == "Y" && !$user->is_anonymous()) || $user->is_admin() || $user->id == $pool['user_id']) {
2009-12-26 00:56:53 +00:00
$this->add_posts();
2009-12-25 23:05:57 +00:00
$page->set_mode("redirect");
$page->set_redirect(make_link("pool/view/".$pool_id));
} else {
$this->theme->display_error("Permssion denied.");
}
2009-12-24 07:36:09 +00:00
break;
2009-12-26 00:56:53 +00:00
2009-12-24 07:36:09 +00:00
case "remove_posts":
2009-12-25 23:05:57 +00:00
$pool_id = int_escape($_POST["pool_id"]);
$pool = $this->get_single_pool($pool_id);
if(($pool['public'] == "Y" && !$user->is_anonymous()) || $user->is_admin() || $user->id == $pool['user_id']) {
$this->remove_posts();
$page->set_mode("redirect");
2009-12-26 00:31:02 +00:00
$page->set_redirect(make_link("pool/view/".$pool_id));
2009-12-25 23:05:57 +00:00
} else {
$this->theme->display_error("Permssion denied.");
}
2009-12-24 07:36:09 +00:00
break;
2009-12-26 00:56:53 +00:00
2009-12-24 07:36:09 +00:00
case "nuke":
2009-12-30 07:07:10 +00:00
$pool_id = int_escape($_POST['pool_id']);
2009-12-25 23:05:57 +00:00
$pool = $this->get_single_pool($pool_id);
// only admins and owners may do this
if($user->is_admin() || $user->id == $pool['user_id']) {
$this->nuke_pool($pool_id);
$page->set_mode("redirect");
$page->set_redirect(make_link("pool/list"));
} else {
$this->theme->display_error("Permssion denied.");
}
2009-12-24 07:36:09 +00:00
break;
2009-12-26 00:56:53 +00:00
2009-12-24 07:36:09 +00:00
default:
2009-12-25 23:05:57 +00:00
$page->set_mode("redirect");
$page->set_redirect(make_link("pool/list"));
break;
}
}
}
2009-12-30 07:07:10 +00:00
public function onUserBlockBuilding($event) {
$event->add_link("Pools", make_link("pool/list"));
}
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
/*
2009-12-25 23:05:57 +00:00
* HERE WE GET THE POOLS WHERE THE IMAGE APPEARS WHEN THE IMAGE IS DISPLAYED
*/
2009-12-24 07:36:09 +00:00
public function onDisplayingImage($event) {
2009-12-30 07:07:10 +00:00
global $config, $database, $page;
2009-12-26 00:56:53 +00:00
if($config->get_bool("poolsInfoOnViewImage")) {
$imageID = $event->image->id;
$poolsIDs = $this->get_pool_id($imageID);
$linksPools = array();
foreach($poolsIDs as $poolID) {
$pools = $this->get_pool($poolID['pool_id']);
foreach ($pools as $pool){
2009-12-30 07:07:10 +00:00
$linksPools[] = "<a href='".make_link("pool/view/".$pool['id'])."'>".html_escape($pool['title'])."</a>";
2009-12-26 00:56:53 +00:00
}
}
2009-12-30 07:07:10 +00:00
$this->theme->pool_info($linksPools);
}
}
public function onImageAdminBlockBuilding($event) {
global $config, $database, $user;
if($config->get_bool("poolsAdderOnViewImage") && !$user->is_anonymous()) {
if($user->is_admin()) {
$pools = $database->get_all("SELECT * FROM pools");
}
else {
$pools = $database->get_all("SELECT * FROM pools WHERE user_id=?", array($user->id));
}
if(count($pools) > 0) {
$event->add_part($this->theme->get_adder_html($event->image, $pools));
2009-12-24 07:36:09 +00:00
}
2009-12-25 23:05:57 +00:00
}
2009-12-24 07:36:09 +00:00
}
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
/*
2009-12-25 23:05:57 +00:00
* HERE WE GET THE LIST OF POOLS
*/
2009-12-26 00:56:53 +00:00
private function list_pools(Page $page, $pageNumber) {
2009-12-24 07:36:09 +00:00
global $config, $database;
2009-12-25 23:05:57 +00:00
if(is_null($pageNumber) || !is_numeric($pageNumber))
$pageNumber = 0;
else if ($pageNumber <= 0)
$pageNumber = 0;
else
$pageNumber--;
$poolsPerPage = $config->get_int("poolsListsPerPage");
2010-05-04 20:10:37 +01:00
$pools = $database->get_all("
SELECT p.id, p.user_id, p.public, p.title, p.description,
p.posts, u.name as user_name
FROM pools AS p
INNER JOIN users AS u
ON p.user_id = u.id
ORDER BY p.date DESC
LIMIT ? OFFSET ?
", array($poolsPerPage, $pageNumber * $poolsPerPage)
2009-12-25 23:05:57 +00:00
);
2009-12-24 07:36:09 +00:00
$totalPages = ceil($database->db->GetOne("SELECT COUNT(*) FROM pools") / $poolsPerPage);
2009-12-25 23:05:57 +00:00
$this->theme->list_pools($page, $pools, $pageNumber + 1, $totalPages);
2009-12-24 07:36:09 +00:00
}
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
/*
2009-12-25 23:05:57 +00:00
* HERE WE CREATE A NEW POOL
*/
2009-12-26 00:31:02 +00:00
private function add_pool() {
2009-12-24 07:36:09 +00:00
global $user, $database;
2009-12-25 23:05:57 +00:00
2010-05-04 20:10:37 +01:00
if($user->is_anonymous()) {
throw new PoolCreationException("You must be registered and logged in to add a image.");
}
if(empty($_POST["title"])) {
throw new PoolCreationException("Pool needs a title");
}
2009-12-26 00:31:02 +00:00
$public = $_POST["public"] == "Y" ? "Y" : "N";
2009-12-24 07:36:09 +00:00
$database->execute("
2009-12-26 00:31:02 +00:00
INSERT INTO pools (user_id, public, title, description, date)
VALUES (?, ?, ?, ?, now())",
array($user->id, $public, $_POST["title"], $_POST["description"]));
2009-12-25 23:05:57 +00:00
2009-12-26 00:31:02 +00:00
$result = $database->get_row("SELECT LAST_INSERT_ID() AS poolID"); # FIXME database specific?
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
log_info("pools", "Pool {$result["poolID"]} created by {$user->name}");
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
return $result["poolID"];
}
2009-12-25 23:05:57 +00:00
2009-12-26 00:31:02 +00:00
private function get_pool($poolID) {
2009-12-24 07:36:09 +00:00
global $database;
return $database->get_all("SELECT * FROM pools WHERE id=?", array($poolID));
}
2009-12-25 23:05:57 +00:00
2009-12-26 00:31:02 +00:00
private function get_single_pool($poolID) {
2009-12-24 07:36:09 +00:00
global $database;
return $database->get_row("SELECT * FROM pools WHERE id=?", array($poolID));
2009-12-25 23:05:57 +00:00
}
2009-12-24 07:36:09 +00:00
/*
2009-12-25 23:05:57 +00:00
* HERE WE GET THE ID OF THE POOL FROM AN IMAGE
*/
2009-12-26 00:31:02 +00:00
private function get_pool_id($imageID) {
2009-12-24 07:36:09 +00:00
global $database;
2009-12-26 00:31:02 +00:00
return $database->get_all("SELECT pool_id FROM pool_images WHERE image_id=?", array($imageID));
2009-12-24 07:36:09 +00:00
}
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
/*
2009-12-25 23:05:57 +00:00
* HERE WE GET THE IMAGES FROM THE TAG ON IMPORT
*/
2009-12-26 00:31:02 +00:00
private function import_posts() {
2009-12-24 07:36:09 +00:00
global $page, $config, $database;
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
$pool_id = int_escape($_POST["pool_id"]);
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
$poolsMaxResults = $config->get_int("poolsMaxImportResults", 1000);
2009-12-25 23:05:57 +00:00
2009-12-26 00:31:02 +00:00
$images = $images = Image::find_images(0, $poolsMaxResults, Tag::explode($_POST["pool_tag"]));
2009-12-24 07:36:09 +00:00
$this->theme->pool_result($page, $images, $pool_id);
}
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
/*
2009-12-25 23:05:57 +00:00
* HERE WE ADD CHECKED IMAGES FROM POOL AND UPDATE THE HISTORY
*/
2009-12-26 00:31:02 +00:00
private function add_posts() {
2009-12-24 07:36:09 +00:00
global $database;
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
$poolID = int_escape($_POST['pool_id']);
$images = "";
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
foreach ($_POST['check'] as $imageID){
if(!$this->check_post($poolID, $imageID)){
$database->execute("
2009-12-26 00:31:02 +00:00
INSERT INTO pool_images (pool_id, image_id)
VALUES (?, ?)",
2009-12-25 23:05:57 +00:00
array($poolID, $imageID));
$images .= " ".$imageID;
2009-12-24 07:36:09 +00:00
}
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
}
2009-12-25 23:05:57 +00:00
2009-12-26 00:31:02 +00:00
if(!strlen($images) == 0) {
2009-12-24 07:36:09 +00:00
$count = $database->db->GetOne("SELECT COUNT(*) FROM pool_images WHERE pool_id=?", array($poolID));
$this->add_history($poolID, 1, $images, $count);
}
2009-12-25 23:05:57 +00:00
2009-12-26 00:31:02 +00:00
$database->Execute("
UPDATE pools
SET posts=(SELECT COUNT(*) FROM pool_images WHERE pool_id=?)
WHERE id=?",
array($poolID, $poolID)
);
2009-12-24 07:36:09 +00:00
return $poolID;
}
2009-12-25 23:05:57 +00:00
2009-12-26 00:31:02 +00:00
private function order_posts() {
2009-12-24 07:36:09 +00:00
global $database;
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
$poolID = int_escape($_POST['pool_id']);
2009-12-25 23:05:57 +00:00
2009-12-26 00:31:02 +00:00
foreach($_POST['imgs'] as $data) {
list($imageORDER, $imageID) = $data;
$database->Execute("
UPDATE pool_images
SET image_order = ?
WHERE pool_id = ? AND image_id = ?",
array($imageORDER, $poolID, $imageID)
);
2009-12-24 07:36:09 +00:00
}
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
return $poolID;
}
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
/*
2009-12-25 23:05:57 +00:00
* HERE WE REMOVE CHECKED IMAGES FROM POOL AND UPDATE THE HISTORY
*/
2009-12-26 00:31:02 +00:00
private function remove_posts() {
2009-12-24 07:36:09 +00:00
global $database;
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
$poolID = int_escape($_POST['pool_id']);
$images = "";
2009-12-25 23:05:57 +00:00
2009-12-26 00:31:02 +00:00
foreach($_POST['check'] as $imageID) {
2009-12-24 07:36:09 +00:00
$database->execute("DELETE FROM pool_images WHERE pool_id = ? AND image_id = ?", array($poolID, $imageID));
$images .= " ".$imageID;
}
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
$count = $database->db->GetOne("SELECT COUNT(*) FROM pool_images WHERE pool_id=?", array($poolID));
$this->add_history($poolID, 0, $images, $count);
return $poolID;
}
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
/*
2009-12-25 23:05:57 +00:00
* HERE WE CHECK IF THE POST IS ALREADY ON POOL
* USED IN add_posts()
*/
2009-12-26 00:31:02 +00:00
private function check_post($poolID, $imageID) {
2009-12-24 07:36:09 +00:00
global $database;
$result = $database->db->GetOne("SELECT COUNT(*) FROM pool_images WHERE pool_id=? AND image_id=?", array($poolID, $imageID));
2009-12-26 00:31:02 +00:00
return ($result != 0);
2009-12-24 07:36:09 +00:00
}
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
/*
2009-12-25 23:05:57 +00:00
* HERE WE GET ALL IMAGES FOR THE POOL
*/
2009-12-26 00:31:02 +00:00
private function get_posts($event, $poolID) {
2009-12-24 07:36:09 +00:00
global $config, $user, $database;
2009-12-25 23:05:57 +00:00
2009-12-26 00:31:02 +00:00
$pageNumber = int_escape($event->get_arg(2));
2009-12-25 23:05:57 +00:00
if(is_null($pageNumber) || !is_numeric($pageNumber))
$pageNumber = 0;
else if ($pageNumber <= 0)
$pageNumber = 0;
else
$pageNumber--;
2009-12-24 07:36:09 +00:00
$poolID = int_escape($poolID);
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
$imagesPerPage = $config->get_int("poolsImagesPerPage");
2009-12-25 23:05:57 +00:00
2009-12-30 07:07:10 +00:00
// WE CHECK IF THE EXTENSION RATING IS INSTALLED, WHICH VERSION AND IF IT
// WORKS TO SHOW/HIDE SAFE, QUESTIONABLE, EXPLICIT AND UNRATED IMAGES FROM USER
if(class_exists("Ratings")) {
2009-12-26 00:31:02 +00:00
$rating = Ratings::privs_to_sql(Ratings::get_user_privs($user));
$result = $database->get_all("
SELECT p.image_id
FROM pool_images AS p
INNER JOIN images AS i ON i.id = p.image_id
WHERE p.pool_id = ? AND i.rating IN ($rating)
ORDER BY p.image_order ASC
2010-05-04 20:10:37 +01:00
LIMIT ? OFFSET ?",
array($poolID, $imagesPerPage, $pageNumber * $imagesPerPage));
2009-12-26 00:31:02 +00:00
$totalPages = ceil($database->db->GetOne("
SELECT COUNT(*)
FROM pool_images AS p
INNER JOIN images AS i ON i.id = p.image_id
WHERE pool_id=? AND i.rating IN ($rating)",
array($poolID)) / $imagesPerPage);
2009-12-24 07:36:09 +00:00
}
2009-12-30 07:07:10 +00:00
else {
$result = $database->get_all("
SELECT image_id
FROM pool_images
WHERE pool_id=?
ORDER BY image_order ASC
2010-05-04 20:10:37 +01:00
LIMIT ? OFFSET ?",
array($poolID, $imagesPerPage, $pageNumber * $imagesPerPage));
2009-12-30 07:07:10 +00:00
$totalPages = ceil($database->db->GetOne("SELECT COUNT(*) FROM pool_images WHERE pool_id=?", array($poolID)) / $imagesPerPage);
}
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
$images = array();
2009-12-26 00:31:02 +00:00
foreach($result as $singleResult) {
2009-12-30 07:07:10 +00:00
$images[] = Image::by_id($singleResult["image_id"]);
2009-12-25 23:05:57 +00:00
}
2009-12-24 07:36:09 +00:00
$pool = $this->get_pool($poolID);
$this->theme->view_pool($pool, $images, $pageNumber + 1, $totalPages);
}
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
/*
2009-12-25 23:05:57 +00:00
* WE GET THE ORDER OF THE IMAGES
*/
2009-12-26 00:31:02 +00:00
private function edit_posts($poolID) {
2009-12-24 07:36:09 +00:00
global $database;
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
$result = $database->Execute("SELECT image_id FROM pool_images WHERE pool_id=? ORDER BY image_order ASC", array($poolID));
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
$images = array();
while(!$result->EOF) {
$image = Image::by_id($result->fields["image_id"]);
$images[] = array($image);
$result->MoveNext();
}
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
return $images;
}
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
/*
2009-12-25 23:05:57 +00:00
* WE GET THE ORDER OF THE IMAGES BUT HERE WE SEND KEYS ADDED IN ARRAY TO GET THE ORDER IN THE INPUT VALUE
*/
2009-12-26 00:31:02 +00:00
private function edit_order($poolID) {
2009-12-24 07:36:09 +00:00
global $database;
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
$result = $database->Execute("SELECT image_id FROM pool_images WHERE pool_id=? ORDER BY image_order ASC", array($poolID));
$images = array();
while(!$result->EOF) {
2009-12-26 00:31:02 +00:00
$image = $database->get_row("
SELECT * FROM images AS i
INNER JOIN pool_images AS p ON i.id = p.image_id
WHERE pool_id=? AND i.id=?",
array($poolID, $result->fields["image_id"]));
2009-12-24 07:36:09 +00:00
$image = ($image ? new Image($image) : null);
$images[] = array($image);
$result->MoveNext();
}
2009-12-25 23:05:57 +00:00
// Original code
//
// $images = array();
// while(!$result->EOF) {
// $image = Image::by_id($result->fields["image_id"]);
// $images[] = array($image);
// $result->MoveNext();
// }
2009-12-24 07:36:09 +00:00
return $images;
}
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
/*
2009-12-25 23:05:57 +00:00
* HERE WE NUKE ENTIRE POOL. WE REMOVE POOLS AND POSTS FROM REMOVED POOL AND HISTORIES ENTRIES FROM REMOVED POOL
*/
2009-12-26 00:31:02 +00:00
private function nuke_pool($poolID) {
2009-12-24 07:36:09 +00:00
global $user, $database;
2009-12-25 23:05:57 +00:00
2009-12-26 00:31:02 +00:00
if($user->is_admin()) {
2009-12-24 07:36:09 +00:00
$database->execute("DELETE FROM pool_history WHERE pool_id = ?", array($poolID));
$database->execute("DELETE FROM pool_images WHERE pool_id = ?", array($poolID));
$database->execute("DELETE FROM pools WHERE id = ?", array($poolID));
2009-12-26 00:31:02 +00:00
} elseif(!$user->is_anonymous()) {
// FIXME: WE CHECK IF THE USER IS THE OWNER OF THE POOL IF NOT HE CAN'T DO ANYTHING
2009-12-24 07:36:09 +00:00
$database->execute("DELETE FROM pool_history WHERE pool_id = ?", array($poolID));
$database->execute("DELETE FROM pool_images WHERE pool_id = ?", array($poolID));
$database->execute("DELETE FROM pools WHERE id = ? AND user_id = ?", array($poolID, $user->id));
}
}
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
/*
2009-12-25 23:05:57 +00:00
* HERE WE ADD A HISTORY ENTRY
* FOR $action 1 (one) MEANS ADDED, 0 (zero) MEANS REMOVED
*/
2009-12-26 00:31:02 +00:00
private function add_history($poolID, $action, $images, $count) {
2009-12-24 07:36:09 +00:00
global $user, $database;
$database->execute("
2009-12-26 00:31:02 +00:00
INSERT INTO pool_history (pool_id, user_id, action, images, count, date)
VALUES (?, ?, ?, ?, ?, now())",
array($poolID, $user->id, $action, $images, $count));
2009-12-24 07:36:09 +00:00
}
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
/*
2009-12-25 23:05:57 +00:00
* HERE WE GET THE HISTORY LIST
*/
2009-12-26 00:56:53 +00:00
private function get_history($pageNumber) {
2009-12-24 07:36:09 +00:00
global $config, $database;
2009-12-25 23:05:57 +00:00
if(is_null($pageNumber) || !is_numeric($pageNumber))
$pageNumber = 0;
else if ($pageNumber <= 0)
$pageNumber = 0;
else
$pageNumber--;
2009-12-24 07:36:09 +00:00
$historiesPerPage = $config->get_int("poolsUpdatedPerPage");
2009-12-25 23:05:57 +00:00
2010-05-04 20:10:37 +01:00
$history = $database->get_all("
SELECT h.id, h.pool_id, h.user_id, h.action, h.images,
h.count, h.date, u.name as user_name, p.title as title
FROM pool_history AS h
INNER JOIN pools AS p
ON p.id = h.pool_id
INNER JOIN users AS u
ON h.user_id = u.id
ORDER BY h.date DESC
LIMIT ? OFFSET ?
", array($historiesPerPage, $pageNumber * $historiesPerPage));
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
$totalPages = ceil($database->db->GetOne("SELECT COUNT(*) FROM pool_history") / $historiesPerPage);
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
$this->theme->show_history($history, $pageNumber + 1, $totalPages);
}
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
/*
2009-12-25 23:05:57 +00:00
* HERE GO BACK IN HISTORY AND ADD OR REMOVE POSTS TO POOL
*/
2009-12-26 00:31:02 +00:00
private function revert_history($historyID) {
2009-12-24 07:36:09 +00:00
global $database;
$status = $database->get_all("SELECT * FROM pool_history WHERE id=?", array($historyID));
2009-12-25 23:05:57 +00:00
2009-12-26 00:31:02 +00:00
foreach($status as $entry) {
2009-12-24 07:36:09 +00:00
$images = trim($entry['images']);
$images = explode(" ", $images);
$poolID = $entry['pool_id'];
$imageArray = "";
2009-12-25 23:05:57 +00:00
2009-12-26 00:31:02 +00:00
if($entry['action'] == 0) {
// READ ENTRIES
foreach($images as $image) {
2009-12-24 07:36:09 +00:00
$imageID = $image;
$this->add_post($poolID, $imageID);
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
$imageArray .= " ".$imageID;
$newAction = 1;
}
2009-12-26 00:31:02 +00:00
}
else if($entry['action'] == 1) {
2009-12-24 07:36:09 +00:00
// DELETE ENTRIES
2009-12-26 00:31:02 +00:00
foreach($images as $image) {
2009-12-24 07:36:09 +00:00
$imageID = $image;
$this->delete_post($poolID, $imageID);
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
$imageArray .= " ".$imageID;
$newAction = 0;
}
}
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
$count = $database->db->GetOne("SELECT COUNT(*) FROM pool_images WHERE pool_id=?", array($poolID));
$this->add_history($poolID, $newAction, $imageArray, $count);
}
}
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
/*
2009-12-25 23:05:57 +00:00
* HERE WE ADD A SIMPLE POST FROM POOL
* USED WITH FOREACH IN revert_history()
*/
2009-12-26 00:31:02 +00:00
private function add_post($poolID, $imageID) {
2009-12-25 23:05:57 +00:00
global $database;
2009-12-26 00:31:02 +00:00
if(!$this->check_post($poolID, $imageID)) {
2009-12-25 23:05:57 +00:00
$database->execute("
2009-12-26 00:31:02 +00:00
INSERT INTO pool_images (pool_id, image_id)
VALUES (?, ?)",
2009-12-25 23:05:57 +00:00
array($poolID, $imageID));
}
$database->execute("UPDATE pools SET posts=(SELECT COUNT(*) FROM pool_images WHERE pool_id=?) WHERE id=?", array($poolID, $poolID));
2009-12-24 07:36:09 +00:00
}
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
/*
2009-12-25 23:05:57 +00:00
* HERE WE REMOVE A SIMPLE POST FROM POOL
* USED WITH FOREACH IN revert_history()
*/
2009-12-26 00:31:02 +00:00
private function delete_post($poolID, $imageID) {
2009-12-25 23:05:57 +00:00
global $database;
$database->execute("DELETE FROM pool_images WHERE pool_id = ? AND image_id = ?", array($poolID, $imageID));
$database->execute("UPDATE pools SET posts=(SELECT COUNT(*) FROM pool_images WHERE pool_id=?) WHERE id=?", array($poolID, $poolID));
2009-12-24 07:36:09 +00:00
}
2009-12-25 23:05:57 +00:00
2009-12-24 07:36:09 +00:00
}
?>