principalBackend->getPrincipalByPath($this->getPrincipalURL().'/'.$name); if (!$principal) { throw new DAV\Exception\NotFound('Node with name '.$name.' was not found'); } if ('calendar-proxy-read' === $name) { return new ProxyRead($this->principalBackend, $this->principalProperties); } if ('calendar-proxy-write' === $name) { return new ProxyWrite($this->principalBackend, $this->principalProperties); } throw new DAV\Exception\NotFound('Node with name '.$name.' was not found'); } /** * Returns an array with all the child nodes. * * @return DAV\INode[] */ public function getChildren() { $r = []; if ($this->principalBackend->getPrincipalByPath($this->getPrincipalURL().'/calendar-proxy-read')) { $r[] = new ProxyRead($this->principalBackend, $this->principalProperties); } if ($this->principalBackend->getPrincipalByPath($this->getPrincipalURL().'/calendar-proxy-write')) { $r[] = new ProxyWrite($this->principalBackend, $this->principalProperties); } return $r; } /** * Returns whether or not the child node exists. * * @param string $name * * @return bool */ public function childExists($name) { try { $this->getChild($name); return true; } catch (DAV\Exception\NotFound $e) { return false; } } /** * Returns a list of ACE's for this node. * * Each ACE has the following properties: * * 'privilege', a string such as {DAV:}read or {DAV:}write. These are * currently the only supported privileges * * 'principal', a url to the principal who owns the node * * 'protected' (optional), indicating that this ACE is not allowed to * be updated. * * @return array */ public function getACL() { $acl = parent::getACL(); $acl[] = [ 'privilege' => '{DAV:}read', 'principal' => $this->principalProperties['uri'].'/calendar-proxy-read', 'protected' => true, ]; $acl[] = [ 'privilege' => '{DAV:}read', 'principal' => $this->principalProperties['uri'].'/calendar-proxy-write', 'protected' => true, ]; return $acl; } }