Пример #1
0
<?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');
});
Пример #2
0
// 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');
});
Пример #3
0
<?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');
});
Пример #4
0
    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');
    }
});
Пример #5
0
});
// 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);
Пример #6
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'))));
});
Пример #7
0
 // '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()) {