2009-12-24 07:36:09 +00:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Name: [Beta] Artists System
|
|
|
|
* Author: Sein Kraft <mail@seinkraft.info>
|
|
|
|
* Alpha <alpha@furries.com.ar>
|
|
|
|
* License: GPLv2
|
|
|
|
* Description: Simple artists extension
|
|
|
|
* Documentation:
|
|
|
|
*
|
|
|
|
*/
|
2019-05-28 16:59:38 +00:00
|
|
|
class AuthorSetEvent extends Event
|
|
|
|
{
|
2019-05-28 19:27:23 +00:00
|
|
|
/** @var Image */
|
2019-05-28 16:59:38 +00:00
|
|
|
public $image;
|
2019-05-28 19:27:23 +00:00
|
|
|
/** @var User */
|
2019-05-28 16:59:38 +00:00
|
|
|
public $user;
|
|
|
|
/** @var string */
|
|
|
|
public $author;
|
|
|
|
|
|
|
|
public function __construct(Image $image, User $user, string $author)
|
|
|
|
{
|
2009-12-24 07:36:09 +00:00
|
|
|
$this->image = $image;
|
|
|
|
$this->user = $user;
|
|
|
|
$this->author = $author;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
class Artists extends Extension
|
|
|
|
{
|
|
|
|
public function onImageInfoSet(ImageInfoSetEvent $event)
|
|
|
|
{
|
2009-12-24 07:36:09 +00:00
|
|
|
global $user;
|
2019-05-28 16:59:38 +00:00
|
|
|
if (isset($_POST["tag_edit__author"])) {
|
|
|
|
send_event(new AuthorSetEvent($event->image, $user, $_POST["tag_edit__author"]));
|
|
|
|
}
|
|
|
|
}
|
2009-12-24 07:36:09 +00:00
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
public function onImageInfoBoxBuilding(ImageInfoBoxBuildingEvent $event)
|
|
|
|
{
|
2015-09-27 00:03:58 +00:00
|
|
|
global $user;
|
|
|
|
$artistName = $this->get_artistName_by_imageID($event->image->id);
|
2019-05-28 16:59:38 +00:00
|
|
|
if (!$user->is_anonymous()) {
|
2015-09-27 00:03:58 +00:00
|
|
|
$event->add_part($this->theme->get_author_editor_html($artistName), 42);
|
|
|
|
}
|
2019-05-28 16:59:38 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public function onSearchTermParse(SearchTermParseEvent $event)
|
|
|
|
{
|
|
|
|
$matches = [];
|
|
|
|
if (preg_match("/^author[=|:](.*)$/i", $event->term, $matches)) {
|
|
|
|
$char = $matches[1];
|
|
|
|
$event->add_querylet(new Querylet("Author = :author_char", ["author_char"=>$char]));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public function onInitExt(InitExtEvent $event)
|
|
|
|
{
|
|
|
|
global $config, $database;
|
2009-12-24 07:36:09 +00:00
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
if ($config->get_int("ext_artists_version") < 1) {
|
2012-03-11 02:09:33 +00:00
|
|
|
$database->create_table("artists", "
|
|
|
|
id SCORE_AIPK,
|
|
|
|
user_id INTEGER NOT NULL,
|
|
|
|
name VARCHAR(255) NOT NULL,
|
2014-03-02 18:50:46 +00:00
|
|
|
created SCORE_DATETIME NOT NULL,
|
|
|
|
updated SCORE_DATETIME NOT NULL,
|
2012-03-11 02:09:33 +00:00
|
|
|
notes TEXT,
|
|
|
|
FOREIGN KEY (user_id) REFERENCES users(id) ON UPDATE CASCADE ON DELETE CASCADE
|
|
|
|
");
|
2019-05-28 16:59:38 +00:00
|
|
|
|
2012-03-11 02:09:33 +00:00
|
|
|
$database->create_table("artist_members", "
|
|
|
|
id SCORE_AIPK,
|
|
|
|
artist_id INTEGER NOT NULL,
|
|
|
|
user_id INTEGER NOT NULL,
|
|
|
|
name VARCHAR(255) NOT NULL,
|
2014-03-02 18:50:46 +00:00
|
|
|
created SCORE_DATETIME NOT NULL,
|
|
|
|
updated SCORE_DATETIME NOT NULL,
|
2012-03-11 02:09:33 +00:00
|
|
|
FOREIGN KEY (user_id) REFERENCES users(id) ON UPDATE CASCADE ON DELETE CASCADE,
|
|
|
|
FOREIGN KEY (artist_id) REFERENCES artists (id) ON UPDATE CASCADE ON DELETE CASCADE
|
|
|
|
");
|
|
|
|
$database->create_table("artist_alias", "
|
|
|
|
id SCORE_AIPK,
|
|
|
|
artist_id INTEGER NOT NULL,
|
|
|
|
user_id INTEGER NOT NULL,
|
2014-03-02 18:50:46 +00:00
|
|
|
created SCORE_DATETIME,
|
|
|
|
updated SCORE_DATETIME,
|
2012-03-11 02:09:33 +00:00
|
|
|
alias VARCHAR(255),
|
|
|
|
FOREIGN KEY (user_id) REFERENCES users(id) ON UPDATE CASCADE ON DELETE CASCADE,
|
|
|
|
FOREIGN KEY (artist_id) REFERENCES artists (id) ON UPDATE CASCADE ON DELETE CASCADE
|
|
|
|
");
|
|
|
|
$database->create_table("artist_urls", "
|
|
|
|
id SCORE_AIPK,
|
|
|
|
artist_id INTEGER NOT NULL,
|
|
|
|
user_id INTEGER NOT NULL,
|
2014-03-02 18:50:46 +00:00
|
|
|
created SCORE_DATETIME NOT NULL,
|
|
|
|
updated SCORE_DATETIME NOT NULL,
|
2012-03-11 02:09:33 +00:00
|
|
|
url VARCHAR(1000) NOT NULL,
|
|
|
|
FOREIGN KEY (user_id) REFERENCES users(id) ON UPDATE CASCADE ON DELETE CASCADE,
|
|
|
|
FOREIGN KEY (artist_id) REFERENCES artists (id) ON UPDATE CASCADE ON DELETE CASCADE
|
|
|
|
");
|
2015-09-27 00:03:58 +00:00
|
|
|
$database->execute("ALTER TABLE images ADD COLUMN author VARCHAR(255) NULL");
|
2009-12-24 07:36:09 +00:00
|
|
|
|
|
|
|
$config->set_int("artistsPerPage", 20);
|
|
|
|
$config->set_int("ext_artists_version", 1);
|
|
|
|
|
|
|
|
log_info("artists", "extension installed");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
public function onAuthorSet(AuthorSetEvent $event)
|
|
|
|
{
|
2009-12-24 07:36:09 +00:00
|
|
|
global $database;
|
|
|
|
|
|
|
|
$author = strtolower($event->author);
|
2019-05-28 16:59:38 +00:00
|
|
|
if (strlen($author) === 0 || strpos($author, " ")) {
|
|
|
|
return;
|
|
|
|
}
|
2009-12-24 07:36:09 +00:00
|
|
|
|
|
|
|
$paddedAuthor = str_replace(" ", "_", $author);
|
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
$artistID = null;
|
|
|
|
if ($this->artist_exists($author)) {
|
2009-12-24 07:36:09 +00:00
|
|
|
$artistID = $this->get_artist_id($author);
|
2019-05-28 16:59:38 +00:00
|
|
|
}
|
2009-12-24 07:36:09 +00:00
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
if (is_null($artistID) && $this->alias_exists_by_name($paddedAuthor)) {
|
2009-12-24 07:36:09 +00:00
|
|
|
$artistID = $this->get_artistID_by_aliasName($paddedAuthor);
|
2019-05-28 16:59:38 +00:00
|
|
|
}
|
2009-12-24 07:36:09 +00:00
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
if (is_null($artistID) && $this->member_exists_by_name($paddedAuthor)) {
|
2009-12-24 07:36:09 +00:00
|
|
|
$artistID = $this->get_artistID_by_memberName($paddedAuthor);
|
2019-05-28 16:59:38 +00:00
|
|
|
}
|
2009-12-24 07:36:09 +00:00
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
if (is_null($artistID) && $this->url_exists_by_url($author)) {
|
2009-12-24 07:36:09 +00:00
|
|
|
$artistID = $this->get_artistID_by_url($author);
|
2019-05-28 16:59:38 +00:00
|
|
|
}
|
2009-12-24 07:36:09 +00:00
|
|
|
|
2015-09-27 00:03:58 +00:00
|
|
|
if (!is_null($artistID)) {
|
2009-12-24 07:36:09 +00:00
|
|
|
$artistName = $this->get_artistName_by_artistID($artistID);
|
2019-05-28 16:59:38 +00:00
|
|
|
} else {
|
2009-12-24 07:36:09 +00:00
|
|
|
$this->save_new_artist($author, "");
|
|
|
|
$artistName = $author;
|
|
|
|
}
|
|
|
|
|
2015-09-27 00:03:58 +00:00
|
|
|
$database->execute(
|
|
|
|
"UPDATE images SET author = ? WHERE id = ?",
|
2019-05-28 16:59:38 +00:00
|
|
|
[$artistName, $event->image->id]
|
2015-09-27 00:03:58 +00:00
|
|
|
);
|
2009-12-24 07:36:09 +00:00
|
|
|
}
|
2015-09-27 00:03:58 +00:00
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
public function onPageRequest(PageRequestEvent $event)
|
|
|
|
{
|
2014-03-30 12:26:48 +00:00
|
|
|
global $page, $user;
|
2009-12-24 07:36:09 +00:00
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
if ($event->page_matches("artist")) {
|
|
|
|
switch ($event->get_arg(0)) {
|
2009-12-24 07:36:09 +00:00
|
|
|
//*************ARTIST SECTION**************
|
|
|
|
case "list":
|
|
|
|
{
|
|
|
|
$this->get_listing($page, $event);
|
|
|
|
$this->theme->sidebar_options("neutral");
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case "new":
|
|
|
|
{
|
2019-05-28 16:59:38 +00:00
|
|
|
if (!$user->is_anonymous()) {
|
|
|
|
$this->theme->new_artist_composer();
|
|
|
|
} else {
|
2012-02-16 15:37:05 +00:00
|
|
|
$this->theme->display_error(401, "Error", "You must be registered and logged in to create a new artist.");
|
2009-12-24 07:36:09 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case "new_artist":
|
|
|
|
{
|
|
|
|
$page->set_mode("redirect");
|
|
|
|
$page->set_redirect(make_link("artist/new"));
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case "create":
|
|
|
|
{
|
2019-05-28 16:59:38 +00:00
|
|
|
if (!$user->is_anonymous()) {
|
2009-12-24 07:36:09 +00:00
|
|
|
$newArtistID = $this->add_artist();
|
2015-09-27 00:03:58 +00:00
|
|
|
if ($newArtistID == -1) {
|
2012-02-16 15:37:05 +00:00
|
|
|
$this->theme->display_error(400, "Error", "Error when entering artist data.");
|
2019-05-28 16:59:38 +00:00
|
|
|
} else {
|
2009-12-24 07:36:09 +00:00
|
|
|
$page->set_mode("redirect");
|
|
|
|
$page->set_redirect(make_link("artist/view/".$newArtistID));
|
|
|
|
}
|
2019-05-28 16:59:38 +00:00
|
|
|
} else {
|
2012-02-16 15:37:05 +00:00
|
|
|
$this->theme->display_error(401, "Error", "You must be registered and logged in to create a new artist.");
|
2009-12-24 07:36:09 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
case "view":
|
|
|
|
{
|
|
|
|
$artistID = $event->get_arg(1);
|
|
|
|
$artist = $this->get_artist($artistID);
|
|
|
|
$aliases = $this->get_alias($artist['id']);
|
|
|
|
$members = $this->get_members($artist['id']);
|
|
|
|
$urls = $this->get_urls($artist['id']);
|
|
|
|
|
|
|
|
$userIsLogged = !$user->is_anonymous();
|
|
|
|
$userIsAdmin = $user->is_admin();
|
2019-05-28 16:59:38 +00:00
|
|
|
|
2009-12-24 07:36:09 +00:00
|
|
|
$images = Image::find_images(0, 4, Tag::explode($artist['name']));
|
|
|
|
|
|
|
|
$this->theme->show_artist($artist, $aliases, $members, $urls, $images, $userIsLogged, $userIsAdmin);
|
2015-09-27 00:03:58 +00:00
|
|
|
if ($userIsLogged) {
|
2009-12-24 07:36:09 +00:00
|
|
|
//$this->theme->show_new_alias_composer($artistID);
|
|
|
|
//$this->theme->show_new_member_composer($artistID);
|
|
|
|
//$this->theme->show_new_url_composer($artistID);
|
|
|
|
}
|
2019-05-28 16:59:38 +00:00
|
|
|
|
2009-12-24 07:36:09 +00:00
|
|
|
$this->theme->sidebar_options("editor", $artistID, $userIsAdmin);
|
2019-05-28 16:59:38 +00:00
|
|
|
|
2009-12-24 07:36:09 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
case "edit":
|
|
|
|
{
|
|
|
|
$artistID = $event->get_arg(1);
|
|
|
|
$artist = $this->get_artist($artistID);
|
|
|
|
$aliases = $this->get_alias($artistID);
|
|
|
|
$members = $this->get_members($artistID);
|
|
|
|
$urls = $this->get_urls($artistID);
|
2019-05-28 16:59:38 +00:00
|
|
|
|
|
|
|
if (!$user->is_anonymous()) {
|
|
|
|
$this->theme->show_artist_editor($artist, $aliases, $members, $urls);
|
|
|
|
|
2009-12-24 07:36:09 +00:00
|
|
|
$userIsAdmin = $user->is_admin();
|
|
|
|
$this->theme->sidebar_options("editor", $artistID, $userIsAdmin);
|
2019-05-28 16:59:38 +00:00
|
|
|
} else {
|
2012-02-16 15:37:05 +00:00
|
|
|
$this->theme->display_error(401, "Error", "You must be registered and logged in to edit an artist.");
|
2009-12-24 07:36:09 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case "edit_artist":
|
|
|
|
{
|
|
|
|
$artistID = $_POST['artist_id'];
|
|
|
|
$page->set_mode("redirect");
|
|
|
|
$page->set_redirect(make_link("artist/edit/".$artistID));
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case "edited":
|
|
|
|
{
|
|
|
|
$artistID = int_escape($_POST['id']);
|
|
|
|
$this->update_artist();
|
|
|
|
$page->set_mode("redirect");
|
|
|
|
$page->set_redirect(make_link("artist/view/".$artistID));
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case "nuke_artist":
|
|
|
|
{
|
|
|
|
$artistID = $_POST['artist_id'];
|
|
|
|
$page->set_mode("redirect");
|
|
|
|
$page->set_redirect(make_link("artist/nuke/".$artistID));
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case "nuke":
|
|
|
|
{
|
|
|
|
$artistID = $event->get_arg(1);
|
2015-09-27 00:03:58 +00:00
|
|
|
$this->delete_artist($artistID); // this will delete the artist, its alias, its urls and its members
|
2009-12-24 07:36:09 +00:00
|
|
|
$page->set_mode("redirect");
|
|
|
|
$page->set_redirect(make_link("artist/list"));
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case "add_alias":
|
|
|
|
{
|
|
|
|
$artistID = $_POST['artist_id'];
|
|
|
|
$this->theme->show_new_alias_composer($artistID);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case "add_member":
|
|
|
|
{
|
|
|
|
$artistID = $_POST['artist_id'];
|
|
|
|
$this->theme->show_new_member_composer($artistID);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case "add_url":
|
|
|
|
{
|
|
|
|
$artistID = $_POST['artist_id'];
|
|
|
|
$this->theme->show_new_url_composer($artistID);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
//***********ALIAS SECTION ***********************
|
|
|
|
case "alias":
|
|
|
|
{
|
2019-05-28 16:59:38 +00:00
|
|
|
switch ($event->get_arg(1)) {
|
2009-12-24 07:36:09 +00:00
|
|
|
case "add":
|
|
|
|
{
|
|
|
|
$artistID = $_POST['artistID'];
|
|
|
|
$this->add_alias();
|
|
|
|
$page->set_mode("redirect");
|
|
|
|
$page->set_redirect(make_link("artist/view/".$artistID));
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case "delete":
|
|
|
|
{
|
|
|
|
$aliasID = $event->get_arg(2);
|
|
|
|
$artistID = $this->get_artistID_by_aliasID($aliasID);
|
|
|
|
$this->delete_alias($aliasID);
|
|
|
|
$page->set_mode("redirect");
|
|
|
|
$page->set_redirect(make_link("artist/view/".$artistID));
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case "edit":
|
|
|
|
{
|
|
|
|
$aliasID = int_escape($event->get_arg(2));
|
|
|
|
$alias = $this->get_alias_by_id($aliasID);
|
|
|
|
$this->theme->show_alias_editor($alias);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case "edited":
|
|
|
|
{
|
|
|
|
$this->update_alias();
|
|
|
|
$aliasID = int_escape($_POST['aliasID']);
|
|
|
|
$artistID = $this->get_artistID_by_aliasID($aliasID);
|
|
|
|
$page->set_mode("redirect");
|
|
|
|
$page->set_redirect(make_link("artist/view/".$artistID));
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break; // case: alias
|
|
|
|
}
|
|
|
|
|
|
|
|
//**************** URLS SECTION **********************
|
|
|
|
case "url":
|
|
|
|
{
|
2019-05-28 16:59:38 +00:00
|
|
|
switch ($event->get_arg(1)) {
|
2009-12-24 07:36:09 +00:00
|
|
|
case "add":
|
|
|
|
{
|
|
|
|
$artistID = $_POST['artistID'];
|
|
|
|
$this->add_urls();
|
|
|
|
$page->set_mode("redirect");
|
|
|
|
$page->set_redirect(make_link("artist/view/".$artistID));
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case "delete":
|
|
|
|
{
|
|
|
|
$urlID = $event->get_arg(2);
|
|
|
|
$artistID = $this->get_artistID_by_urlID($urlID);
|
|
|
|
$this->delete_url($urlID);
|
|
|
|
$page->set_mode("redirect");
|
|
|
|
$page->set_redirect(make_link("artist/view/".$artistID));
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case "edit":
|
|
|
|
{
|
|
|
|
$urlID = int_escape($event->get_arg(2));
|
|
|
|
$url = $this->get_url_by_id($urlID);
|
|
|
|
$this->theme->show_url_editor($url);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case "edited":
|
|
|
|
{
|
|
|
|
$this->update_url();
|
|
|
|
$urlID = int_escape($_POST['urlID']);
|
|
|
|
$artistID = $this->get_artistID_by_urlID($urlID);
|
|
|
|
$page->set_mode("redirect");
|
|
|
|
$page->set_redirect(make_link("artist/view/".$artistID));
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break; // case: urls
|
|
|
|
}
|
|
|
|
//******************* MEMBERS SECTION *********************
|
|
|
|
case "member":
|
|
|
|
{
|
2019-05-28 16:59:38 +00:00
|
|
|
switch ($event->get_arg(1)) {
|
2009-12-24 07:36:09 +00:00
|
|
|
case "add":
|
|
|
|
{
|
|
|
|
$artistID = $_POST['artistID'];
|
|
|
|
$this->add_members();
|
|
|
|
$page->set_mode("redirect");
|
|
|
|
$page->set_redirect(make_link("artist/view/".$artistID));
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case "delete":
|
|
|
|
{
|
|
|
|
$memberID = int_escape($event->get_arg(2));
|
|
|
|
$artistID = $this->get_artistID_by_memberID($memberID);
|
|
|
|
$this->delete_member($memberID);
|
|
|
|
$page->set_mode("redirect");
|
|
|
|
$page->set_redirect(make_link("artist/view/".$artistID));
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case "edit":
|
|
|
|
{
|
|
|
|
$memberID = int_escape($event->get_arg(2));
|
|
|
|
$member = $this->get_member_by_id($memberID);
|
|
|
|
$this->theme->show_member_editor($member);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case "edited":
|
|
|
|
{
|
|
|
|
$this->update_member();
|
|
|
|
$memberID = int_escape($_POST['memberID']);
|
|
|
|
$artistID = $this->get_artistID_by_memberID($memberID);
|
|
|
|
$page->set_mode("redirect");
|
|
|
|
$page->set_redirect(make_link("artist/view/".$artistID));
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break; //case: members
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function get_artistName_by_imageID(int $imageID): string
|
|
|
|
{
|
2009-12-24 07:36:09 +00:00
|
|
|
global $database;
|
2019-05-28 16:59:38 +00:00
|
|
|
$result = $database->get_row("SELECT author FROM images WHERE id = ?", [$imageID]);
|
2009-12-24 07:36:09 +00:00
|
|
|
return stripslashes($result['author']);
|
|
|
|
}
|
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function url_exists_by_url(string $url): bool
|
|
|
|
{
|
2009-12-24 07:36:09 +00:00
|
|
|
global $database;
|
2019-05-28 16:59:38 +00:00
|
|
|
$result = $database->get_one("SELECT COUNT(1) FROM artist_urls WHERE url = ?", [$url]);
|
2009-12-24 07:36:09 +00:00
|
|
|
return ($result != 0);
|
|
|
|
}
|
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function member_exists_by_name(string $member): bool
|
|
|
|
{
|
2009-12-24 07:36:09 +00:00
|
|
|
global $database;
|
2019-05-28 16:59:38 +00:00
|
|
|
$result = $database->get_one("SELECT COUNT(1) FROM artist_members WHERE name = ?", [$member]);
|
2009-12-24 07:36:09 +00:00
|
|
|
return ($result != 0);
|
|
|
|
}
|
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function alias_exists_by_name(string $alias): bool
|
|
|
|
{
|
2009-12-24 07:36:09 +00:00
|
|
|
global $database;
|
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
$result = $database->get_one("SELECT COUNT(1) FROM artist_alias WHERE alias = ?", [$alias]);
|
2009-12-24 07:36:09 +00:00
|
|
|
return ($result != 0);
|
|
|
|
}
|
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function alias_exists(int $artistID, string $alias): bool
|
|
|
|
{
|
2009-12-24 07:36:09 +00:00
|
|
|
global $database;
|
2015-09-27 00:03:58 +00:00
|
|
|
$result = $database->get_one(
|
|
|
|
"SELECT COUNT(1) FROM artist_alias WHERE artist_id = ? AND alias = ?",
|
2019-05-28 16:59:38 +00:00
|
|
|
[$artistID, $alias]
|
2015-09-27 00:03:58 +00:00
|
|
|
);
|
2009-12-24 07:36:09 +00:00
|
|
|
return ($result != 0);
|
|
|
|
}
|
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function get_artistID_by_url(string $url): int
|
|
|
|
{
|
2009-12-24 07:36:09 +00:00
|
|
|
global $database;
|
2019-05-28 16:59:38 +00:00
|
|
|
return $database->get_one("SELECT artist_id FROM artist_urls WHERE url = ?", [$url]);
|
2009-12-24 07:36:09 +00:00
|
|
|
}
|
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function get_artistID_by_memberName(string $member): int
|
|
|
|
{
|
2009-12-24 07:36:09 +00:00
|
|
|
global $database;
|
2019-05-28 16:59:38 +00:00
|
|
|
return $database->get_one("SELECT artist_id FROM artist_members WHERE name = ?", [$member]);
|
2009-12-24 07:36:09 +00:00
|
|
|
}
|
2015-09-27 00:03:58 +00:00
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function get_artistName_by_artistID(int $artistID): string
|
|
|
|
{
|
2009-12-24 07:36:09 +00:00
|
|
|
global $database;
|
2019-05-28 16:59:38 +00:00
|
|
|
return $database->get_one("SELECT name FROM artists WHERE id = ?", [$artistID]);
|
2009-12-24 07:36:09 +00:00
|
|
|
}
|
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function get_artistID_by_aliasID(int $aliasID): int
|
|
|
|
{
|
2009-12-24 07:36:09 +00:00
|
|
|
global $database;
|
2019-05-28 16:59:38 +00:00
|
|
|
return $database->get_one("SELECT artist_id FROM artist_alias WHERE id = ?", [$aliasID]);
|
2009-12-24 07:36:09 +00:00
|
|
|
}
|
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function get_artistID_by_memberID(int $memberID): int
|
|
|
|
{
|
2009-12-24 07:36:09 +00:00
|
|
|
global $database;
|
2019-05-28 16:59:38 +00:00
|
|
|
return $database->get_one("SELECT artist_id FROM artist_members WHERE id = ?", [$memberID]);
|
2009-12-24 07:36:09 +00:00
|
|
|
}
|
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function get_artistID_by_urlID(int $urlID): int
|
|
|
|
{
|
2009-12-24 07:36:09 +00:00
|
|
|
global $database;
|
2019-05-28 16:59:38 +00:00
|
|
|
return $database->get_one("SELECT artist_id FROM artist_urls WHERE id = ?", [$urlID]);
|
2009-12-24 07:36:09 +00:00
|
|
|
}
|
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function delete_alias(int $aliasID)
|
|
|
|
{
|
2009-12-24 07:36:09 +00:00
|
|
|
global $database;
|
2019-05-28 16:59:38 +00:00
|
|
|
$database->execute("DELETE FROM artist_alias WHERE id = ?", [$aliasID]);
|
2009-12-24 07:36:09 +00:00
|
|
|
}
|
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function delete_url(int $urlID)
|
|
|
|
{
|
2009-12-24 07:36:09 +00:00
|
|
|
global $database;
|
2019-05-28 16:59:38 +00:00
|
|
|
$database->execute("DELETE FROM artist_urls WHERE id = ?", [$urlID]);
|
2009-12-24 07:36:09 +00:00
|
|
|
}
|
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function delete_member(int $memberID)
|
|
|
|
{
|
2009-12-24 07:36:09 +00:00
|
|
|
global $database;
|
2019-05-28 16:59:38 +00:00
|
|
|
$database->execute("DELETE FROM artist_members WHERE id = ?", [$memberID]);
|
2009-12-24 07:36:09 +00:00
|
|
|
}
|
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function get_alias_by_id(int $aliasID): array
|
|
|
|
{
|
2009-12-24 07:36:09 +00:00
|
|
|
global $database;
|
2019-05-28 16:59:38 +00:00
|
|
|
$result = $database->get_row("SELECT * FROM artist_alias WHERE id = ?", [$aliasID]);
|
2009-12-24 07:36:09 +00:00
|
|
|
$result["alias"] = stripslashes($result["alias"]);
|
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function get_url_by_id(int $urlID): array
|
|
|
|
{
|
2009-12-24 07:36:09 +00:00
|
|
|
global $database;
|
2019-05-28 16:59:38 +00:00
|
|
|
$result = $database->get_row("SELECT * FROM artist_urls WHERE id = ?", [$urlID]);
|
2009-12-24 07:36:09 +00:00
|
|
|
$result["url"] = stripslashes($result["url"]);
|
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function get_member_by_id(int $memberID): array
|
|
|
|
{
|
2009-12-24 07:36:09 +00:00
|
|
|
global $database;
|
2019-05-28 16:59:38 +00:00
|
|
|
$result = $database->get_row("SELECT * FROM artist_members WHERE id = ?", [$memberID]);
|
2009-12-24 07:36:09 +00:00
|
|
|
$result["name"] = stripslashes($result["name"]);
|
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function update_artist()
|
|
|
|
{
|
2009-12-24 07:36:09 +00:00
|
|
|
global $user;
|
2019-05-28 16:59:38 +00:00
|
|
|
$inputs = validate_input([
|
2015-09-27 00:03:58 +00:00
|
|
|
'id' => 'int',
|
|
|
|
'name' => 'string,lower',
|
|
|
|
'notes' => 'string,trim,nullify',
|
|
|
|
'aliases' => 'string,trim,nullify',
|
|
|
|
'aliasesIDs' => 'string,trim,nullify',
|
|
|
|
'members' => 'string,trim,nullify',
|
2019-05-28 16:59:38 +00:00
|
|
|
]);
|
2015-09-27 00:03:58 +00:00
|
|
|
$artistID = $inputs['id'];
|
|
|
|
$name = $inputs['name'];
|
|
|
|
$notes = $inputs['notes'];
|
2009-12-24 07:36:09 +00:00
|
|
|
$userID = $user->id;
|
|
|
|
|
2015-09-27 00:03:58 +00:00
|
|
|
$aliasesAsString = $inputs["aliases"];
|
|
|
|
$aliasesIDsAsString = $inputs["aliasesIDs"];
|
2009-12-24 07:36:09 +00:00
|
|
|
|
2015-09-27 00:03:58 +00:00
|
|
|
$membersAsString = $inputs["members"];
|
|
|
|
$membersIDsAsString = $inputs["membersIDs"];
|
2009-12-24 07:36:09 +00:00
|
|
|
|
2015-09-27 00:03:58 +00:00
|
|
|
$urlsAsString = $inputs["urls"];
|
|
|
|
$urlsIDsAsString = $inputs["urlsIDs"];
|
2009-12-24 07:36:09 +00:00
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
if (strpos($name, " ")) {
|
2009-12-24 07:36:09 +00:00
|
|
|
return;
|
2019-05-28 16:59:38 +00:00
|
|
|
}
|
2009-12-24 07:36:09 +00:00
|
|
|
|
|
|
|
global $database;
|
2015-09-27 00:03:58 +00:00
|
|
|
$database->execute(
|
|
|
|
"UPDATE artists SET name = ?, notes = ?, updated = now(), user_id = ? WHERE id = ? ",
|
2019-05-28 16:59:38 +00:00
|
|
|
[$name, $notes, $userID, $artistID]
|
2015-09-27 00:03:58 +00:00
|
|
|
);
|
2009-12-24 07:36:09 +00:00
|
|
|
|
|
|
|
// ALIAS MATCHING SECTION
|
|
|
|
$i = 0;
|
2019-05-28 16:59:38 +00:00
|
|
|
$aliasesAsArray = is_null($aliasesAsString) ? [] : explode(" ", $aliasesAsString);
|
|
|
|
$aliasesIDsAsArray = is_null($aliasesIDsAsString) ? [] : explode(" ", $aliasesIDsAsString);
|
|
|
|
while ($i < count($aliasesAsArray)) {
|
2009-12-24 07:36:09 +00:00
|
|
|
// if an alias was updated
|
2019-05-28 16:59:38 +00:00
|
|
|
if ($i < count($aliasesIDsAsArray)) {
|
2009-12-24 07:36:09 +00:00
|
|
|
$this->save_existing_alias($aliasesIDsAsArray[$i], $aliasesAsArray[$i], $userID);
|
2019-05-28 16:59:38 +00:00
|
|
|
} else {
|
2009-12-24 07:36:09 +00:00
|
|
|
// if we already updated all, save new ones
|
|
|
|
$this->save_new_alias($artistID, $aliasesAsArray[$i], $userID);
|
2019-05-28 16:59:38 +00:00
|
|
|
}
|
2009-12-24 07:36:09 +00:00
|
|
|
|
|
|
|
$i++;
|
|
|
|
}
|
|
|
|
// if we have more ids than alias, then some alias have been deleted -- delete them from db
|
2019-05-28 16:59:38 +00:00
|
|
|
while ($i < count($aliasesIDsAsArray)) {
|
2009-12-24 07:36:09 +00:00
|
|
|
$this->delete_alias($aliasesIDsAsArray[$i++]);
|
2019-05-28 16:59:38 +00:00
|
|
|
}
|
2009-12-24 07:36:09 +00:00
|
|
|
|
|
|
|
// MEMBERS MATCHING SECTION
|
|
|
|
$i = 0;
|
2019-05-28 16:59:38 +00:00
|
|
|
$membersAsArray = is_null($membersAsString) ? [] : explode(" ", $membersAsString);
|
|
|
|
$membersIDsAsArray = is_null($membersIDsAsString) ? [] : explode(" ", $membersIDsAsString);
|
|
|
|
while ($i < count($membersAsArray)) {
|
2009-12-24 07:36:09 +00:00
|
|
|
// if a member was updated
|
2019-05-28 16:59:38 +00:00
|
|
|
if ($i < count($membersIDsAsArray)) {
|
2009-12-24 07:36:09 +00:00
|
|
|
$this->save_existing_member($membersIDsAsArray[$i], $membersAsArray[$i], $userID);
|
2019-05-28 16:59:38 +00:00
|
|
|
} else {
|
2009-12-24 07:36:09 +00:00
|
|
|
// if we already updated all, save new ones
|
2015-09-12 10:43:28 +00:00
|
|
|
$this->save_new_member($artistID, $membersAsArray[$i], $userID);
|
2019-05-28 16:59:38 +00:00
|
|
|
}
|
2009-12-24 07:36:09 +00:00
|
|
|
|
|
|
|
$i++;
|
|
|
|
}
|
|
|
|
// if we have more ids than members, then some members have been deleted -- delete them from db
|
2019-05-28 16:59:38 +00:00
|
|
|
while ($i < count($membersIDsAsArray)) {
|
2009-12-24 07:36:09 +00:00
|
|
|
$this->delete_member($membersIDsAsArray[$i++]);
|
2019-05-28 16:59:38 +00:00
|
|
|
}
|
2009-12-24 07:36:09 +00:00
|
|
|
|
|
|
|
// URLS MATCHING SECTION
|
|
|
|
$i = 0;
|
|
|
|
$urlsAsString = str_replace("\r\n", "\n", $urlsAsString);
|
|
|
|
$urlsAsString = str_replace("\n\r", "\n", $urlsAsString);
|
2019-05-28 16:59:38 +00:00
|
|
|
$urlsAsArray = is_null($urlsAsString) ? [] : explode("\n", $urlsAsString);
|
|
|
|
$urlsIDsAsArray = is_null($urlsIDsAsString) ? [] : explode(" ", $urlsIDsAsString);
|
|
|
|
while ($i < count($urlsAsArray)) {
|
2009-12-24 07:36:09 +00:00
|
|
|
// if an URL was updated
|
2015-09-27 00:03:58 +00:00
|
|
|
if ($i < count($urlsIDsAsArray)) {
|
2009-12-24 07:36:09 +00:00
|
|
|
$this->save_existing_url($urlsIDsAsArray[$i], $urlsAsArray[$i], $userID);
|
2019-05-28 16:59:38 +00:00
|
|
|
} else {
|
2009-12-24 07:36:09 +00:00
|
|
|
$this->save_new_url($artistID, $urlsAsArray[$i], $userID);
|
|
|
|
}
|
|
|
|
|
|
|
|
$i++;
|
|
|
|
}
|
|
|
|
|
|
|
|
// if we have more ids than urls, then some urls have been deleted -- delete them from db
|
2019-05-28 16:59:38 +00:00
|
|
|
while ($i < count($urlsIDsAsArray)) {
|
2009-12-24 07:36:09 +00:00
|
|
|
$this->delete_url($urlsIDsAsArray[$i++]);
|
2019-05-28 16:59:38 +00:00
|
|
|
}
|
2009-12-24 07:36:09 +00:00
|
|
|
}
|
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function update_alias()
|
|
|
|
{
|
2009-12-24 07:36:09 +00:00
|
|
|
global $user;
|
2019-05-28 16:59:38 +00:00
|
|
|
$inputs = validate_input([
|
2015-09-27 00:03:58 +00:00
|
|
|
"aliasID" => "int",
|
|
|
|
"alias" => "string,lower",
|
2019-05-28 16:59:38 +00:00
|
|
|
]);
|
2015-09-27 00:03:58 +00:00
|
|
|
$this->save_existing_alias($inputs['aliasID'], $inputs['alias'], $user->id);
|
2009-12-24 07:36:09 +00:00
|
|
|
}
|
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function save_existing_alias(int $aliasID, string $alias, int $userID)
|
|
|
|
{
|
2009-12-24 07:36:09 +00:00
|
|
|
global $database;
|
2015-09-27 00:03:58 +00:00
|
|
|
$database->execute(
|
|
|
|
"UPDATE artist_alias SET alias = ?, updated = now(), user_id = ? WHERE id = ? ",
|
2019-05-28 16:59:38 +00:00
|
|
|
[$alias, $userID, $aliasID]
|
2015-09-27 00:03:58 +00:00
|
|
|
);
|
2009-12-24 07:36:09 +00:00
|
|
|
}
|
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function update_url()
|
|
|
|
{
|
2009-12-24 07:36:09 +00:00
|
|
|
global $user;
|
2019-05-28 16:59:38 +00:00
|
|
|
$inputs = validate_input([
|
2015-09-27 00:03:58 +00:00
|
|
|
"urlID" => "int",
|
|
|
|
"url" => "string",
|
2019-05-28 16:59:38 +00:00
|
|
|
]);
|
2015-09-27 00:03:58 +00:00
|
|
|
$this->save_existing_url($inputs['urlID'], $inputs['url'], $user->id);
|
2009-12-24 07:36:09 +00:00
|
|
|
}
|
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function save_existing_url(int $urlID, string $url, int $userID)
|
|
|
|
{
|
2009-12-24 07:36:09 +00:00
|
|
|
global $database;
|
2015-09-27 00:03:58 +00:00
|
|
|
$database->execute(
|
|
|
|
"UPDATE artist_urls SET url = ?, updated = now(), user_id = ? WHERE id = ?",
|
2019-05-28 16:59:38 +00:00
|
|
|
[$url, $userID, $urlID]
|
2015-09-27 00:03:58 +00:00
|
|
|
);
|
2009-12-24 07:36:09 +00:00
|
|
|
}
|
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function update_member()
|
|
|
|
{
|
2015-09-27 00:03:58 +00:00
|
|
|
global $user;
|
2019-05-28 16:59:38 +00:00
|
|
|
$inputs = validate_input([
|
2015-09-27 00:03:58 +00:00
|
|
|
"memberID" => "int",
|
|
|
|
"name" => "string,lower",
|
2019-05-28 16:59:38 +00:00
|
|
|
]);
|
2015-09-27 00:03:58 +00:00
|
|
|
$this->save_existing_member($inputs['memberID'], $inputs['name'], $user->id);
|
2009-12-24 07:36:09 +00:00
|
|
|
}
|
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function save_existing_member(int $memberID, string $memberName, int $userID)
|
|
|
|
{
|
2009-12-24 07:36:09 +00:00
|
|
|
global $database;
|
2015-09-27 00:03:58 +00:00
|
|
|
$database->execute(
|
|
|
|
"UPDATE artist_members SET name = ?, updated = now(), user_id = ? WHERE id = ?",
|
2019-05-28 16:59:38 +00:00
|
|
|
[$memberName, $userID, $memberID]
|
2015-09-27 00:03:58 +00:00
|
|
|
);
|
2009-12-24 07:36:09 +00:00
|
|
|
}
|
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function add_artist()
|
|
|
|
{
|
2009-12-24 07:36:09 +00:00
|
|
|
global $user;
|
2019-05-28 16:59:38 +00:00
|
|
|
$inputs = validate_input([
|
2015-09-27 00:03:58 +00:00
|
|
|
"name" => "string,lower",
|
|
|
|
"notes" => "string,optional",
|
|
|
|
"aliases" => "string,lower,optional",
|
|
|
|
"members" => "string,lower,optional",
|
|
|
|
"urls" => "string,optional"
|
2019-05-28 16:59:38 +00:00
|
|
|
]);
|
2015-09-27 00:03:58 +00:00
|
|
|
|
|
|
|
$name = $inputs["name"];
|
2019-05-28 16:59:38 +00:00
|
|
|
if (strpos($name, " ")) {
|
2009-12-24 07:36:09 +00:00
|
|
|
return -1;
|
2019-05-28 16:59:38 +00:00
|
|
|
}
|
2009-12-24 07:36:09 +00:00
|
|
|
|
2015-09-27 00:03:58 +00:00
|
|
|
$notes = $inputs["notes"];
|
2009-12-24 07:36:09 +00:00
|
|
|
|
2015-09-27 00:03:58 +00:00
|
|
|
$aliases = $inputs["aliases"];
|
|
|
|
$members = $inputs["members"];
|
|
|
|
$urls = $inputs["urls"];
|
2009-12-24 07:36:09 +00:00
|
|
|
$userID = $user->id;
|
|
|
|
|
2014-04-19 06:33:34 +00:00
|
|
|
//$artistID = "";
|
2009-12-24 07:36:09 +00:00
|
|
|
|
|
|
|
//// WE CHECK IF THE ARTIST ALREADY EXISTS ON DATABASE; IF NOT WE CREATE
|
2019-05-28 16:59:38 +00:00
|
|
|
if (!$this->artist_exists($name)) {
|
2009-12-24 07:36:09 +00:00
|
|
|
$artistID = $this->save_new_artist($name, $notes);
|
|
|
|
log_info("artists", "Artist {$artistID} created by {$user->name}");
|
2019-05-28 16:59:38 +00:00
|
|
|
} else {
|
2009-12-24 07:36:09 +00:00
|
|
|
$artistID = $this->get_artist_id($name);
|
2015-09-27 00:03:58 +00:00
|
|
|
}
|
2009-12-24 07:36:09 +00:00
|
|
|
|
2015-09-27 00:03:58 +00:00
|
|
|
if (!is_null($aliases)) {
|
2009-12-24 07:36:09 +00:00
|
|
|
$aliasArray = explode(" ", $aliases);
|
2019-05-28 16:59:38 +00:00
|
|
|
foreach ($aliasArray as $alias) {
|
|
|
|
if (!$this->alias_exists($artistID, $alias)) {
|
2009-12-24 07:36:09 +00:00
|
|
|
$this->save_new_alias($artistID, $alias, $userID);
|
2019-05-28 16:59:38 +00:00
|
|
|
}
|
|
|
|
}
|
2009-12-24 07:36:09 +00:00
|
|
|
}
|
|
|
|
|
2015-09-27 00:03:58 +00:00
|
|
|
if (!is_null($members)) {
|
2009-12-24 07:36:09 +00:00
|
|
|
$membersArray = explode(" ", $members);
|
2019-05-28 16:59:38 +00:00
|
|
|
foreach ($membersArray as $member) {
|
|
|
|
if (!$this->member_exists($artistID, $member)) {
|
2015-09-12 10:43:28 +00:00
|
|
|
$this->save_new_member($artistID, $member, $userID);
|
2019-05-28 16:59:38 +00:00
|
|
|
}
|
|
|
|
}
|
2009-12-24 07:36:09 +00:00
|
|
|
}
|
|
|
|
|
2015-09-27 00:03:58 +00:00
|
|
|
if (!is_null($urls)) {
|
2009-12-24 07:36:09 +00:00
|
|
|
//delete double "separators"
|
|
|
|
$urls = str_replace("\r\n", "\n", $urls);
|
|
|
|
$urls = str_replace("\n\r", "\n", $urls);
|
|
|
|
|
|
|
|
$urlsArray = explode("\n", $urls);
|
2019-05-28 16:59:38 +00:00
|
|
|
foreach ($urlsArray as $url) {
|
|
|
|
if (!$this->url_exists($artistID, $url)) {
|
2009-12-24 07:36:09 +00:00
|
|
|
$this->save_new_url($artistID, $url, $userID);
|
2019-05-28 16:59:38 +00:00
|
|
|
}
|
|
|
|
}
|
2009-12-24 07:36:09 +00:00
|
|
|
}
|
|
|
|
return $artistID;
|
|
|
|
}
|
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function save_new_artist(string $name, string $notes): int
|
|
|
|
{
|
2009-12-24 07:36:09 +00:00
|
|
|
global $database, $user;
|
|
|
|
$database->execute("
|
2015-09-27 00:03:58 +00:00
|
|
|
INSERT INTO artists (user_id, name, notes, created, updated)
|
|
|
|
VALUES (?, ?, ?, now(), now())
|
2019-05-28 16:59:38 +00:00
|
|
|
", [$user->id, $name, $notes]);
|
2016-06-19 03:57:14 +00:00
|
|
|
return $database->get_last_insert_id('artists_id_seq');
|
2009-12-24 07:36:09 +00:00
|
|
|
}
|
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function artist_exists(string $name): bool
|
|
|
|
{
|
2009-12-24 07:36:09 +00:00
|
|
|
global $database;
|
2015-09-27 00:03:58 +00:00
|
|
|
$result = $database->get_one(
|
|
|
|
"SELECT COUNT(1) FROM artists WHERE name = ?",
|
2019-05-28 16:59:38 +00:00
|
|
|
[$name]
|
2015-09-27 00:03:58 +00:00
|
|
|
);
|
2009-12-24 07:36:09 +00:00
|
|
|
return ($result != 0);
|
|
|
|
}
|
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function get_artist(int $artistID): array
|
|
|
|
{
|
2009-12-24 07:36:09 +00:00
|
|
|
global $database;
|
2015-09-27 00:03:58 +00:00
|
|
|
$result = $database->get_row(
|
|
|
|
"SELECT * FROM artists WHERE id = ?",
|
2019-05-28 16:59:38 +00:00
|
|
|
[$artistID]
|
2015-09-27 00:03:58 +00:00
|
|
|
);
|
2009-12-24 07:36:09 +00:00
|
|
|
|
|
|
|
$result["name"] = stripslashes($result["name"]);
|
|
|
|
$result["notes"] = stripslashes($result["notes"]);
|
|
|
|
|
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function get_members(int $artistID): array
|
|
|
|
{
|
2009-12-24 07:36:09 +00:00
|
|
|
global $database;
|
2015-09-27 00:03:58 +00:00
|
|
|
$result = $database->get_all(
|
|
|
|
"SELECT * FROM artist_members WHERE artist_id = ?",
|
2019-05-28 16:59:38 +00:00
|
|
|
[$artistID]
|
2015-09-27 00:03:58 +00:00
|
|
|
);
|
2019-05-28 16:59:38 +00:00
|
|
|
|
|
|
|
$num = count($result);
|
2015-09-27 00:03:58 +00:00
|
|
|
for ($i = 0 ; $i < $num ; $i++) {
|
2009-12-24 07:36:09 +00:00
|
|
|
$result[$i]["name"] = stripslashes($result[$i]["name"]);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $result;
|
|
|
|
}
|
2015-09-27 00:03:58 +00:00
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function get_urls(int $artistID): array
|
|
|
|
{
|
2009-12-24 07:36:09 +00:00
|
|
|
global $database;
|
2015-09-27 00:03:58 +00:00
|
|
|
$result = $database->get_all(
|
|
|
|
"SELECT id, url FROM artist_urls WHERE artist_id = ?",
|
2019-05-28 16:59:38 +00:00
|
|
|
[$artistID]
|
2015-09-27 00:03:58 +00:00
|
|
|
);
|
2019-05-28 16:59:38 +00:00
|
|
|
|
|
|
|
$num = count($result);
|
2015-09-27 00:03:58 +00:00
|
|
|
for ($i = 0 ; $i < $num ; $i++) {
|
2009-12-24 07:36:09 +00:00
|
|
|
$result[$i]["url"] = stripslashes($result[$i]["url"]);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function get_artist_id(string $name): int
|
|
|
|
{
|
|
|
|
global $database;
|
|
|
|
return (int)$database->get_one(
|
2015-09-27 00:03:58 +00:00
|
|
|
"SELECT id FROM artists WHERE name = ?",
|
2019-05-28 16:59:38 +00:00
|
|
|
[$name]
|
2015-09-27 00:03:58 +00:00
|
|
|
);
|
2019-05-28 16:59:38 +00:00
|
|
|
}
|
2009-12-24 07:36:09 +00:00
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function get_artistID_by_aliasName(string $alias): int
|
|
|
|
{
|
2015-09-27 00:03:58 +00:00
|
|
|
global $database;
|
2009-12-24 07:36:09 +00:00
|
|
|
|
2015-09-27 00:03:58 +00:00
|
|
|
return (int)$database->get_one(
|
|
|
|
"SELECT artist_id FROM artist_alias WHERE alias = ?",
|
2019-05-28 16:59:38 +00:00
|
|
|
[$alias]
|
2015-09-27 00:03:58 +00:00
|
|
|
);
|
|
|
|
}
|
2009-12-24 07:36:09 +00:00
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function delete_artist(int $artistID)
|
|
|
|
{
|
2015-09-27 00:03:58 +00:00
|
|
|
global $database;
|
|
|
|
$database->execute(
|
|
|
|
"DELETE FROM artists WHERE id = ? ",
|
2019-05-28 16:59:38 +00:00
|
|
|
[$artistID]
|
2015-09-27 00:03:58 +00:00
|
|
|
);
|
2019-05-28 16:59:38 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* HERE WE GET THE LIST OF ALL ARTIST WITH PAGINATION
|
|
|
|
*/
|
|
|
|
private function get_listing(Page $page, PageRequestEvent $event)
|
|
|
|
{
|
|
|
|
global $config, $database;
|
|
|
|
|
|
|
|
$pageNumber = clamp($event->get_arg(1), 1, null) - 1;
|
|
|
|
$artistsPerPage = $config->get_int("artistsPerPage");
|
|
|
|
|
|
|
|
$listing = $database->get_all(
|
|
|
|
"
|
2009-12-24 07:36:09 +00:00
|
|
|
(
|
|
|
|
SELECT a.id, a.user_id, a.name, u.name AS user_name, COALESCE(t.count, 0) AS posts
|
|
|
|
, 'artist' as type, a.id AS artist_id, a.name AS artist_name, a.updated
|
|
|
|
FROM artists AS a
|
|
|
|
INNER JOIN users AS u
|
|
|
|
ON a.user_id = u.id
|
|
|
|
LEFT OUTER JOIN tags AS t
|
|
|
|
ON a.name = t.tag
|
|
|
|
GROUP BY a.id, a.user_id, a.name, u.name
|
|
|
|
ORDER BY a.updated DESC
|
|
|
|
)
|
|
|
|
|
|
|
|
UNION
|
|
|
|
|
|
|
|
(
|
|
|
|
SELECT aa.id, aa.user_id, aa.alias AS name, u.name AS user_name, COALESCE(t.count, 0) AS posts
|
|
|
|
, 'alias' as type, a.id AS artist_id, a.name AS artist_name, aa.updated
|
|
|
|
FROM artist_alias AS aa
|
|
|
|
INNER JOIN users AS u
|
|
|
|
ON aa.user_id = u.id
|
|
|
|
INNER JOIN artists AS a
|
|
|
|
ON aa.artist_id = a.id
|
|
|
|
LEFT OUTER JOIN tags AS t
|
|
|
|
ON aa.alias = t.tag
|
|
|
|
GROUP BY aa.id, a.user_id, aa.alias, u.name, a.id, a.name
|
|
|
|
ORDER BY aa.updated DESC
|
|
|
|
)
|
|
|
|
|
|
|
|
UNION
|
|
|
|
|
|
|
|
(
|
|
|
|
SELECT m.id, m.user_id, m.name AS name, u.name AS user_name, COALESCE(t.count, 0) AS posts
|
|
|
|
, 'member' AS type, a.id AS artist_id, a.name AS artist_name, m.updated
|
|
|
|
FROM artist_members AS m
|
|
|
|
INNER JOIN users AS u
|
|
|
|
ON m.user_id = u.id
|
|
|
|
INNER JOIN artists AS a
|
|
|
|
ON m.artist_id = a.id
|
|
|
|
LEFT OUTER JOIN tags AS t
|
|
|
|
ON m.name = t.tag
|
|
|
|
GROUP BY m.id, m.user_id, m.name, u.name, a.id, a.name
|
|
|
|
ORDER BY m.updated DESC
|
|
|
|
)
|
|
|
|
ORDER BY updated DESC
|
|
|
|
LIMIT ?, ?
|
2019-05-28 16:59:38 +00:00
|
|
|
",
|
|
|
|
[
|
2009-12-24 07:36:09 +00:00
|
|
|
$pageNumber * $artistsPerPage
|
|
|
|
, $artistsPerPage
|
2019-05-28 16:59:38 +00:00
|
|
|
]
|
|
|
|
);
|
|
|
|
|
|
|
|
$number_of_listings = count($listing);
|
|
|
|
|
|
|
|
for ($i = 0 ; $i < $number_of_listings ; $i++) {
|
|
|
|
$listing[$i]["name"] = stripslashes($listing[$i]["name"]);
|
|
|
|
$listing[$i]["user_name"] = stripslashes($listing[$i]["user_name"]);
|
|
|
|
$listing[$i]["artist_name"] = stripslashes($listing[$i]["artist_name"]);
|
|
|
|
}
|
2009-12-24 07:36:09 +00:00
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
$count = $database->get_one("
|
2015-09-27 00:03:58 +00:00
|
|
|
SELECT COUNT(1)
|
2009-12-24 07:36:09 +00:00
|
|
|
FROM artists AS a
|
|
|
|
LEFT OUTER JOIN artist_members AS am
|
|
|
|
ON a.id = am.artist_id
|
|
|
|
LEFT OUTER JOIN artist_alias AS aa
|
|
|
|
ON a.id = aa.artist_id
|
2015-09-27 00:03:58 +00:00
|
|
|
");
|
2009-12-24 07:36:09 +00:00
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
$totalPages = ceil($count / $artistsPerPage);
|
2009-12-24 07:36:09 +00:00
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
$this->theme->list_artists($listing, $pageNumber + 1, $totalPages);
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* HERE WE ADD AN ALIAS
|
|
|
|
*/
|
|
|
|
private function add_urls()
|
|
|
|
{
|
2015-09-27 00:03:58 +00:00
|
|
|
global $user;
|
2019-05-28 16:59:38 +00:00
|
|
|
$inputs = validate_input([
|
2015-09-27 00:03:58 +00:00
|
|
|
"artistID" => "int",
|
|
|
|
"urls" => "string",
|
2019-05-28 16:59:38 +00:00
|
|
|
]);
|
2015-09-27 00:03:58 +00:00
|
|
|
$artistID = $inputs["artistID"];
|
|
|
|
$urls = explode("\n", $inputs["urls"]);
|
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
foreach ($urls as $url) {
|
|
|
|
if (!$this->url_exists($artistID, $url)) {
|
2015-09-27 00:03:58 +00:00
|
|
|
$this->save_new_url($artistID, $url, $user->id);
|
2019-05-28 16:59:38 +00:00
|
|
|
}
|
|
|
|
}
|
2015-09-27 00:03:58 +00:00
|
|
|
}
|
2009-12-24 07:36:09 +00:00
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function save_new_url(int $artistID, string $url, int $userID)
|
|
|
|
{
|
2015-09-27 00:03:58 +00:00
|
|
|
global $database;
|
2009-12-24 07:36:09 +00:00
|
|
|
|
2015-09-27 00:03:58 +00:00
|
|
|
$database->execute(
|
|
|
|
"INSERT INTO artist_urls (artist_id, created, updated, url, user_id) VALUES (?, now(), now(), ?, ?)",
|
2019-05-28 16:59:38 +00:00
|
|
|
[$artistID, $url, $userID]
|
2015-09-27 00:03:58 +00:00
|
|
|
);
|
|
|
|
}
|
2009-12-24 07:36:09 +00:00
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function add_alias()
|
|
|
|
{
|
2015-09-27 00:03:58 +00:00
|
|
|
global $user;
|
2019-05-28 16:59:38 +00:00
|
|
|
$inputs = validate_input([
|
2015-09-27 00:03:58 +00:00
|
|
|
"artistID" => "int",
|
|
|
|
"aliases" => "string,lower",
|
2019-05-28 16:59:38 +00:00
|
|
|
]);
|
2015-09-27 00:03:58 +00:00
|
|
|
$artistID = $inputs["artistID"];
|
|
|
|
$aliases = explode(" ", $inputs["aliases"]);
|
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
foreach ($aliases as $alias) {
|
|
|
|
if (!$this->alias_exists($artistID, $alias)) {
|
2015-09-27 00:03:58 +00:00
|
|
|
$this->save_new_alias($artistID, $alias, $user->id);
|
2019-05-28 16:59:38 +00:00
|
|
|
}
|
|
|
|
}
|
2015-09-27 00:03:58 +00:00
|
|
|
}
|
2009-12-24 07:36:09 +00:00
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function save_new_alias(int $artistID, string $alias, int $userID)
|
|
|
|
{
|
2015-09-27 00:03:58 +00:00
|
|
|
global $database;
|
2009-12-24 07:36:09 +00:00
|
|
|
|
2015-09-27 00:03:58 +00:00
|
|
|
$database->execute(
|
|
|
|
"INSERT INTO artist_alias (artist_id, created, updated, alias, user_id) VALUES (?, now(), now(), ?, ?)",
|
2019-05-28 16:59:38 +00:00
|
|
|
[$artistID, $alias, $userID]
|
2015-09-27 00:03:58 +00:00
|
|
|
);
|
|
|
|
}
|
2009-12-24 07:36:09 +00:00
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function add_members()
|
|
|
|
{
|
2015-09-27 00:03:58 +00:00
|
|
|
global $user;
|
2019-05-28 16:59:38 +00:00
|
|
|
$inputs = validate_input([
|
2015-09-27 00:03:58 +00:00
|
|
|
"artistID" => "int",
|
|
|
|
"members" => "string,lower",
|
2019-05-28 16:59:38 +00:00
|
|
|
]);
|
2015-09-27 00:03:58 +00:00
|
|
|
$artistID = $inputs["artistID"];
|
|
|
|
$members = explode(" ", $inputs["members"]);
|
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
foreach ($members as $member) {
|
|
|
|
if (!$this->member_exists($artistID, $member)) {
|
2015-09-27 00:03:58 +00:00
|
|
|
$this->save_new_member($artistID, $member, $user->id);
|
2019-05-28 16:59:38 +00:00
|
|
|
}
|
|
|
|
}
|
2015-09-27 00:03:58 +00:00
|
|
|
}
|
2009-12-24 07:36:09 +00:00
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function save_new_member(int $artistID, string $member, int $userID)
|
|
|
|
{
|
2015-09-27 00:03:58 +00:00
|
|
|
global $database;
|
2009-12-24 07:36:09 +00:00
|
|
|
|
2015-09-27 00:03:58 +00:00
|
|
|
$database->execute(
|
|
|
|
"INSERT INTO artist_members (artist_id, name, created, updated, user_id) VALUES (?, ?, now(), now(), ?)",
|
2019-05-28 16:59:38 +00:00
|
|
|
[$artistID, $member, $userID]
|
2015-09-27 00:03:58 +00:00
|
|
|
);
|
|
|
|
}
|
2009-12-24 07:36:09 +00:00
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function member_exists(int $artistID, string $member): bool
|
|
|
|
{
|
2015-09-27 00:03:58 +00:00
|
|
|
global $database;
|
2009-12-24 07:36:09 +00:00
|
|
|
|
2015-09-27 00:03:58 +00:00
|
|
|
$result = $database->get_one(
|
|
|
|
"SELECT COUNT(1) FROM artist_members WHERE artist_id = ? AND name = ?",
|
2019-05-28 16:59:38 +00:00
|
|
|
[$artistID, $member]
|
2015-09-27 00:03:58 +00:00
|
|
|
);
|
|
|
|
return ($result != 0);
|
|
|
|
}
|
2009-12-24 07:36:09 +00:00
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
private function url_exists(int $artistID, string $url): bool
|
|
|
|
{
|
2015-09-27 00:03:58 +00:00
|
|
|
global $database;
|
2009-12-24 07:36:09 +00:00
|
|
|
|
2015-09-27 00:03:58 +00:00
|
|
|
$result = $database->get_one(
|
|
|
|
"SELECT COUNT(1) FROM artist_urls WHERE artist_id = ? AND url = ?",
|
2019-05-28 16:59:38 +00:00
|
|
|
[$artistID, $url]
|
2015-09-27 00:03:58 +00:00
|
|
|
);
|
|
|
|
return ($result != 0);
|
|
|
|
}
|
2009-12-24 07:36:09 +00:00
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
/**
|
|
|
|
* HERE WE GET THE INFO OF THE ALIAS
|
|
|
|
*/
|
|
|
|
private function get_alias(int $artistID): array
|
|
|
|
{
|
2015-09-27 00:03:58 +00:00
|
|
|
global $database;
|
2009-12-24 07:36:09 +00:00
|
|
|
|
2015-09-27 00:03:58 +00:00
|
|
|
$result = $database->get_all("
|
|
|
|
SELECT id AS alias_id, alias AS alias_name
|
|
|
|
FROM artist_alias
|
|
|
|
WHERE artist_id = ?
|
|
|
|
ORDER BY alias ASC
|
2019-05-28 16:59:38 +00:00
|
|
|
", [$artistID]);
|
2009-12-24 07:36:09 +00:00
|
|
|
|
2015-09-27 00:03:58 +00:00
|
|
|
for ($i = 0 ; $i < count($result) ; $i++) {
|
|
|
|
$result[$i]["alias_name"] = stripslashes($result[$i]["alias_name"]);
|
|
|
|
}
|
|
|
|
return $result;
|
2019-05-28 16:59:38 +00:00
|
|
|
}
|
2009-12-24 07:36:09 +00:00
|
|
|
}
|