# # This file is part of Plinth. # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU Affero General Public License as # published by the Free Software Foundation, either version 3 of the # License, or (at your option) any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU Affero General Public License for more details. # # You should have received a copy of the GNU Affero General Public License # along with this program. If not, see . # """ Plinth module to configure Tiny Tiny RSS. """ from django.utils.translation import ugettext_lazy as _ from plinth import actions from plinth import action_utils from plinth import cfg from plinth import frontpage from plinth import service as service_module version = 1 depends = ['apps'] managed_services = ['tt-rss'] managed_packages = ['tt-rss', 'postgresql', 'dbconfig-pgsql', 'php-pgsql'] title = _('News Feed Reader \n (Tiny Tiny RSS)') description = [ _('Tiny Tiny RSS is a news feed (RSS/Atom) reader and aggregator, ' 'designed to allow reading news from any location, while feeling as ' 'close to a real desktop application as possible.'), _('When enabled, Tiny Tiny RSS will be available from ' '/tt-rss path on the web server.'), ] service = None def init(): """Intialize the module.""" menu = cfg.main_menu.get('apps:index') menu.add_urlname(title, 'glyphicon-envelope', 'ttrss:index') global service setup_helper = globals()['setup_helper'] if setup_helper.get_state() != 'needs-setup': service = service_module.Service( managed_services[0], title, ports=['http', 'https'], is_external=True, is_enabled=is_enabled, enable=enable, disable=disable) if is_enabled(): add_shortcut() def setup(helper, old_version=None): """Install and configure the module.""" helper.call('pre', actions.superuser_run, 'ttrss', ['pre-setup']) helper.install(managed_packages) helper.call('post', actions.superuser_run, 'ttrss', ['setup']) global service if service is None: service = service_module.Service( managed_services[0], title, ports=['http', 'https'], is_external=True, is_enabled=is_enabled, enable=enable, disable=disable) helper.call('post', service.notify_enabled, None, True) helper.call('post', add_shortcut) def add_shortcut(): frontpage.add_shortcut('ttrss', title, url='/tt-rss', login_required=True) def is_enabled(): """Return whether the module is enabled.""" return (action_utils.service_is_enabled('tt-rss') and action_utils.webserver_is_enabled('tt-rss-plinth')) def enable(): """Enable the module.""" actions.superuser_run('ttrss', ['enable']) add_shortcut() def disable(): """Enable the module.""" actions.superuser_run('ttrss', ['disable']) frontpage.remove_shortcut('ttrss') def diagnose(): """Run diagnostics and return the results.""" results = [] results.extend(action_utils.diagnose_url_on_all( 'https://{host}/tt-rss', check_certificate=False)) return results