summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorThomas Tanghus <thomas@tanghus.net>2013-05-20 10:16:07 +0200
committerThomas Tanghus <thomas@tanghus.net>2013-05-20 10:16:07 +0200
commitb1bb899867b787f024c94ae26907b857e203d59c (patch)
tree4335797b38053f80be2a7e75c81a1b63a3ae2580
parent6609de28d832262e8f72fb19e5f0343cd021cca3 (diff)
downloadnextcloud-server-b1bb899867b787f024c94ae26907b857e203d59c.tar.gz
nextcloud-server-b1bb899867b787f024c94ae26907b857e203d59c.zip
Add rename() method to OC_VCategories.
-rw-r--r--lib/vcategories.php32
-rw-r--r--tests/lib/vcategories.php10
2 files changed, 42 insertions, 0 deletions
diff --git a/lib/vcategories.php b/lib/vcategories.php
index 5975e688b75..74864704e30 100644
--- a/lib/vcategories.php
+++ b/lib/vcategories.php
@@ -325,6 +325,38 @@ class OC_VCategories {
}
/**
+ * @brief Rename category.
+ * @param string $from The name of the existing category
+ * @param string $to The new name of the category.
+ * @returns bool
+ */
+ public function rename($from, $to) {
+ $id = $this->array_searchi($from, $this->categories);
+ if($id === false) {
+ OCP\Util::writeLog('core', __METHOD__.', category: ' . $from. ' does not exist', OCP\Util::DEBUG);
+ return false;
+ }
+
+ $sql = 'UPDATE `' . self::CATEGORY_TABLE . '` SET `category` = ? '
+ . 'WHERE `uid` = ? AND `type` = ? AND `id` = ?';
+ try {
+ $stmt = OCP\DB::prepare($sql);
+ $result = $stmt->execute(array($to, $this->user, $this->type, $id));
+ if (OC_DB::isError($result)) {
+ echo 'DB error: ' . $result . "\n";
+ OC_Log::write('core', __METHOD__. 'DB error: ' . OC_DB::getErrorMessage($result), OC_Log::ERROR);
+ return false;
+ }
+ } catch(Exception $e) {
+ OCP\Util::writeLog('core', __METHOD__.', exception: '.$e->getMessage(),
+ OCP\Util::ERROR);
+ return false;
+ }
+ $this->categories[$id] = $to;
+ return true;
+ }
+
+ /**
* @brief Add a new category.
* @param $names A string with a name or an array of strings containing
* the name(s) of the categor(y|ies) to add.
diff --git a/tests/lib/vcategories.php b/tests/lib/vcategories.php
index e79dd49870c..a8af6ae9f7a 100644
--- a/tests/lib/vcategories.php
+++ b/tests/lib/vcategories.php
@@ -81,6 +81,16 @@ class Test_VCategories extends PHPUnit_Framework_TestCase {
}
+ public function testrenameCategory() {
+ $defcategories = array('Friends', 'Family', 'Wrok', 'Other');
+ $catmgr = new OC_VCategories($this->objectType, $this->user, $defcategories);
+
+ $this->assertTrue($catmgr->rename('Wrok', 'Work'));
+ $this->assertTrue($catmgr->hasCategory('Work'));
+ $this->assertFalse($catmgr->hasCategory('Wrok'));
+
+ }
+
public function testAddToCategory() {
$objids = array(1, 2, 3, 4, 5, 6, 7, 8, 9);