RootCollection.php 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. <?php
  2. declare(strict_types=1);
  3. /**
  4. * @copyright 2018, Roeland Jago Douma <roeland@famdouma.nl>
  5. *
  6. * @author Roeland Jago Douma <roeland@famdouma.nl>
  7. *
  8. * @license GNU AGPL version 3 or any later version
  9. *
  10. * This program is free software: you can redistribute it and/or modify
  11. * it under the terms of the GNU Affero General Public License as
  12. * published by the Free Software Foundation, either version 3 of the
  13. * License, or (at your option) any later version.
  14. *
  15. * This program is distributed in the hope that it will be useful,
  16. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  17. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  18. * GNU Affero General Public License for more details.
  19. *
  20. * You should have received a copy of the GNU Affero General Public License
  21. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  22. *
  23. */
  24. namespace OCA\Files_Trashbin\Sabre;
  25. use OCA\Files_Trashbin\Trash\ITrashManager;
  26. use OCP\IConfig;
  27. use Sabre\DAV\INode;
  28. use Sabre\DAVACL\AbstractPrincipalCollection;
  29. use Sabre\DAVACL\PrincipalBackend;
  30. class RootCollection extends AbstractPrincipalCollection {
  31. /** @var ITrashManager */
  32. private $trashManager;
  33. public function __construct(
  34. ITrashManager $trashManager,
  35. PrincipalBackend\BackendInterface $principalBackend,
  36. IConfig $config
  37. ) {
  38. parent::__construct($principalBackend, 'principals/users');
  39. $this->trashManager = $trashManager;
  40. $this->disableListing = !$config->getSystemValue('debug', false);
  41. }
  42. /**
  43. * This method returns a node for a principal.
  44. *
  45. * The passed array contains principal information, and is guaranteed to
  46. * at least contain a uri item. Other properties may or may not be
  47. * supplied by the authentication backend.
  48. *
  49. * @param array $principalInfo
  50. * @return INode
  51. */
  52. public function getChildForPrincipal(array $principalInfo): TrashHome {
  53. list(, $name) = \Sabre\Uri\split($principalInfo['uri']);
  54. $user = \OC::$server->getUserSession()->getUser();
  55. if (is_null($user) || $name !== $user->getUID()) {
  56. throw new \Sabre\DAV\Exception\Forbidden();
  57. }
  58. return new TrashHome($principalInfo, $this->trashManager, $user);
  59. }
  60. public function getName(): string {
  61. return 'trashbin';
  62. }
  63. }