miniflux-legacy/controllers/common.php

71 lines
2.1 KiB
PHP
Raw Normal View History

<?php
// Called before each action
2016-04-18 01:44:45 +02:00
Router\before(function ($action) {
Session\open(BASE_URL_DIRECTORY, SESSION_SAVE_PATH, 0);
2014-02-08 20:13:14 +01:00
// Select the requested database either from post param database or from the
// session variable. If it fails, logout to destroy session and
// 'remember me' cookie
2016-05-03 10:45:07 +02:00
if (Request\value('database') !== null && ! Model\Database\select(Request\value('database'))) {
Model\User\logout();
Response\redirect('?action=login');
2016-04-18 01:44:45 +02:00
} elseif (! empty($_SESSION['database'])) {
if (! Model\Database\select($_SESSION['database'])) {
Model\User\logout();
2014-05-27 02:47:40 +02:00
Response\redirect('?action=login');
}
}
// These actions are considered to be safe even for unauthenticated users
$safe_actions = array('login', 'bookmark-feed', 'select-db', 'logout', 'notfound');
2015-01-18 00:53:40 +01:00
if (! Model\User\is_loggedin() && ! in_array($action, $safe_actions)) {
if (! Model\RememberMe\authenticate()) {
Model\User\logout();
Response\redirect('?action=login');
}
2016-04-18 01:44:45 +02:00
} elseif (Model\RememberMe\has_cookie()) {
Model\RememberMe\refresh();
}
// Load translations
$language = Model\Config\get('language') ?: 'en_US';
Translator\load($language);
2014-02-26 01:03:46 +01:00
// Set timezone
date_default_timezone_set(Model\Config\get('timezone') ?: 'UTC');
// HTTP secure headers
Response\csp(array(
'media-src' => '*',
'img-src' => '* data:',
'frame-src' => Model\Config\get_iframe_whitelist(),
'referrer' => 'no-referrer',
));
Response\xframe();
Response\xss();
Response\nosniff();
if (ENABLE_HSTS && Helper\is_secure_connection()) {
Response\hsts();
}
});
// Show help
2016-04-18 01:44:45 +02:00
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
2016-04-18 01:44:45 +02:00
Router\get_action('more', function () {
2014-02-05 03:47:59 +01:00
Response\html(Template\layout('show_more', array('menu' => 'more')));
});
// Image proxy (avoid SSL mixed content warnings)
2016-04-18 01:44:45 +02:00
Router\get_action('proxy', function () {
Model\Proxy\download(rawurldecode(Request\param('url')));
exit;
});