mirror of
https://github.com/wallabag/wallabag.git
synced 2025-01-11 17:35:25 +00:00
Clean old unused tags when deleting a tag
This commit is contained in:
parent
78bddb22be
commit
9c743ab965
2 changed files with 30 additions and 1 deletions
|
@ -511,6 +511,24 @@ class Database {
|
|||
$query = $this->executeQuery($sql_action, $params_action);
|
||||
return $query;
|
||||
}
|
||||
|
||||
public function cleanUnusedTags() {
|
||||
$sql_action = "SELECT tags.* FROM tags JOIN tags_entries ON tags_entries.tag_id=tags.id";
|
||||
$query = $this->executeQuery($sql_action,array());
|
||||
$tagstokeep = $query->fetchAll();
|
||||
$sql_action = "SELECT tags.* FROM tags LEFT JOIN tags_entries ON tags_entries.tag_id=tags.id";
|
||||
$query = $this->executeQuery($sql_action,array());
|
||||
$alltags = $query->fetchAll();
|
||||
foreach ($alltags as $tag) {
|
||||
if ($tag && !in_array($tag,$tagstokeep)) {
|
||||
//delete tag
|
||||
$sql_action = "DELETE FROM tags WHERE id=?";
|
||||
$params_action = array($tag[0]);
|
||||
$query = $this->executeQuery($sql_action, $params_action);
|
||||
return $query;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public function retrieveTagByValue($value) {
|
||||
$tag = NULL;
|
||||
|
|
|
@ -558,7 +558,7 @@ class Poche
|
|||
}
|
||||
}
|
||||
}
|
||||
$this->messages->add('s', _('the tag has been applied successfully'));
|
||||
$this->messages->add('s', _('The tag has been applied successfully'));
|
||||
Tools::redirect();
|
||||
break;
|
||||
case 'remove_tag' :
|
||||
|
@ -570,6 +570,10 @@ class Poche
|
|||
Tools::redirect();
|
||||
}
|
||||
$this->store->removeTagForEntry($id, $tag_id);
|
||||
Tools::logm('tag entry deleted');
|
||||
$this->store->cleanUnusedTags();
|
||||
Tools::logm('old tags cleaned');
|
||||
$this->messages->add('s', _('The tag has been successfully deleted'));
|
||||
Tools::redirect();
|
||||
break;
|
||||
default:
|
||||
|
@ -1131,6 +1135,13 @@ class Poche
|
|||
$this->messages->add('s', _('Cache deleted.'));
|
||||
Tools::redirect();
|
||||
}
|
||||
|
||||
public function cleanTags() {
|
||||
$this->store->cleanUnusedTags();
|
||||
$this->messages->add('s', _('The unused tags have been cleaned.'));
|
||||
Tools::logm('clean tags');
|
||||
Tools::redirect();
|
||||
}
|
||||
|
||||
/**
|
||||
* return new purifier object with actual config
|
||||
|
|
Loading…
Reference in a new issue