diff --git a/modules/installed/services/xmpp.py b/modules/installed/services/xmpp.py index 7e1cb749f..6ccc469cf 100644 --- a/modules/installed/services/xmpp.py +++ b/modules/installed/services/xmpp.py @@ -11,50 +11,60 @@ class xmpp(PagePlugin): def __init__(self, *args, **kwargs): PagePlugin.__init__(self, *args, **kwargs) self.register_page("services.xmpp") + self.register_page("services.xmpp.configure") self.register_page("services.xmpp.register") cfg.html_root.services.menu.add_item("XMPP", "icon-comment", "/services/xmpp", 40) @cherrypy.expose @require() - def index(self, submitted=False, **kwargs): - checkedinfo = { - 'inband_enable' : False, - } + def index(self, **kwargs): + main = "
XMPP Server Accounts and Configuration
" + sidebar_right = 'Configure XMPP ServerXMPP Server Configuration
" - form = Form(title="Configuration", - action=cfg.server_dir + "/services/xmpp", - name="configure_xmpp", - message='') - form.checkbox(_("Allow In-Band Registration"), name="xmpp_inband_enable", - id="xmpp_inband_enable", checked=checkedinfo['inband_enable']) + form = Form(title="Configure XMPP Server", + action=cfg.server_dir + "/services/xmpp/configure/index", + name="configure_xmpp_form", + message=message) + form.checkbox(_("Allow In-Band Registration"), name="inband_enable", + id="inband_enable", checked=inband_enable) + # hidden field is needed because checkbox doesn't post if not checked form.hidden(name="submitted", value="True") form.html(_("When enabled, anyone who can reach this server will be allowed to register an account through an XMPP client.
")) form.submit(_("Update setup")) - main += form.render() + return form.render() - sidebar_right = 'Register XMPP Account' - return self.fill_template(title="XMPP Server Configuration", main=main, sidebar_right=sidebar_right) + def process_form(self, inband_enable=None, **kwargs): + msg = Message() + + if inband_enable == u'on': + output, error = privilegedaction_run("xmpp-setup", "inband_enable") + if error: + raise Exception("something is wrong: " + error) + msg.add = _("Enabled in-band registration.") + else: + output, error = privilegedaction_run("xmpp-setup", "noinband_enable") + if error: + raise Exception("something is wrong: " + error) + msg.add = _("Disabled in-band registration.") + + cfg.log(msg.text) + main = self.main(inband_enable, msg=msg.text) + return self.fill_template(title="XMPP Server Configuration", main=main, sidebar_left=self.sidebar_left, sidebar_right=self.sidebar_right) class register(FormPlugin, PagePlugin): url = ["/services/xmpp/register"]