# # 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 for Quassel. """ 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 from plinth.utils import format_lazy from plinth.views import ServiceView version = 1 depends = ['apps'] service = None managed_services = ['quasselcore'] managed_packages = ['quassel-core'] title = _('IRC Client (Quassel)') description = [ format_lazy( _('Quassel is an IRC application that is split into two parts, a ' '"core" and a "client". This allows the core to remain connected ' 'to IRC servers, and to continue receiving messages, even when ' 'the client is disconnected. {box_name} can run the Quassel ' 'core service keeping you always online and one or more Quassel ' 'clients from a desktop or a mobile can be used to connect and ' 'disconnect from it.'), box_name=_(cfg.box_name)), _('You can connect to your Quassel core on the default Quassel port ' '4242. Clients to connect to Quassel from your ' 'desktop and ' 'mobile devices ' 'are available.') ] def init(): """Initialize the quassel module.""" menu = cfg.main_menu.get('apps:index') menu.add_urlname(title, 'glyphicon-retweet', 'quassel:index') global service service = service_module.Service( managed_services[0], title, ports=['quassel-plinth'], is_external=True, enable=enable, disable=disable) if service.is_enabled(): add_shortcut() class QuasselServiceView(ServiceView): service_id = managed_services[0] diagnostics_module_name = "quassel" description = description def setup(helper, old_version=None): """Install and configure the module.""" helper.install(managed_packages) helper.call('post', service.notify_enabled, None, True) helper.call('post', add_shortcut) def add_shortcut(): frontpage.add_shortcut('quassel', title, None, 'glyphicon-retweet', description) def enable(): """Enable the module.""" actions.superuser_run('service', ['enable', managed_services[0]]) add_shortcut() def disable(): """Disable the module.""" actions.superuser_run('service', ['disable', managed_services[0]]) frontpage.remove_shortcut('quassel') def diagnose(): """Run diagnostics and return the results.""" results = [] results.append(action_utils.diagnose_port_listening(4242, 'tcp4')) results.append(action_utils.diagnose_port_listening(4242, 'tcp6')) return results