Blame view

sources/lib/private/connector/sabre/principal.php 3.38 KB
03e52840d   Kload   Init
1
2
3
4
5
6
7
8
  <?php
  /**
   * Copyright (c) 2011 Jakob Sack mail@jakobsack.de
   * Copyright (c) 2012 Bart Visscher <bartv@thisnet.nl>
   * This file is licensed under the Affero General Public License version 3 or
   * later.
   * See the COPYING-README file.
   */
6d9380f96   Cédric Dupont   Update sources OC...
9
  class OC_Connector_Sabre_Principal implements \Sabre\DAVACL\PrincipalBackend\BackendInterface {
03e52840d   Kload   Init
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
  	/**
  	 * Returns a list of principals based on a prefix.
  	 *
  	 * This prefix will often contain something like 'principals'. You are only
  	 * expected to return principals that are in this base path.
  	 *
  	 * You are expected to return at least a 'uri' for every user, you can
  	 * return any additional properties if you wish so. Common properties are:
  	 *   {DAV:}displayname
  	 *
  	 * @param string $prefixPath
  	 * @return array
  	 */
  	public function getPrincipalsByPrefix( $prefixPath ) {
  		$principals = array();
  
  		if ($prefixPath == 'principals') {
  			foreach(OC_User::getUsers() as $user) {
  				$user_uri = 'principals/'.$user;
  				$principals[] = array(
  					'uri' => $user_uri,
  					'{DAV:}displayname' => $user,
  				);
  			}
  		}
  
  		return $principals;
  	}
  
  	/**
  	 * Returns a specific principal, specified by it's path.
  	 * The returned structure should be the exact same as from
  	 * getPrincipalsByPrefix.
  	 *
  	 * @param string $path
  	 * @return array
  	 */
  	public function getPrincipalByPath($path) {
  		list($prefix, $name) = explode('/', $path);
  
  		if ($prefix == 'principals' && OC_User::userExists($name)) {
  			return array(
  				'uri' => 'principals/'.$name,
  				'{DAV:}displayname' => $name,
  			);
  		}
  
  		return null;
  	}
  
  	/**
  	 * Returns the list of members for a group-principal
  	 *
  	 * @param string $principal
6d9380f96   Cédric Dupont   Update sources OC...
64
  	 * @return string[]
03e52840d   Kload   Init
65
66
67
68
69
  	 */
  	public function getGroupMemberSet($principal) {
  		// TODO: for now the group principal has only one member, the user itself
  		$principal = $this->getPrincipalByPath($principal);
  		if (!$principal) {
6d9380f96   Cédric Dupont   Update sources OC...
70
  			throw new \Sabre\DAV\Exception('Principal not found');
03e52840d   Kload   Init
71
72
73
74
75
76
77
78
79
80
81
82
83
84
  		}
  
  		return array(
  			$principal['uri']
  		);
  	}
  
  	/**
  	 * Returns the list of groups a principal is a member of
  	 *
  	 * @param string $principal
  	 * @return array
  	 */
  	public function getGroupMembership($principal) {
6d9380f96   Cédric Dupont   Update sources OC...
85
  		list($prefix, $name) = \Sabre\DAV\URLUtil::splitPath($principal);
03e52840d   Kload   Init
86
87
88
89
90
  
  		$group_membership = array();
  		if ($prefix == 'principals') {
  			$principal = $this->getPrincipalByPath($principal);
  			if (!$principal) {
6d9380f96   Cédric Dupont   Update sources OC...
91
  				throw new \Sabre\DAV\Exception('Principal not found');
03e52840d   Kload   Init
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
  			}
  
  			// TODO: for now the user principal has only its own groups
  			return array(
  				'principals/'.$name.'/calendar-proxy-read',
  				'principals/'.$name.'/calendar-proxy-write',
  				// The addressbook groups are not supported in Sabre,
  				// see http://groups.google.com/group/sabredav-discuss/browse_thread/thread/ef2fa9759d55f8c#msg_5720afc11602e753
  				//'principals/'.$name.'/addressbook-proxy-read',
  				//'principals/'.$name.'/addressbook-proxy-write',
  			);
  		}
  		return $group_membership;
  	}
  
  	/**
  	 * Updates the list of group members for a group principal.
  	 *
  	 * The principals should be passed as a list of uri's.
  	 *
  	 * @param string $principal
  	 * @param array $members
  	 * @return void
  	 */
  	public function setGroupMemberSet($principal, array $members) {
6d9380f96   Cédric Dupont   Update sources OC...
117
  		throw new \Sabre\DAV\Exception('Setting members of the group is not supported yet');
03e52840d   Kload   Init
118
119
120
121
122
123
124
125
126
127
  	}
  
  	function updatePrincipal($path, $mutations) {
  		return 0;
  	}
  
  	function searchPrincipals($prefixPath, array $searchProperties) {
  		return array();
  	}
  }