2021-12-14 18:32:47 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
declare(strict_types=1);
|
2007-04-16 11:58:25 +00:00
|
|
|
|
2023-01-10 22:44:09 +00:00
|
|
|
namespace Shimmie2;
|
|
|
|
|
2019-12-26 00:36:32 +00:00
|
|
|
use MicroCRUD\ActionColumn;
|
2019-12-01 01:02:18 +00:00
|
|
|
use MicroCRUD\TextColumn;
|
|
|
|
use MicroCRUD\Table;
|
|
|
|
|
|
|
|
class AliasTable extends Table
|
|
|
|
{
|
|
|
|
public function __construct(\FFSPHP\PDO $db)
|
|
|
|
{
|
|
|
|
parent::__construct($db);
|
|
|
|
$this->table = "aliases";
|
|
|
|
$this->base_query = "SELECT * FROM aliases";
|
|
|
|
$this->primary_key = "oldtag";
|
|
|
|
$this->size = 100;
|
|
|
|
$this->limit = 1000000;
|
2019-12-26 00:36:32 +00:00
|
|
|
$this->set_columns([
|
2019-12-01 01:02:18 +00:00
|
|
|
new TextColumn("oldtag", "Old Tag"),
|
|
|
|
new TextColumn("newtag", "New Tag"),
|
2019-12-26 00:36:32 +00:00
|
|
|
new ActionColumn("oldtag"),
|
|
|
|
]);
|
2019-12-01 01:02:18 +00:00
|
|
|
$this->order_by = ["oldtag"];
|
|
|
|
$this->table_attrs = ["class" => "zebra"];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
class AddAliasEvent extends Event
|
|
|
|
{
|
2021-03-14 23:43:50 +00:00
|
|
|
public string $oldtag;
|
|
|
|
public string $newtag;
|
2019-05-28 17:59:38 +01:00
|
|
|
|
|
|
|
public function __construct(string $oldtag, string $newtag)
|
|
|
|
{
|
2020-01-26 13:19:35 +00:00
|
|
|
parent::__construct();
|
2019-05-28 17:59:38 +01:00
|
|
|
$this->oldtag = trim($oldtag);
|
|
|
|
$this->newtag = trim($newtag);
|
|
|
|
}
|
2007-04-16 11:58:25 +00:00
|
|
|
}
|
|
|
|
|
2020-01-29 00:49:21 +00:00
|
|
|
class DeleteAliasEvent extends Event
|
|
|
|
{
|
2021-03-14 23:43:50 +00:00
|
|
|
public string $oldtag;
|
2020-01-28 21:19:59 +00:00
|
|
|
|
2020-01-29 00:49:21 +00:00
|
|
|
public function __construct(string $oldtag)
|
|
|
|
{
|
2020-02-01 18:11:00 +00:00
|
|
|
parent::__construct();
|
2020-01-28 21:19:59 +00:00
|
|
|
$this->oldtag = $oldtag;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
class AddAliasException extends SCoreException
|
|
|
|
{
|
2007-04-16 11:58:25 +00:00
|
|
|
}
|
2014-04-24 22:34:45 -04:00
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
class AliasEditor extends Extension
|
|
|
|
{
|
2020-01-26 13:19:35 +00:00
|
|
|
/** @var AliasEditorTheme */
|
2023-06-27 15:56:49 +01:00
|
|
|
protected Themelet $theme;
|
2020-01-26 13:19:35 +00:00
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
public function onPageRequest(PageRequestEvent $event)
|
|
|
|
{
|
|
|
|
global $config, $database, $page, $user;
|
|
|
|
|
|
|
|
if ($event->page_matches("alias")) {
|
|
|
|
if ($event->get_arg(0) == "add") {
|
2019-08-01 08:40:15 -05:00
|
|
|
if ($user->can(Permissions::MANAGE_ALIAS_LIST)) {
|
2019-12-01 01:02:18 +00:00
|
|
|
$user->ensure_authed();
|
|
|
|
$input = validate_input(["c_oldtag"=>"string", "c_newtag"=>"string"]);
|
|
|
|
try {
|
2020-01-28 21:19:59 +00:00
|
|
|
send_event(new AddAliasEvent($input['c_oldtag'], $input['c_newtag']));
|
2019-12-01 01:02:18 +00:00
|
|
|
$page->set_mode(PageMode::REDIRECT);
|
|
|
|
$page->set_redirect(make_link("alias/list"));
|
|
|
|
} catch (AddAliasException $ex) {
|
|
|
|
$this->theme->display_error(500, "Error adding alias", $ex->getMessage());
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
} elseif ($event->get_arg(0) == "remove") {
|
2019-08-01 08:40:15 -05:00
|
|
|
if ($user->can(Permissions::MANAGE_ALIAS_LIST)) {
|
2019-12-01 01:02:18 +00:00
|
|
|
$user->ensure_authed();
|
|
|
|
$input = validate_input(["d_oldtag"=>"string"]);
|
2020-01-28 21:19:59 +00:00
|
|
|
send_event(new DeleteAliasEvent($input['d_oldtag']));
|
2019-12-01 01:02:18 +00:00
|
|
|
$page->set_mode(PageMode::REDIRECT);
|
|
|
|
$page->set_redirect(make_link("alias/list"));
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
|
|
|
} elseif ($event->get_arg(0) == "list") {
|
2019-12-01 01:02:18 +00:00
|
|
|
$t = new AliasTable($database->raw_db());
|
|
|
|
$t->token = $user->get_auth_token();
|
|
|
|
$t->inputs = $_GET;
|
|
|
|
$t->size = $config->get_int('alias_items_per_page', 30);
|
2019-12-15 15:31:44 +00:00
|
|
|
if ($user->can(Permissions::MANAGE_ALIAS_LIST)) {
|
2019-12-01 01:02:18 +00:00
|
|
|
$t->create_url = make_link("alias/add");
|
|
|
|
$t->delete_url = make_link("alias/remove");
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
2019-12-01 01:02:18 +00:00
|
|
|
$this->theme->display_aliases($t->table($t->query()), $t->paginator());
|
2019-05-28 17:59:38 +01:00
|
|
|
} elseif ($event->get_arg(0) == "export") {
|
2019-06-18 20:58:28 -05:00
|
|
|
$page->set_mode(PageMode::DATA);
|
2020-06-14 11:05:55 -05:00
|
|
|
$page->set_mime(MimeType::CSV);
|
2019-05-28 17:59:38 +01:00
|
|
|
$page->set_filename("aliases.csv");
|
|
|
|
$page->set_data($this->get_alias_csv($database));
|
|
|
|
} elseif ($event->get_arg(0) == "import") {
|
2019-07-09 09:10:21 -05:00
|
|
|
if ($user->can(Permissions::MANAGE_ALIAS_LIST)) {
|
2019-05-28 17:59:38 +01:00
|
|
|
if (count($_FILES) > 0) {
|
|
|
|
$tmp = $_FILES['alias_file']['tmp_name'];
|
|
|
|
$contents = file_get_contents($tmp);
|
2023-01-11 18:28:43 +00:00
|
|
|
$this->add_alias_csv($contents);
|
2019-05-28 17:59:38 +01:00
|
|
|
log_info("alias_editor", "Imported aliases from file", "Imported aliases"); # FIXME: how many?
|
2019-06-18 20:58:28 -05:00
|
|
|
$page->set_mode(PageMode::REDIRECT);
|
2019-05-28 17:59:38 +01:00
|
|
|
$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");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public function onAddAlias(AddAliasEvent $event)
|
|
|
|
{
|
|
|
|
global $database;
|
2019-12-15 16:01:32 +00:00
|
|
|
|
|
|
|
$row = $database->get_row(
|
|
|
|
"SELECT * FROM aliases WHERE lower(oldtag)=lower(:oldtag)",
|
|
|
|
["oldtag"=>$event->oldtag]
|
|
|
|
);
|
|
|
|
if ($row) {
|
|
|
|
throw new AddAliasException("{$row['oldtag']} is already an alias for {$row['newtag']}");
|
|
|
|
}
|
|
|
|
|
|
|
|
$row = $database->get_row(
|
|
|
|
"SELECT * FROM aliases WHERE lower(oldtag)=lower(:newtag)",
|
|
|
|
["newtag" => $event->newtag]
|
|
|
|
);
|
|
|
|
if ($row) {
|
|
|
|
throw new AddAliasException("{$row['oldtag']} is itself an alias for {$row['newtag']}");
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
2019-12-15 16:01:32 +00:00
|
|
|
|
|
|
|
$database->execute(
|
|
|
|
"INSERT INTO aliases(oldtag, newtag) VALUES(:oldtag, :newtag)",
|
|
|
|
["oldtag" => $event->oldtag, "newtag" => $event->newtag]
|
|
|
|
);
|
|
|
|
log_info("alias_editor", "Added alias for {$event->oldtag} -> {$event->newtag}", "Added alias");
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
|
|
|
|
2020-01-29 00:49:21 +00:00
|
|
|
public function onDeleteAlias(DeleteAliasEvent $event)
|
|
|
|
{
|
2020-01-28 21:19:59 +00:00
|
|
|
global $database;
|
|
|
|
$database->execute("DELETE FROM aliases WHERE oldtag=:oldtag", ["oldtag" => $event->oldtag]);
|
|
|
|
log_info("alias_editor", "Deleted alias for {$event->oldtag}", "Deleted alias");
|
|
|
|
}
|
|
|
|
|
2019-08-02 14:54:48 -05:00
|
|
|
public function onPageSubNavBuilding(PageSubNavBuildingEvent $event)
|
|
|
|
{
|
2019-09-29 14:30:55 +01:00
|
|
|
if ($event->parent=="tags") {
|
2019-08-02 14:54:48 -05:00
|
|
|
$event->add_nav_link("aliases", new Link('alias/list'), "Aliases", NavLink::is_active(["alias"]));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
public function onUserBlockBuilding(UserBlockBuildingEvent $event)
|
|
|
|
{
|
|
|
|
global $user;
|
2019-07-09 09:10:21 -05:00
|
|
|
if ($user->can(Permissions::MANAGE_ALIAS_LIST)) {
|
2019-05-28 17:59:38 +01:00
|
|
|
$event->add_link("Alias Editor", make_link("alias/list"));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private function get_alias_csv(Database $database): string
|
|
|
|
{
|
|
|
|
$csv = "";
|
|
|
|
$aliases = $database->get_pairs("SELECT oldtag, newtag FROM aliases ORDER BY newtag");
|
|
|
|
foreach ($aliases as $old => $new) {
|
|
|
|
$csv .= "\"$old\",\"$new\"\n";
|
|
|
|
}
|
|
|
|
return $csv;
|
|
|
|
}
|
|
|
|
|
2023-01-11 18:28:43 +00:00
|
|
|
private function add_alias_csv(string $csv): int
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
|
|
|
$csv = str_replace("\r", "\n", $csv);
|
2020-03-02 15:21:27 +00:00
|
|
|
$i = 0;
|
2019-05-28 17:59:38 +01:00
|
|
|
foreach (explode("\n", $csv) as $line) {
|
|
|
|
$parts = str_getcsv($line);
|
|
|
|
if (count($parts) == 2) {
|
|
|
|
try {
|
2020-01-28 21:19:59 +00:00
|
|
|
send_event(new AddAliasEvent($parts[0], $parts[1]));
|
2020-03-02 15:21:27 +00:00
|
|
|
$i++;
|
2019-05-28 17:59:38 +01:00
|
|
|
} catch (AddAliasException $ex) {
|
|
|
|
$this->theme->display_error(500, "Error adding alias", $ex->getMessage());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2020-03-02 15:21:27 +00:00
|
|
|
return $i;
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the priority for this extension.
|
|
|
|
*
|
|
|
|
* Add alias *after* mass tag editing, else the MTE will
|
|
|
|
* search for the images and be redirected to the alias,
|
|
|
|
* missing out the images tagged with the old tag.
|
|
|
|
*/
|
|
|
|
public function get_priority(): int
|
|
|
|
{
|
|
|
|
return 60;
|
|
|
|
}
|
|
|
|
}
|