changeset 1532:4c558a3fe052

plugin tmp_demo_directory: removed
author souliane <souliane@mailoo.org>
date Mon, 14 Sep 2015 08:52:00 +0200
parents 51dec65ec62c
children d749922300d0
files src/plugins/plugin_tmp_demo_directory.py
diffstat 1 files changed, 0 insertions(+), 141 deletions(-) [+]
line wrap: on
line diff
--- a/src/plugins/plugin_tmp_demo_directory.py	Sat Sep 26 18:39:05 2015 +0200
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,141 +0,0 @@
-#!/usr/bin/python
-# -*- coding: utf-8 -*-
-
-# SAT plugin for account creation (experimental)
-# Copyright (C) 2009, 2010, 2011, 2012, 2013, 2014, 2015 Jérôme Poisson (goffi@goffi.org)
-
-# 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 <http://www.gnu.org/licenses/>.
-
-from sat.core.i18n import _, D_
-from sat.core.log import getLogger
-log = getLogger(__name__)
-from twisted.internet import defer
-from twisted.words.protocols.jabber.xmlstream import IQ
-from twisted.words.protocols.jabber import jid
-from wokkel import data_form
-
-PLUGIN_INFO = {
-    "name": "Demo directory plugin",
-    "import_name": "DEMO-DIRECTORY",
-    "type": "TMP",
-    "protocols": [],
-    "dependencies": [],
-    "main": "DemoDirectory",
-    "handler": "no",
-    "description": _(u"""Plugin to add paramaters to subscribe to the demo directory""")
-}
-
-NS_COMMANDS = "http://jabber.org/protocol/commands"
-
-CONFIG_SECTION = "plugin demo directory"
-CONFIG_ACTIVATE = "activate"
-CONFIG_SERVICE = "service"
-
-PARAM_CATEGORY = ("directory", D_("Directory"))
-PARAM_NAME_INFO = D_("To appear on the directory, check the box. To be removed from the directory, just uncheck it.")
-PARAM_NAME_DESC = ("description", D_("Some words about you"))
-PARAM_NAME_SUB = ("subscribe", D_("I want to appear in the public demo directory"))
-
-
-
-class DemoDirectory(object):
-    """Account plugin: create a SàT + Prosody account, used by Libervia"""
-    # XXX: This plugin is a Q&D one used for the demo.
-    # TODO: A generic way to add menu/parameters for local services would be nice
-
-    params = """
-    <params>
-    <individual>
-    <category name="%(category_name)s" label="%(category_label)s">
-        <param label="%(info)s" type="text" security="1" />
-        <param name="%(desc)s" label="%(desc_label)s" type="string" security="1" />
-        <param name="%(sub)s" label="%(sub_label)s" value='false' type="bool" security="1" />
-     </category>
-    </individual>
-    </params>
-    """ % {
-        'category_name': PARAM_CATEGORY[0],
-        'category_label': _(PARAM_CATEGORY[1]),
-        'info': _(PARAM_NAME_INFO),
-        'desc': PARAM_NAME_DESC[0],
-        'desc_label': _(PARAM_NAME_DESC[1]),
-        'sub': PARAM_NAME_SUB[0],
-        'sub_label': _(PARAM_NAME_SUB[1]),
-    }
-
-    def __init__(self, host):
-        log.info(_(u"Plugin demo directory initialization"))
-        activate = host.memory.getConfig(CONFIG_SECTION, CONFIG_ACTIVATE, 'false')
-        if not activate.lower() in ('true', 'yes', '1'):
-            log.info("not activated")
-            return
-        service_str = host.memory.getConfig(CONFIG_SECTION, CONFIG_SERVICE, 'salut.libervia.org')
-        self.service = jid.JID(service_str)
-        self.host = host
-        host.memory.updateParams(self.params)
-        host.trigger.add("paramUpdateTrigger", self.paramUpdateTrigger)
-
-    @defer.inlineCallbacks
-    def manageSubscription(self, subscribe, profile):
-        """ Subscribe or unsubscribe according to subscribe value
-        This follow the implementation of the "Salut", this is not for general purpose
-        @param subscribe: True to subscribe, else unsubscribe
-        @param profile: %(doc_profile)s
-
-        """
-        client = self.host.getClient(profile)
-        if not subscribe:
-            log.info ("Unsubscribing [%s] from directory" % profile)
-            unsub_req = IQ(client.xmlstream, 'set')
-            unsub_req['from'] = client.jid.full()
-            unsub_req['to'] = self.service.userhost()
-            command_elt = unsub_req.addElement('command', NS_COMMANDS)
-            command_elt['node'] = 'unsubscribe'
-            command_elt['action'] = 'execute'
-            yield unsub_req.send(self.service.userhost())
-        else:
-            log.info ("Subscribing [%s] to directory" % profile)
-            sub_req = IQ(client.xmlstream, 'set')
-            sub_req['from'] = client.jid.full()
-            sub_req['to'] = self.service.userhost()
-            command_elt = sub_req.addElement('command', NS_COMMANDS)
-            command_elt['node'] = 'subscribe'
-            command_elt['action'] = 'execute'
-            sub_first_elt = yield sub_req.send(self.service.userhost())
-            sub_cmd = sub_first_elt.elements(NS_COMMANDS, 'command').next()
-            session_id = sub_cmd['sessionid']
-            sub_req = IQ(client.xmlstream, 'set')
-            sub_req['from'] = client.jid.full()
-            sub_req['to'] = self.service.userhost()
-            command_elt = sub_req.addElement('command', NS_COMMANDS)
-            command_elt['node'] = 'subscribe'
-            command_elt['action'] = 'execute'
-            command_elt['sessionid'] = session_id
-            description = self.host.memory.getParamA(PARAM_NAME_DESC[0], PARAM_CATEGORY[0], profile_key=client.profile)
-            ret_form = data_form.Form('submit')
-            ret_form.makeFields({'jid': client.jid.userhost(), 'description': description})
-            command_elt.addChild(ret_form.toElement())
-            yield sub_req.send(self.service.userhost())
-
-    def paramUpdateTrigger(self, name, value, category, type_, profile):
-        """
-        Reset all the existing chat state entity data associated with this profile after a parameter modification.
-        @param name: parameter name
-        @param value: "true" to activate the notifications, or any other value to delete it
-        @param category: parameter category
-        """
-        if (category, name) == (PARAM_CATEGORY[0], PARAM_NAME_SUB[0]):
-            self.manageSubscription(value.lower()=='true', profile)
-            return False
-        return True