/usr/share/php/Horde/Kolab/Storage/Folder/Namespace/Element/Other.php is in php-horde-kolab-storage 2.0.5-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 | <?php
/**
* The Horde_Kolab_Storage_Folder_Namespace_Element_Other:: class represents the
* namespace for folders of other users.
*
* PHP version 5
*
* @category Kolab
* @package Kolab_Storage
* @author Gunnar Wrobel <wrobel@pardus.de>
* @license http://www.horde.org/licenses/lgpl21 LGPL 2.1
* @link http://pear.horde.org/index.php?package=Kolab_Storage
*/
/**
* The Horde_Kolab_Storage_Folder_Namespace_Element_Other:: class represents the
* namespace for folders of other users.
*
* Copyright 2010-2013 Horde LLC (http://www.horde.org/)
*
* See the enclosed file COPYING for license information (LGPL). If you
* did not receive this file, see http://www.horde.org/licenses/lgpl21.
*
* @category Kolab
* @package Kolab_Storage
* @author Gunnar Wrobel <wrobel@pardus.de>
* @license http://www.horde.org/licenses/lgpl21 LGPL 2.1
* @link http://pear.horde.org/index.php?package=Kolab_Storage
*/
class Horde_Kolab_Storage_Folder_Namespace_Element_Other
extends Horde_Kolab_Storage_Folder_Namespace_Element
{
/**
* Return the type of this namespace (personal, other, or shared).
*
* @return string The type.
*/
public function getType()
{
return Horde_Kolab_Storage_Folder_Namespace::OTHER;
}
/**
* Return the owner of a folder.
*
* @param string $name The name of the folder.
*
* @return string|boolean The owner of the folder.
*/
public function getOwner($name)
{
$path = explode($this->_delimiter, $name);
$user = $path[1];
if (strpos($user, '@') === false) {
$domain = strstr(array_pop($path), '@');
if (!empty($domain)) {
$user .= $domain;
} else {
$domain = strstr($this->_user, '@');
if (!empty($domain)) {
$user .= $domain;
}
}
}
return $user;
}
/**
* Generate a folder path for the given subpath and owner.
*
* @param string $subpath The subpath of the folder.
* @param string $owner The folder owner.
*
* @return string The name of the folder.
*/
public function generatePath($subpath, $owner)
{
if (strpos($owner, '@') !== false) {
$local = strstr($owner, '@', true);
} else {
$local = $owner;
}
$start = join(
array($this->_name, $local, $subpath),
$this->_delimiter
);
if (strstr($this->_user, '@') !== strstr($owner, '@')) {
return $start . strstr($owner, '@');
} else {
return $start;
}
}
/**
* Return an array describing the path elements of the folder.
*
* @param string $name The name of the folder.
*
* @return array The path elements.
*/
protected function _subpath($name)
{
$path = parent::_subpath($name);
array_shift($path);
return $path;
}
}
|