owncloud/core

View on GitHub
apps/dav/lib/Files/BrowserErrorPagePlugin.php

Summary

Maintainability
A
0 mins
Test Coverage
<?php
/**
 * @author Lukas Reschke <lukas@statuscode.ch>
 * @author Thomas Müller <thomas.mueller@tmit.eu>
 *
 * @copyright Copyright (c) 2018, ownCloud GmbH
 * @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\Files;

use OC\AppFramework\Http\Request;
use OC_Template;
use OCP\IRequest;
use Sabre\DAV\Exception;
use Sabre\DAV\Server;
use Sabre\DAV\ServerPlugin;

class BrowserErrorPagePlugin extends ServerPlugin {
    /** @var Server */
    private $server;

    /**
     * This initializes the plugin.
     *
     * This function is called by Sabre\DAV\Server, after
     * addPlugin is called.
     *
     * This method should set up the required event subscriptions.
     *
     * @param Server $server
     * @return void
     */
    public function initialize(Server $server) {
        $this->server = $server;
        $server->on('exception', [$this, 'logException'], 1000);
    }

    /**
     * @param IRequest $request
     * @return bool
     */
    public static function isBrowserRequest(IRequest $request) {
        if ($request->getMethod() !== 'GET') {
            return false;
        }
        return $request->isUserAgent([
            Request::USER_AGENT_IE,
            Request::USER_AGENT_MS_EDGE,
            Request::USER_AGENT_CHROME,
            Request::USER_AGENT_FIREFOX,
            Request::USER_AGENT_SAFARI,
        ]);
    }

    /**
     * @param \Throwable $ex
     */
    public function logException(\Throwable $ex) {
        if ($ex instanceof Exception) {
            $httpCode = $ex->getHTTPCode();
            $headers = $ex->getHTTPHeaders($this->server);
        } else {
            $httpCode = 500;
            $headers = [];
        }
        $this->server->httpResponse->addHeaders($headers);
        $this->server->httpResponse->setStatus($httpCode);
        $body = $this->generateBody($ex);
        $this->server->httpResponse->setBody($body);
        $this->server->httpResponse->setHeader('Content-Security-Policy', "default-src 'self'; img-src 'self'; style-src 'self' 'unsafe-inline'; font-src 'self';");
        $this->sendResponse();
    }

    /**
     * @codeCoverageIgnore
     * @param \Throwable $ex
     * @return bool|string
     */
    public function generateBody(\Throwable $ex) {
        $request = \OC::$server->getRequest();
        $content = new OC_Template('dav', 'exception', 'guest');
        $content->assign('title', $this->server->httpResponse->getStatusText());
        $content->assign('hint', $ex->getMessage());
        $content->assign('remoteAddr', $request->getRemoteAddress());
        $content->assign('requestID', $request->getId());
        return $content->fetchPage();
    }

    /**
     * @codeCoverageIgnore
     */
    public function sendResponse() {
        $this->server->sapi->sendResponse($this->server->httpResponse);
        exit();
    }
}