2013-12-23 02:55:53 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
use PicoFarad\Router;
|
|
|
|
use PicoFarad\Response;
|
|
|
|
use PicoFarad\Request;
|
|
|
|
use PicoFarad\Session;
|
2014-03-17 02:56:43 +01:00
|
|
|
use PicoFarad\Template;
|
2013-12-23 02:55:53 +01:00
|
|
|
|
|
|
|
// Called before each action
|
|
|
|
Router\before(function($action) {
|
|
|
|
|
2014-05-27 02:47:40 +02:00
|
|
|
Session\open(BASE_URL_DIRECTORY, SESSION_SAVE_PATH);
|
2014-02-08 20:13:14 +01:00
|
|
|
|
2015-01-17 19:35:59 +01:00
|
|
|
// Select the requested database. If it fails, logout to destroy session and
|
|
|
|
// 'remember me' cookie
|
2014-04-06 02:24:13 +02:00
|
|
|
if (! empty($_SESSION['database'])) {
|
2015-01-17 19:35:59 +01:00
|
|
|
if (! Model\Database\select($_SESSION['database'])) {
|
|
|
|
Model\User\logout();
|
2014-05-27 02:47:40 +02:00
|
|
|
Response\redirect('?action=login');
|
|
|
|
}
|
|
|
|
}
|
2014-11-19 01:00:53 +01:00
|
|
|
|
2015-01-17 19:35:59 +01:00
|
|
|
// These actions are considered to be safe even for unauthenticated users
|
|
|
|
$safe_actions = array('login', 'bookmark-feed', 'select-db', 'logout', 'notfound');
|
2014-11-19 01:00:53 +01:00
|
|
|
|
2015-01-17 19:35:59 +01:00
|
|
|
if ( ! Model\User\is_loggedin() && ! in_array($action, $safe_actions)) {
|
|
|
|
if (! Model\RememberMe\authenticate()) {
|
|
|
|
Model\User\logout();
|
|
|
|
Response\redirect('?action=login');
|
2014-11-19 01:00:53 +01:00
|
|
|
}
|
2013-12-23 02:55:53 +01:00
|
|
|
}
|
2015-01-17 19:35:59 +01:00
|
|
|
else if (Model\RememberMe\has_cookie()) {
|
|
|
|
Model\RememberMe\refresh();
|
|
|
|
}
|
2013-12-23 02:55:53 +01:00
|
|
|
|
|
|
|
// Load translations
|
|
|
|
$language = Model\Config\get('language') ?: 'en_US';
|
2014-11-19 01:00:53 +01:00
|
|
|
if ($language !== 'en_US') Translator\load($language);
|
2013-12-23 02:55:53 +01:00
|
|
|
|
2014-02-26 01:03:46 +01:00
|
|
|
// Set timezone
|
|
|
|
date_default_timezone_set(Model\Config\get('timezone') ?: 'UTC');
|
|
|
|
|
2013-12-23 02:55:53 +01:00
|
|
|
// HTTP secure headers
|
|
|
|
Response\csp(array(
|
|
|
|
'media-src' => '*',
|
|
|
|
'img-src' => '*',
|
2014-11-08 02:53:50 +01:00
|
|
|
'frame-src' => Model\Config\get_iframe_whitelist(),
|
2013-12-23 02:55:53 +01:00
|
|
|
));
|
|
|
|
|
|
|
|
Response\xframe();
|
|
|
|
Response\xss();
|
|
|
|
Response\nosniff();
|
|
|
|
});
|
|
|
|
|
|
|
|
// Show help
|
|
|
|
Router\get_action('show-help', function() {
|
|
|
|
|
|
|
|
Response\html(Template\load('show_help'));
|
2014-02-05 03:47:59 +01:00
|
|
|
});
|
|
|
|
|
2014-02-08 20:13:14 +01:00
|
|
|
// Show the menu for the mobile view
|
2014-02-05 03:47:59 +01:00
|
|
|
Router\get_action('more', function() {
|
|
|
|
|
|
|
|
Response\html(Template\layout('show_more', array('menu' => 'more')));
|
|
|
|
});
|
2014-04-06 02:24:13 +02:00
|
|
|
|
|
|
|
// Select another database
|
|
|
|
Router\get_action('select-db', function() {
|
|
|
|
|
|
|
|
if (ENABLE_MULTIPLE_DB) {
|
|
|
|
$_SESSION['database'] = \Model\Database\select(Request\param('database'));
|
|
|
|
}
|
|
|
|
|
|
|
|
Response\redirect('?action=login');
|
|
|
|
});
|
2014-12-24 21:58:24 +01:00
|
|
|
|
|
|
|
// Image proxy (avoid SSL mixed content warnings)
|
|
|
|
Router\get_action('proxy', function() {
|
2015-01-07 01:08:10 +01:00
|
|
|
list($content, $type) = Model\Proxy\download(rawurldecode(Request\param('url')));
|
2014-12-24 21:58:24 +01:00
|
|
|
|
|
|
|
if (empty($content)) {
|
|
|
|
Response\text('Not Found', 404);
|
|
|
|
}
|
|
|
|
|
|
|
|
Response\content_type($type);
|
2014-12-29 22:52:36 +01:00
|
|
|
Response\raw($content);
|
2014-12-24 21:58:24 +01:00
|
|
|
});
|