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/ext/tips/main.php

171 lines
4.8 KiB
PHP
Raw Normal View History

2009-11-24 14:07:18 +00:00
<?php
class Tips extends Extension
{
protected $db_support = [DatabaseDriver::MYSQL, DatabaseDriver::SQLITE]; // rand() ?
2015-08-09 11:16:06 +00:00
public function onInitExt(InitExtEvent $event)
{
global $config, $database;
2009-11-24 14:07:18 +00:00
if ($config->get_int("ext_tips_version") < 1) {
$database->create_table("tips", "
2009-11-24 14:07:18 +00:00
id SCORE_AIPK,
enable SCORE_BOOL NOT NULL DEFAULT SCORE_BOOL_N,
image TEXT NOT NULL,
text TEXT NOT NULL,
");
$database->execute(
"
2009-11-24 14:07:18 +00:00
INSERT INTO tips (enable, image, text)
VALUES (?, ?, ?)",
["Y", "coins.png", "Do you like this extension? Please support us for developing new ones. <a href=\"https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=8235933\" target=\"_blank\">Donate through paypal</a>."]
);
$config->set_int("ext_tips_version", 1);
log_info("tips", "extension installed");
}
}
public function onPageRequest(PageRequestEvent $event)
{
global $page, $user;
$this->getTip();
if ($event->page_matches("tips") && $user->is_admin()) {
switch ($event->get_arg(0)) {
case "list":
$this->manageTips();
$this->getAll();
break;
case "save":
if ($user->check_auth_token()) {
$this->saveTip();
2019-06-19 01:58:28 +00:00
$page->set_mode(PageMode::REDIRECT);
$page->set_redirect(make_link("tips/list"));
}
break;
case "status":
// FIXME: HTTP GET CSRF
$tipID = int_escape($event->get_arg(1));
$this->setStatus($tipID);
2019-06-19 01:58:28 +00:00
$page->set_mode(PageMode::REDIRECT);
$page->set_redirect(make_link("tips/list"));
break;
case "delete":
// FIXME: HTTP GET CSRF
$tipID = int_escape($event->get_arg(1));
$this->deleteTip($tipID);
2019-06-19 01:58:28 +00:00
$page->set_mode(PageMode::REDIRECT);
$page->set_redirect(make_link("tips/list"));
break;
}
}
}
public function onPageSubNavBuilding(PageSubNavBuildingEvent $event)
{
global $user;
if($event->parent==="system") {
if ($user->is_admin()) {
$event->add_nav_link("tips", new Link('tips/list'), "Tips Editor");
}
}
}
public function onUserBlockBuilding(UserBlockBuildingEvent $event)
{
global $user;
if ($user->is_admin()) {
$event->add_link("Tips Editor", make_link("tips/list"));
}
}
private function manageTips()
{
$data_href = get_base_href();
$url = $data_href."/ext/tips/images/";
$dirPath = dir('./ext/tips/images');
$images = [];
while (($file = $dirPath->read()) !== false) {
if ($file[0] != ".") {
$images[] = trim($file);
}
}
$dirPath->close();
sort($images);
$this->theme->manageTips($url, $images);
}
private function saveTip()
{
global $database;
$enable = isset($_POST["enable"]) ? "Y" : "N";
$image = html_escape($_POST["image"]);
$text = $_POST["text"];
$database->execute(
"
2009-11-24 14:07:18 +00:00
INSERT INTO tips (enable, image, text)
VALUES (?, ?, ?)",
[$enable, $image, $text]
);
}
2009-11-24 14:07:18 +00:00
private function getTip()
{
global $database;
2009-11-24 14:07:18 +00:00
$data_href = get_base_href();
$url = $data_href."/ext/tips/images/";
2009-11-24 14:07:18 +00:00
$tip = $database->get_row("SELECT * ".
"FROM tips ".
"WHERE enable = 'Y' ".
"ORDER BY RAND() ".
"LIMIT 1");
2009-11-24 14:07:18 +00:00
if ($tip) {
$this->theme->showTip($url, $tip);
}
}
2009-11-24 14:07:18 +00:00
private function getAll()
{
global $database;
2009-11-24 14:07:18 +00:00
$data_href = get_base_href();
$url = $data_href."/ext/tips/images/";
2009-11-24 14:07:18 +00:00
$tips = $database->get_all("SELECT * FROM tips ORDER BY id ASC");
2009-11-24 14:07:18 +00:00
$this->theme->showAll($url, $tips);
}
2009-11-24 14:07:18 +00:00
private function setStatus(int $tipID)
{
global $database;
2009-11-24 14:07:18 +00:00
$tip = $database->get_row("SELECT * FROM tips WHERE id = ? ", [int_escape($tipID)]);
2009-11-24 14:07:18 +00:00
if (bool_escape($tip['enable'])) {
$enable = "N";
} else {
$enable = "Y";
}
2009-11-24 14:07:18 +00:00
$database->execute("UPDATE tips SET enable = ? WHERE id = ?", [$enable, int_escape($tipID)]);
}
2009-11-24 14:07:18 +00:00
private function deleteTip(int $tipID)
{
global $database;
$database->execute("DELETE FROM tips WHERE id = ?", [int_escape($tipID)]);
}
2009-11-24 14:07:18 +00:00
}