diff --git a/actions/ttrss b/actions/ttrss
index 070b9cdcc..43daa2d15 100755
--- a/actions/ttrss
+++ b/actions/ttrss
@@ -18,8 +18,9 @@
#
"""
-Configuration helper for News Feed Reader (Tiny Tiny RSS)
+Configuration helper for Tiny Tiny RSS.
"""
+
import argparse
from plinth import action_utils
@@ -30,8 +31,8 @@ def parse_arguments():
parser = argparse.ArgumentParser()
subparsers = parser.add_subparsers(dest='subcommand', help='Sub command')
- subparsers.add_parser('enable', help='Enable Tiny Tiny RSS')
- subparsers.add_parser('disable', help='Disable Tiny Tiny RSS')
+ subparsers.add_parser('enable', help='Enable Tiny Tiny RSS site')
+ subparsers.add_parser('disable', help='Disable Tiny Tiny RSS site')
return parser.parse_args()
diff --git a/plinth/modules/ttrss/__init__.py b/plinth/modules/ttrss/__init__.py
index b9b8f289e..920975705 100644
--- a/plinth/modules/ttrss/__init__.py
+++ b/plinth/modules/ttrss/__init__.py
@@ -16,26 +16,69 @@
#
"""
-Plinth module to configure Tiny Tiny RSS
+Plinth module to configure Tiny Tiny RSS.
"""
-from gettext import gettext as _
+from django.utils.translation import ugettext_lazy as _
-from plinth import cfg
+from plinth import actions
from plinth import action_utils
+from plinth import cfg
+from plinth import service as service_module
+
+
+version = 1
+
+depends = ['apps']
+
+title = _('News Feed Reader (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 Tiny Tiny RSS module."""
+ """Intialize the module."""
menu = cfg.main_menu.get('apps:index')
- menu.add_urlname(_('News Feed Reader (Tiny Tiny RSS)'), 'glyphicon-envelope',
- 'ttrss:index', 600)
+ menu.add_urlname(title, 'glyphicon-envelope', 'ttrss:index', 780)
+
+ global service
+ service = service_module.Service(
+ 'tt-rss', title, ['http', 'https'], is_external=True,
+ enabled=is_enabled())
+
+
+def setup(helper, old_version=None):
+ """Install and configure the module."""
+ helper.install(['tt-rss'])
+ helper.call('post', service.notify_enabled, None, True)
+
+
+def get_status():
+ """Get the current settings."""
+ return {'enabled': is_enabled()}
-depends = ['plinth.modules.apps']
def is_enabled():
"""Return whether the module is enabled."""
return action_utils.webserver_is_enabled('50-tt-rss')
+
+def enable(should_enable):
+ """Enable/disable the module."""
+ sub_command = 'enable' if should_enable else 'disable'
+ actions.superuser_run('ttrss', [sub_command])
+ service.notify_enabled(None, should_enable)
+
+
def diagnose():
"""Run diagnostics and return the results."""
results = []
diff --git a/plinth/modules/ttrss/forms.py b/plinth/modules/ttrss/forms.py
deleted file mode 100644
index 07439c429..000000000
--- a/plinth/modules/ttrss/forms.py
+++ /dev/null
@@ -1,28 +0,0 @@
-#
-# 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
Tiny Tiny RSS is a news feed (RSS/Atom) reader and aggregator, - designed to allow you to read news from any location, while feeling - as close to a real desktop application as possible.
+ {% include "diagnostics_button.html" with module="ttrss" %} -{% include "diagnostics_button.html" with module="ttrss" %} -