2016-02-29 16:30:02 +00:00
|
|
|
<?php
|
|
|
|
/**
|
2016-07-21 14:49:16 +00:00
|
|
|
* @copyright Copyright (c) 2016, ownCloud, Inc.
|
|
|
|
*
|
2016-05-26 17:56:05 +00:00
|
|
|
* @author Lukas Reschke <lukas@statuscode.ch>
|
|
|
|
* @author Thomas Müller <thomas.mueller@tmit.eu>
|
2016-02-29 16:30:02 +00:00
|
|
|
*
|
|
|
|
* @license AGPL-3.0
|
|
|
|
*
|
|
|
|
* This code is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Affero General Public License, version 3,
|
|
|
|
* as published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU Affero General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Affero General Public License, version 3,
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace OCA\DAV\Connector\Sabre;
|
|
|
|
|
|
|
|
use Sabre\DAV\Exception\NotFound;
|
|
|
|
use Sabre\DAV\IFile;
|
|
|
|
use Sabre\DAV\INode;
|
|
|
|
use \Sabre\DAV\PropFind;
|
|
|
|
use \Sabre\DAV\PropPatch;
|
|
|
|
use Sabre\DAVACL\Exception\NeedPrivileges;
|
|
|
|
use \Sabre\HTTP\RequestInterface;
|
|
|
|
use \Sabre\HTTP\ResponseInterface;
|
|
|
|
use Sabre\HTTP\URLUtil;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Class DavAclPlugin is a wrapper around \Sabre\DAVACL\Plugin that returns 404
|
|
|
|
* responses in case the resource to a response has been forbidden instead of
|
|
|
|
* a 403. This is used to prevent enumeration of valid resources.
|
|
|
|
*
|
|
|
|
* @see https://github.com/owncloud/core/issues/22578
|
|
|
|
* @package OCA\DAV\Connector\Sabre
|
|
|
|
*/
|
|
|
|
class DavAclPlugin extends \Sabre\DAVACL\Plugin {
|
|
|
|
public function __construct() {
|
|
|
|
$this->hideNodesFromListings = true;
|
2016-10-13 10:15:10 +00:00
|
|
|
$this->allowUnauthenticatedAccess = false;
|
2016-02-29 16:30:02 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function checkPrivileges($uri, $privileges, $recursion = self::R_PARENT, $throwExceptions = true) {
|
|
|
|
$access = parent::checkPrivileges($uri, $privileges, $recursion, false);
|
2016-03-17 17:00:06 +00:00
|
|
|
if($access === false && $throwExceptions) {
|
2016-02-29 16:30:02 +00:00
|
|
|
/** @var INode $node */
|
|
|
|
$node = $this->server->tree->getNodeForPath($uri);
|
|
|
|
|
|
|
|
switch(get_class($node)) {
|
|
|
|
case 'OCA\DAV\CardDAV\AddressBook':
|
|
|
|
$type = 'Addressbook';
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
$type = 'Node';
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
throw new NotFound(
|
|
|
|
sprintf(
|
|
|
|
"%s with name '%s' could not be found",
|
|
|
|
$type,
|
|
|
|
$node->getName()
|
|
|
|
)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $access;
|
|
|
|
}
|
|
|
|
}
|