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

143 lines
4.4 KiB
PHP
Raw Normal View History

<?php
2010-01-05 10:11:53 +00:00
/**
* Name: Alias Editor
* Author: Shish <webmaster@shishnet.org>
* Link: http://code.shishnet.org/shimmie2/
* License: GPLv2
* Description: Edit the alias list
* Documentation:
* The list is visible at <a href="$site/alias/list">/alias/list</a>; only
* site admins can edit it, other people can view and download it
2010-01-05 10:11:53 +00:00
*/
class AddAliasEvent extends Event {
var $oldtag;
var $newtag;
public function AddAliasEvent($oldtag, $newtag) {
$this->oldtag = $oldtag;
$this->newtag = $newtag;
}
}
class AddAliasException extends SCoreException {}
class AliasEditor extends Extension {
2010-05-15 11:17:32 +00:00
public function onPageRequest(PageRequestEvent $event) {
global $config, $database, $page, $user;
2010-05-15 11:17:32 +00:00
if($event->page_matches("alias")) {
if($event->get_arg(0) == "add") {
2012-02-07 15:15:18 +00:00
if($user->can("manage_alias_list")) {
if(isset($_POST['oldtag']) && isset($_POST['newtag'])) {
try {
$aae = new AddAliasEvent($_POST['oldtag'], $_POST['newtag']);
send_event($aae);
$page->set_mode("redirect");
$page->set_redirect(make_link("alias/list"));
}
catch(AddAliasException $ex) {
$this->theme->display_error(500, "Error adding alias", $ex->getMessage());
}
}
}
}
else if($event->get_arg(0) == "remove") {
2012-02-07 15:15:18 +00:00
if($user->can("manage_alias_list")) {
if(isset($_POST['oldtag'])) {
2011-02-22 22:35:07 +00:00
$database->execute("DELETE FROM aliases WHERE oldtag=:oldtag", array("oldtag" => $_POST['oldtag']));
2009-12-30 07:59:40 +00:00
log_info("alias_editor", "Deleted alias for ".$_POST['oldtag']);
$page->set_mode("redirect");
$page->set_redirect(make_link("alias/list"));
}
}
}
else if($event->get_arg(0) == "list") {
2009-08-25 01:36:00 +00:00
$page_number = $event->get_arg(1);
if(is_null($page_number) || !is_numeric($page_number)) {
$page_number = 0;
}
else if ($page_number <= 0) {
$page_number = 0;
}
else {
$page_number--;
}
$alias_per_page = $config->get_int('alias_items_per_page', 30);
2011-01-01 16:28:04 +00:00
$query = "SELECT oldtag, newtag FROM aliases ORDER BY newtag ASC LIMIT :limit OFFSET :offset";
$alias = $database->get_pairs($query,
array("limit"=>$alias_per_page, "offset"=>$page_number * $alias_per_page)
2009-08-25 01:36:00 +00:00
);
2011-01-01 16:28:04 +00:00
$total_pages = ceil($database->get_one("SELECT COUNT(*) FROM aliases") / $alias_per_page);
2009-08-25 01:36:00 +00:00
2012-02-07 15:15:18 +00:00
$this->theme->display_aliases($alias, $page_number + 1, $total_pages);
}
else if($event->get_arg(0) == "export") {
$page->set_mode("data");
$page->set_type("text/plain");
$page->set_data($this->get_alias_csv($database));
}
else if($event->get_arg(0) == "import") {
2012-02-07 15:15:18 +00:00
if($user->can("manage_alias_list")) {
if(count($_FILES) > 0) {
$tmp = $_FILES['alias_file']['tmp_name'];
$contents = file_get_contents($tmp);
$this->add_alias_csv($database, $contents);
$page->set_mode("redirect");
$page->set_redirect(make_link("alias/list"));
}
else {
$this->theme->display_error(400, "No File Specified", "You have to upload a file");
}
}
else {
$this->theme->display_error(401, "Admins Only", "Only admins can edit the alias list");
}
}
}
2010-05-15 11:17:32 +00:00
}
2010-05-15 11:17:32 +00:00
public function onAddAlias(AddAliasEvent $event) {
global $database;
2011-02-22 22:35:07 +00:00
$pair = array("oldtag" => $event->oldtag, "newtag" => $event->newtag);
if($database->get_row("SELECT * FROM aliases WHERE oldtag=:oldtag AND lower(newtag)=lower(:newtag)", $pair)) {
2010-05-15 11:17:32 +00:00
throw new AddAliasException("That alias already exists");
}
2010-05-15 11:17:32 +00:00
else {
2011-02-22 22:35:07 +00:00
$database->execute("INSERT INTO aliases(oldtag, newtag) VALUES(:oldtag, :newtag)", $pair);
2010-05-15 11:17:32 +00:00
log_info("alias_editor", "Added alias for {$event->oldtag} -> {$event->newtag}");
}
}
2009-01-04 19:18:37 +00:00
2010-05-15 11:17:32 +00:00
public function onUserBlockBuilding(UserBlockBuildingEvent $event) {
global $user;
2012-02-07 15:15:18 +00:00
if($user->can("manage_alias_list")) {
2010-05-15 11:17:32 +00:00
$event->add_link("Alias Editor", make_link("alias/list"));
}
}
2012-02-02 14:14:33 +00:00
private function get_alias_csv(Database $database) {
$csv = "";
$aliases = $database->get_pairs("SELECT oldtag, newtag FROM aliases ORDER BY newtag");
foreach($aliases as $old => $new) {
$csv .= "$old,$new\n";
}
return $csv;
}
2012-02-02 14:14:33 +00:00
private function add_alias_csv(Database $database, /*string*/ $csv) {
$csv = str_replace("\r", "\n", $csv);
foreach(explode("\n", $csv) as $line) {
$parts = explode(",", $line);
if(count($parts) == 2) {
2012-01-31 14:46:19 +00:00
$database->execute("INSERT INTO aliases(oldtag, newtag) VALUES(:oldtag, :newtag)", array("oldtag" => $parts[0], "newtag" => $parts[1]));
}
}
}
}
?>