web/database.php
<?php
/**
* @author Nicolas CARPi <nico-git@deltablot.email>
* @copyright 2012 Nicolas CARPi
* @see https://www.elabftw.net Official website
* @license AGPL-3.0
* @package elabftw
*/
declare(strict_types=1);
namespace Elabftw\Elabftw;
use Elabftw\Controllers\DatabaseController;
use Elabftw\Exceptions\DatabaseErrorException;
use Elabftw\Exceptions\FilesystemErrorException;
use Elabftw\Exceptions\IllegalActionException;
use Elabftw\Exceptions\ImproperActionException;
use Elabftw\Models\Items;
use Exception;
use Symfony\Component\HttpFoundation\Response;
/**
* Entry point for database things
*
*/
require_once 'app/init.inc.php';
$App->pageTitle = ngettext('Resource', 'Resources', 2);
// default response is error page with general error message
$Response = new Response();
$Response->prepare($Request);
try {
$Controller = new DatabaseController($App, new Items($App->Users));
$Response = $Controller->getResponse();
} catch (ImproperActionException $e) {
// show message to user
$template = 'error.html';
$renderArr = array('error' => $e->getMessage());
$Response->setContent($App->render($template, $renderArr));
} catch (IllegalActionException $e) {
// log notice and show message
$App->Log->notice('', array(array('userid' => $App->Session->get('userid')), array('IllegalAction', $e)));
$template = 'error.html';
$renderArr = array('error' => $e->getMessage());
$Response->setContent($App->render($template, $renderArr));
} catch (DatabaseErrorException | FilesystemErrorException $e) {
// log error and show message
$App->Log->error('', array(array('userid' => $App->Session->get('userid')), array('Error', $e)));
$template = 'error.html';
$renderArr = array('error' => $e->getMessage());
$Response->setContent($App->render($template, $renderArr));
} catch (Exception $e) {
// log error and show general error message
$App->Log->error('', array(array('userid' => $App->Session->get('userid')), array('Exception' => $e)));
$template = 'error.html';
$renderArr = array('error' => Tools::error());
$Response->setContent($App->render($template, $renderArr));
} finally {
// autologout if there is elabid in view mode
// so we don't stay logged in as anon
if ($App->Request->query->has('elabid')
&& $App->Request->query->get('mode') === 'view'
&& !$App->Request->getSession()->has('is_auth')) {
$App->Session->invalidate();
}
$Response->send();
}