1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677 |
- <?php
- /**
- * @copyright Copyright (c) 2016, ownCloud, Inc.
- *
- * @author Christoph Wurst <christoph@winzerhof-wurst.at>
- * @author Georg Ehrke <oc.list@georgehrke.com>
- * @author Lukas Reschke <lukas@statuscode.ch>
- * @author Roeland Jago Douma <roeland@famdouma.nl>
- * @author Thomas Müller <thomas.mueller@tmit.eu>
- *
- * @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 OCP\IConfig;
- use Sabre\DAV\ServerPlugin;
- use Sabre\HTTP\RequestInterface;
- use Sabre\DAV\Server;
- /**
- * Class BlockLegacyClientPlugin is used to detect old legacy sync clients and
- * returns a 403 status to those clients
- *
- * @package OCA\DAV\Connector\Sabre
- */
- class BlockLegacyClientPlugin extends ServerPlugin {
- protected ?Server $server = null;
- protected IConfig $config;
- public function __construct(IConfig $config) {
- $this->config = $config;
- }
- /**
- * @return void
- */
- public function initialize(Server $server) {
- $this->server = $server;
- $this->server->on('beforeMethod:*', [$this, 'beforeHandler'], 200);
- }
- /**
- * Detects all unsupported clients and throws a \Sabre\DAV\Exception\Forbidden
- * exception which will result in a 403 to them.
- * @param RequestInterface $request
- * @throws \Sabre\DAV\Exception\Forbidden If the client version is not supported
- */
- public function beforeHandler(RequestInterface $request) {
- $userAgent = $request->getHeader('User-Agent');
- if ($userAgent === null) {
- return;
- }
- $minimumSupportedDesktopVersion = $this->config->getSystemValue('minimum.supported.desktop.version', '2.3.0');
- // Match on the mirall version which is in scheme "Mozilla/5.0 (%1) mirall/%2" or
- // "mirall/%1" for older releases
- preg_match("/(?:mirall\\/)([\d.]+)/i", $userAgent, $versionMatches);
- if (isset($versionMatches[1]) &&
- version_compare($versionMatches[1], $minimumSupportedDesktopVersion) === -1) {
- throw new \Sabre\DAV\Exception\Forbidden('Unsupported client version.');
- }
- }
- }
|