90 lines
2.3 KiB
PHP
90 lines
2.3 KiB
PHP
<?php
|
|
/**
|
|
* ownCloud - Tag class
|
|
*
|
|
* @author Bernhard Reiter
|
|
* @copyright 2014 Bernhard Reiter <ockham@raz.or.at>
|
|
*
|
|
* This library is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE
|
|
* License as published by the Free Software Foundation; either
|
|
* version 3 of the License, or any later version.
|
|
*
|
|
* This library 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 AFFERO GENERAL PUBLIC LICENSE for more details.
|
|
*
|
|
* You should have received a copy of the GNU Affero General Public
|
|
* License along with this library. If not, see <http://www.gnu.org/licenses/>.
|
|
*
|
|
*/
|
|
|
|
namespace OC\Tagging;
|
|
|
|
use \OCP\AppFramework\Db\Entity;
|
|
|
|
/**
|
|
* Class to represent a tag.
|
|
*
|
|
* @method string getOwner()
|
|
* @method void setOwner(string $owner)
|
|
* @method string getType()
|
|
* @method void setType(string $type)
|
|
* @method string getName()
|
|
* @method void setName(string $name)
|
|
*/
|
|
class Tag extends Entity {
|
|
|
|
protected $owner;
|
|
protected $type;
|
|
protected $name;
|
|
|
|
/**
|
|
* Constructor.
|
|
*
|
|
* @param string $owner The tag's owner
|
|
* @param string $type The type of item this tag is used for
|
|
* @param string $name The tag's name
|
|
*/
|
|
public function __construct($owner = null, $type = null, $name = null) {
|
|
$this->setOwner($owner);
|
|
$this->setType($type);
|
|
$this->setName($name);
|
|
}
|
|
|
|
/**
|
|
* Transform a database columnname to a property
|
|
*
|
|
* @param string $columnName the name of the column
|
|
* @return string the property name
|
|
* @todo migrate existing database columns to the correct names
|
|
* to be able to drop this direct mapping
|
|
*/
|
|
public function columnToProperty($columnName){
|
|
if ($columnName === 'category') {
|
|
return 'name';
|
|
} elseif ($columnName === 'uid') {
|
|
return 'owner';
|
|
} else {
|
|
return parent::columnToProperty($columnName);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Transform a property to a database column name
|
|
*
|
|
* @param string $property the name of the property
|
|
* @return string the column name
|
|
*/
|
|
public function propertyToColumn($property){
|
|
if ($property === 'name') {
|
|
return 'category';
|
|
} elseif ($property === 'owner') {
|
|
return 'uid';
|
|
} else {
|
|
return parent::propertyToColumn($property);
|
|
}
|
|
}
|
|
}
|