<?php // Display history page Router\get_action('history', function () { $offset = Request\int_param('offset', 0); $nb_items = Model\Item\count_by_status('read'); $items = Model\Item\get_all_by_status('read', array(), $offset, Model\Config\get('items_per_page'), 'updated', Model\Config\get('items_sorting_direction')); Response\html(Template\layout('history', array('favicons' => Model\Favicon\get_item_favicons($items), 'original_marks_read' => Model\Config\get('original_marks_read'), 'items' => $items, 'order' => '', 'direction' => '', 'display_mode' => Model\Config\get('items_display_mode'), 'nb_items' => $nb_items, 'nb_unread_items' => Model\Item\count_by_status('unread'), 'offset' => $offset, 'items_per_page' => Model\Config\get('items_per_page'), 'nothing_to_read' => Request\int_param('nothing_to_read'), 'menu' => 'history', 'title' => t('History') . ' (' . $nb_items . ')'))); }); // Confirmation box to flush history Router\get_action('confirm-flush-history', function () { Response\html(Template\layout('confirm_flush_items', array('nb_unread_items' => Model\Item\count_by_status('unread'), 'menu' => 'history', 'title' => t('Confirmation')))); }); // Flush history Router\get_action('flush-history', function () { Model\Item\mark_all_as_removed(); Response\redirect('?action=history'); });
// Display help page Router\get_action('help', function () { Response\html(Template\layout('help', array('config' => Model\Config\get_all(), 'nb_unread_items' => Model\Item\count_by_status('unread'), 'menu' => 'config', 'title' => t('Preferences')))); }); // Display about page Router\get_action('about', function () { Response\html(Template\layout('about', array('csrf' => Model\Config\generate_csrf(), 'config' => Model\Config\get_all(), 'nb_unread_items' => Model\Item\count_by_status('unread'), 'menu' => 'config', 'title' => t('Preferences')))); }); // Display database page Router\get_action('database', function () { Response\html(Template\layout('database', array('csrf' => Model\Config\generate_csrf(), 'config' => Model\Config\get_all(), 'db_size' => filesize(\Model\Database\get_path()), 'nb_unread_items' => Model\Item\count_by_status('unread'), 'menu' => 'config', 'title' => t('Preferences')))); }); // Display API page Router\get_action('api', function () { Response\html(Template\layout('api', array('config' => Model\Config\get_all(), 'nb_unread_items' => Model\Item\count_by_status('unread'), 'menu' => 'config', 'title' => t('Preferences')))); }); // Display bookmark services page Router\get_action('services', function () { Response\html(Template\layout('services', array('errors' => array(), 'values' => Model\Config\get_all() + array('csrf' => Model\Config\generate_csrf()), 'menu' => 'config', 'title' => t('Preferences')))); }); // Update bookmark services Router\post_action('services', function () { $values = Request\values() + array('pinboard_enabled' => 0, 'instapaper_enabled' => 0); Model\Config\check_csrf_values($values); if (Model\Config\save($values)) { Session\flash(t('Your preferences are updated.')); } else { Session\flash_error(t('Unable to update your preferences.')); } Response\redirect('?action=services'); });
<?php require __DIR__ . '/common.php'; Router\bootstrap(__DIR__ . '/controllers', 'common', 'console', 'user', 'config', 'item', 'history', 'bookmark', 'feed'); // Page not found Router\notfound(function () { Response\redirect('?action=unread'); });
Model\Config\write_debug(); if (isset($feed_id) && $feed_id !== false) { Session\flash(t('Subscription added successfully.')); Response\redirect('?action=feed-items&feed_id=' . $feed_id); } else { if (!isset($error_message)) { $error_message = t('Error occured.'); } Session\flash_error($error_message); } Response\html(Template\layout('add', array('values' => $values + array('csrf' => Model\Config\generate_csrf()), 'nb_unread_items' => Model\Item\count_by_status('unread'), 'groups' => Model\Group\get_all(), 'menu' => 'feeds', 'title' => t('Subscriptions')))); }); // OPML export Router\get_action('export', function () { Response\force_download('feeds.opml'); Response\xml(Model\Feed\export_opml()); }); // OPML import form Router\get_action('import', function () { Response\html(Template\layout('import', array('errors' => array(), 'nb_unread_items' => Model\Item\count_by_status('unread'), 'menu' => 'feeds', 'title' => t('OPML Import')))); }); // OPML importation Router\post_action('import', function () { if (Model\Feed\import_opml(Request\file_content('file'))) { Session\flash(t('Your feeds have been imported.')); Response\redirect('?action=feeds'); } else { Session\flash_error(t('Unable to import your OPML file.')); Response\redirect('?action=import'); } });
}); // Mark unread items as read Router\get_action('mark-all-read', function () { $group_id = Request\int_param('group_id', null); if (!is_null($group_id)) { Model\Item\mark_group_as_read($group_id); } else { Model\Item\mark_all_as_read(); } Response\redirect('?action=unread'); }); // Mark all unread items as read for a specific feed Router\get_action('mark-feed-as-read', function () { $feed_id = Request\int_param('feed_id'); Model\Item\mark_feed_as_read($feed_id); Response\redirect('?action=feed-items&feed_id=' . $feed_id); }); // Mark all unread items as read for a specific feed (Ajax request) and return // the number of unread items. It's not possible to get the number of items // that where marked read from the frontend, since the number of unread items // on page 2+ is unknown. Router\post_action('mark-feed-as-read', function () { Model\Item\mark_feed_as_read(Request\int_param('feed_id')); $nb_items = Model\Item\count_by_status('unread'); Response\raw($nb_items); }); // Mark item as read and redirect to the listing page Router\get_action('mark-item-read', function () { $id = Request\param('id'); $redirect = Request\param('redirect', 'unread'); $offset = Request\int_param('offset', 0);
<?php // Flush console messages Router\get_action('flush-console', function () { @unlink(DEBUG_FILENAME); Response\redirect('?action=console'); }); // Display console Router\get_action('console', function () { Response\html(Template\layout('console', array('content' => @file_get_contents(DEBUG_FILENAME), 'nb_unread_items' => Model\Item\count_by_status('unread'), 'menu' => 'config', 'title' => t('Console')))); });
// 'remember me' cookie if (!is_null(Request\value('database')) && !Model\Database\select(Request\value('database'))) { Model\User\logout(); Response\redirect('?action=login'); } elseif (!empty($_SESSION['database'])) { if (!Model\Database\select($_SESSION['database'])) { Model\User\logout(); 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'); if (!Model\User\is_loggedin() && !in_array($action, $safe_actions)) { if (!Model\RememberMe\authenticate()) { Model\User\logout(); Response\redirect('?action=login'); } } elseif (Model\RememberMe\has_cookie()) { Model\RememberMe\refresh(); } // Load translations $language = Model\Config\get('language') ?: 'en_US'; Translator\load($language); // 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()) {