2013-12-22 20:55:53 -05:00
|
|
|
<?php
|
|
|
|
|
2016-08-24 21:17:58 -04:00
|
|
|
use Miniflux\Router;
|
|
|
|
use Miniflux\Response;
|
|
|
|
use Miniflux\Request;
|
|
|
|
use Miniflux\Session;
|
|
|
|
use Miniflux\Template;
|
|
|
|
use Miniflux\Helper;
|
|
|
|
use Miniflux\Model;
|
|
|
|
use Miniflux\Translator;
|
|
|
|
use Miniflux\Handler;
|
|
|
|
|
2013-12-22 20:55:53 -05:00
|
|
|
// Called before each action
|
2016-04-17 19:44:45 -04:00
|
|
|
Router\before(function ($action) {
|
2015-01-17 19:17:44 -05:00
|
|
|
Session\open(BASE_URL_DIRECTORY, SESSION_SAVE_PATH, 0);
|
2014-02-08 14:13:14 -05:00
|
|
|
|
2015-01-18 01:53:54 +01:00
|
|
|
// Select the requested database either from post param database or from the
|
|
|
|
// session variable. If it fails, logout to destroy session and
|
2015-01-17 19:35:59 +01:00
|
|
|
// 'remember me' cookie
|
2016-05-03 17:45:07 +09:00
|
|
|
if (Request\value('database') !== null && ! Model\Database\select(Request\value('database'))) {
|
2015-01-18 01:53:54 +01:00
|
|
|
Model\User\logout();
|
|
|
|
Response\redirect('?action=login');
|
2016-04-17 19:44:45 -04:00
|
|
|
} elseif (! empty($_SESSION['database'])) {
|
2015-01-17 19:35:59 +01:00
|
|
|
if (! Model\Database\select($_SESSION['database'])) {
|
|
|
|
Model\User\logout();
|
2014-05-26 20:47:40 -04:00
|
|
|
Response\redirect('?action=login');
|
|
|
|
}
|
|
|
|
}
|
2014-11-18 19:00:53 -05: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-18 19:00:53 -05:00
|
|
|
|
2015-01-17 18:53:40 -05:00
|
|
|
if (! Model\User\is_loggedin() && ! in_array($action, $safe_actions)) {
|
2015-01-17 19:35:59 +01:00
|
|
|
if (! Model\RememberMe\authenticate()) {
|
|
|
|
Model\User\logout();
|
|
|
|
Response\redirect('?action=login');
|
2014-11-18 19:00:53 -05:00
|
|
|
}
|
2016-04-17 19:44:45 -04:00
|
|
|
} elseif (Model\RememberMe\has_cookie()) {
|
2015-01-17 19:35:59 +01:00
|
|
|
Model\RememberMe\refresh();
|
|
|
|
}
|
2013-12-22 20:55:53 -05:00
|
|
|
|
|
|
|
// Load translations
|
|
|
|
$language = Model\Config\get('language') ?: 'en_US';
|
2015-01-30 19:45:23 +01:00
|
|
|
Translator\load($language);
|
2013-12-22 20:55:53 -05:00
|
|
|
|
2014-02-25 19:03:46 -05:00
|
|
|
// Set timezone
|
|
|
|
date_default_timezone_set(Model\Config\get('timezone') ?: 'UTC');
|
|
|
|
|
2013-12-22 20:55:53 -05:00
|
|
|
// HTTP secure headers
|
|
|
|
Response\csp(array(
|
|
|
|
'media-src' => '*',
|
2015-08-21 18:18:08 -04:00
|
|
|
'img-src' => '* data:',
|
2014-11-07 20:53:50 -05:00
|
|
|
'frame-src' => Model\Config\get_iframe_whitelist(),
|
2016-08-05 20:50:48 -04:00
|
|
|
'child-src' => Model\Config\get_iframe_whitelist(),
|
2015-05-16 09:35:50 +02:00
|
|
|
'referrer' => 'no-referrer',
|
2013-12-22 20:55:53 -05:00
|
|
|
));
|
|
|
|
|
|
|
|
Response\xframe();
|
|
|
|
Response\xss();
|
|
|
|
Response\nosniff();
|
2015-05-17 13:40:56 -04:00
|
|
|
|
|
|
|
if (ENABLE_HSTS && Helper\is_secure_connection()) {
|
|
|
|
Response\hsts();
|
|
|
|
}
|
2013-12-22 20:55:53 -05:00
|
|
|
});
|
|
|
|
|
|
|
|
// Show help
|
2016-04-17 19:44:45 -04:00
|
|
|
Router\get_action('show-help', function () {
|
2013-12-22 20:55:53 -05:00
|
|
|
Response\html(Template\load('show_help'));
|
2014-02-04 21:47:59 -05:00
|
|
|
});
|
|
|
|
|
2014-12-24 15:58:24 -05:00
|
|
|
// Image proxy (avoid SSL mixed content warnings)
|
2016-04-17 19:44:45 -04:00
|
|
|
Router\get_action('proxy', function () {
|
2016-08-18 22:41:39 -04:00
|
|
|
Handler\Proxy\download(rawurldecode(Request\param('url')));
|
2015-02-01 22:54:57 +01:00
|
|
|
exit;
|
2014-12-24 15:58:24 -05:00
|
|
|
});
|