AddressBookRoot.php 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. <?php
  2. /**
  3. * @copyright Copyright (c) 2016, ownCloud, Inc.
  4. *
  5. * @author Thomas Müller <thomas.mueller@tmit.eu>
  6. *
  7. * @license AGPL-3.0
  8. *
  9. * This code is free software: you can redistribute it and/or modify
  10. * it under the terms of the GNU Affero General Public License, version 3,
  11. * as published by the Free Software Foundation.
  12. *
  13. * This program is distributed in the hope that it will be useful,
  14. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  16. * GNU Affero General Public License for more details.
  17. *
  18. * You should have received a copy of the GNU Affero General Public License, version 3,
  19. * along with this program. If not, see <http://www.gnu.org/licenses/>
  20. *
  21. */
  22. namespace OCA\DAV\CardDAV;
  23. class AddressBookRoot extends \Sabre\CardDAV\AddressBookRoot {
  24. /**
  25. * This method returns a node for a principal.
  26. *
  27. * The passed array contains principal information, and is guaranteed to
  28. * at least contain a uri item. Other properties may or may not be
  29. * supplied by the authentication backend.
  30. *
  31. * @param array $principal
  32. * @return \Sabre\DAV\INode
  33. */
  34. function getChildForPrincipal(array $principal) {
  35. return new UserAddressBooks($this->carddavBackend, $principal['uri']);
  36. }
  37. function getName() {
  38. if ($this->principalPrefix === 'principals') {
  39. return parent::getName();
  40. }
  41. // Grabbing all the components of the principal path.
  42. $parts = explode('/', $this->principalPrefix);
  43. // We are only interested in the second part.
  44. return $parts[1];
  45. }
  46. }