summaryrefslogtreecommitdiff
path: root/modules/tag
diff options
context:
space:
mode:
authormamouneyya <mamoun.diraneyya@gmail.com>2010-12-09 18:31:01 +0200
committermamouneyya <mamoun.diraneyya@gmail.com>2010-12-09 18:31:01 +0200
commit3e2610ea83c60805d5e727df6509da6c49fd6c7b (patch)
tree28638f7a1cd2e298587f4b3960caf409f7d2d2fa /modules/tag
parent6aabab4b715ff8ac00cc667e9d0a40c9868410d8 (diff)
parentc3ef8921260db8e39b6d2a7b4708e3d19f35f8b5 (diff)
Merge remote branch 'gallery3/master'
Diffstat (limited to 'modules/tag')
-rw-r--r--modules/tag/controllers/admin_tags.php1
-rw-r--r--modules/tag/helpers/tag_event.php11
-rw-r--r--modules/tag/helpers/tag_task.php97
-rw-r--r--modules/tag/models/tag.php28
4 files changed, 118 insertions, 19 deletions
diff --git a/modules/tag/controllers/admin_tags.php b/modules/tag/controllers/admin_tags.php
index 0c82579b..99743a8e 100644
--- a/modules/tag/controllers/admin_tags.php
+++ b/modules/tag/controllers/admin_tags.php
@@ -52,7 +52,6 @@ class Admin_Tags_Controller extends Admin_Controller {
$form = tag::get_delete_form($tag);
if ($form->validate()) {
$name = $tag->name;
- db::build()->delete("items_tags")->where("tag_id", "=", $tag->id)->execute();
$tag->delete();
message::success(t("Deleted tag %tag_name", array("tag_name" => $name)));
log::success("tags", t("Deleted tag %tag_name", array("tag_name" => $name)));
diff --git a/modules/tag/helpers/tag_event.php b/modules/tag/helpers/tag_event.php
index 0cc2170c..829089c4 100644
--- a/modules/tag/helpers/tag_event.php
+++ b/modules/tag/helpers/tag_event.php
@@ -62,6 +62,12 @@ class tag_event_Core {
static function item_deleted($item) {
tag::clear_all($item);
+ if (!batch::in_progress()) {
+ tag::compact();
+ }
+ }
+
+ static function batch_complete() {
tag::compact();
}
@@ -88,6 +94,7 @@ class tag_event_Core {
tag::add($item, trim($tag_name));
}
}
+ module::event("item_related_update", $item);
tag::compact();
}
@@ -109,7 +116,7 @@ class tag_event_Core {
if (!isset($group->uploadify)) {
return;
}
-
+
$group = $form->add_photos;
$group->input("tags")
->label(t("Add tags to all uploaded files"))
@@ -132,7 +139,7 @@ class tag_event_Core {
if (!isset($group->uploadify)) {
return;
}
-
+
foreach (explode(",", $form->add_photos->tags->value) as $tag_name) {
$tag_name = trim($tag_name);
if ($tag_name) {
diff --git a/modules/tag/helpers/tag_task.php b/modules/tag/helpers/tag_task.php
new file mode 100644
index 00000000..7bf50546
--- /dev/null
+++ b/modules/tag/helpers/tag_task.php
@@ -0,0 +1,97 @@
+<?php defined("SYSPATH") or die("No direct script access.");
+/**
+ * Gallery - a web based photo album viewer and editor
+ * Copyright (C) 2000-2010 Bharat Mediratta
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or (at
+ * your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.
+ */
+class tag_task_Core {
+
+ static function available_tasks() {
+ $tasks[] = Task_Definition::factory()
+ ->callback("tag_task::clean_up_tags")
+ ->name(t("Clean up tags"))
+ ->description(t("Correct tag counts and remove tags with no items"))
+ ->severity(log::SUCCESS);
+ return $tasks;
+ }
+
+ /**
+ * Fix up tag counts and delete any tags that have no associated items.
+ * @param Task_Model the task
+ */
+ static function clean_up_tags($task) {
+ $errors = array();
+ try {
+ $start = microtime(true);
+ $last_tag_id = $task->get("last_tag_id", null);
+ $current = 0;
+ $total = 0;
+
+ switch ($task->get("mode", "init")) {
+ case "init":
+ $task->set("total", ORM::factory("tag")->count_all());
+ $task->set("mode", "clean_up_tags");
+ $task->set("completed", 0);
+ $task->set("last_tag_id", 0);
+
+ case "clean_up_tags":
+ $completed = $task->get("completed");
+ $total = $task->get("total");
+ $last_tag_id = $task->get("last_tag_id");
+ $tags = ORM::factory("tag")->where("id", ">", $last_tag_id)->find_all(25);
+ Kohana_Log::add("error",print_r(Database::instance()->last_query(),1));
+ while ($current < $total && microtime(true) - $start < 1 && $tag = $tags->current()) {
+ $last_tag_id = $tag->id;
+ $real_count = $tag->items_count();
+ if ($tag->count != $real_count) {
+ $tag->count = $real_count;
+ if ($tag->count) {
+ $task->log(
+ "Fixing count for tag {$tag->name} (id: {$tag->id}, new count: {$tag->count})");
+ $tag->save();
+ } else {
+ $task->log("Deleting empty tag {$tag->name} ({$tag->id})");
+ $tag->delete();
+ }
+ }
+
+ $completed++;
+ $tags->next();
+ }
+ $task->percent_complete = $completed / $total * 100;
+ $task->set("completed", $completed);
+ $task->set("last_tag_id", $last_tag_id);
+ }
+
+ $task->status = t2("Examined %count tag", "Examined %count tags", $completed);
+
+ if ($completed == $total) {
+ $task->done = true;
+ $task->state = "success";
+ $task->percent_complete = 100;
+ }
+ } catch (Exception $e) {
+ Kohana_Log::add("error",(string)$e);
+ $task->done = true;
+ $task->state = "error";
+ $task->status = $e->getMessage();
+ $errors[] = (string)$e;
+ }
+ if ($errors) {
+ $task->log($errors);
+ }
+ }
+} \ No newline at end of file
diff --git a/modules/tag/models/tag.php b/modules/tag/models/tag.php
index 269a0f39..c038f6d1 100644
--- a/modules/tag/models/tag.php
+++ b/modules/tag/models/tag.php
@@ -17,7 +17,7 @@
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.
*/
-class Tag_Model extends ORM {
+class Tag_Model_Core extends ORM {
protected $has_and_belongs_to_many = array("items");
/**
@@ -57,8 +57,7 @@ class Tag_Model extends ORM {
/**
* Overload ORM::save() to trigger an item_related_update event for all items that are related
- * to this tag. Since items can be added or removed as part of the save, we need to trigger an
- * event for the union of all related items before and after the save.
+ * to this tag.
*/
public function save() {
$related_item_ids = array();
@@ -70,20 +69,16 @@ class Tag_Model extends ORM {
$related_item_ids[$row->item_id] = 1;
}
- $result = parent::save();
-
- foreach (db::build()
- ->select("item_id")
- ->from("items_tags")
- ->where("tag_id", "=", $this->id)
- ->execute() as $row) {
- $related_item_ids[$row->item_id] = 1;
+ if (isset($this->changed_relations["items"])) {
+ $changed = array_merge(
+ array_diff($this->changed_relations["items"], $this->object_relations["items"]),
+ array_diff($this->object_relations["items"], $this->changed_relations["items"]));
}
- if ($related_item_ids) {
- foreach (ORM::factory("item")
- ->where("id", "IN", array_keys($related_item_ids))
- ->find_all() as $item) {
+ $result = parent::save();
+
+ if (!empty($changed)) {
+ foreach (ORM::factory("item")->where("id", "IN", $changed)->find_all() as $item) {
module::event("item_related_update", $item);
}
}
@@ -93,7 +88,7 @@ class Tag_Model extends ORM {
/**
* Overload ORM::delete() to trigger an item_related_update event for all items that are
- * related to this tag.
+ * related to this tag, and delete all items_tags relationships.
*/
public function delete($ignored_id=null) {
$related_item_ids = array();
@@ -105,6 +100,7 @@ class Tag_Model extends ORM {
$related_item_ids[$row->item_id] = 1;
}
+ db::build()->delete("items_tags")->where("tag_id", "=", $this->id)->execute();
$result = parent::delete();
if ($related_item_ids) {