Pass data form to set_register filters
darcs-hash:20071008054253-86b55-d93c18ba8336484edfbfd3631c5b54fbeb207df5.gz
This commit is contained in:
@@ -458,18 +458,11 @@ class JCLComponent(Component, object):
|
|||||||
{"jir" : "jabber:iq:register",
|
{"jir" : "jabber:iq:register",
|
||||||
"jxd" : "jabber:x:data"})[0]
|
"jxd" : "jabber:x:data"})[0]
|
||||||
x_data = Form(x_node)
|
x_data = Form(x_node)
|
||||||
if not "name" in x_data or x_data["name"].value == "":
|
|
||||||
iq_error = info_query.make_error_response("not-acceptable")
|
|
||||||
text = iq_error.get_error().xmlnode.newTextChild(\
|
|
||||||
None,
|
|
||||||
"text",
|
|
||||||
lang_class.mandatory_field % ("name"))
|
|
||||||
text.setNs(text.newNs(error.STANZA_ERROR_NS, None))
|
|
||||||
self.stream.send(iq_error)
|
|
||||||
return
|
|
||||||
return self.apply_registered_behavior(\
|
return self.apply_registered_behavior(\
|
||||||
self.set_register_handlers,
|
self.set_register_handlers,
|
||||||
info_query,
|
info_query,
|
||||||
|
apply_filter_func=lambda filter_func, stanza, lang_class: \
|
||||||
|
filter_func(stanza, lang_class, x_data),
|
||||||
apply_handle_func=lambda handle_func, stanza, lang_class, data, result: \
|
apply_handle_func=lambda handle_func, stanza, lang_class, data, result: \
|
||||||
handle_func(stanza, lang_class, data, x_data))
|
handle_func(stanza, lang_class, data, x_data))
|
||||||
|
|
||||||
|
|||||||
@@ -38,7 +38,7 @@ class SetRegisterHandler(object):
|
|||||||
self.account_manager = component.account_manager
|
self.account_manager = component.account_manager
|
||||||
self.__logger = logging.getLogger("jcl.jabber.SetRegisterHandler")
|
self.__logger = logging.getLogger("jcl.jabber.SetRegisterHandler")
|
||||||
|
|
||||||
def filter(self, info_query, lang_class, node):
|
def filter(self, info_query, lang_class, x_data):
|
||||||
"""Filter requests to be handled"""
|
"""Filter requests to be handled"""
|
||||||
return False
|
return False
|
||||||
|
|
||||||
@@ -61,27 +61,38 @@ class SetRegisterHandler(object):
|
|||||||
|
|
||||||
class RootSetRegisterHandler(SetRegisterHandler):
|
class RootSetRegisterHandler(SetRegisterHandler):
|
||||||
|
|
||||||
filter = jabber.root_filter
|
|
||||||
|
|
||||||
def __init__(self, component):
|
def __init__(self, component):
|
||||||
SetRegisterHandler.__init__(self, component)
|
SetRegisterHandler.__init__(self, component)
|
||||||
self.__logger = logging.getLogger("jcl.jabber.RootSetRegisterHandler")
|
self.__logger = logging.getLogger("jcl.jabber.RootSetRegisterHandler")
|
||||||
|
|
||||||
|
def filter(self, stanza, lang_class, x_data):
|
||||||
|
""""""
|
||||||
|
return jabber.root_filter(self, stanza, lang_class)
|
||||||
|
|
||||||
def handle(self, info_query, lang_class, data, x_data):
|
def handle(self, info_query, lang_class, data, x_data):
|
||||||
""""""
|
""""""
|
||||||
self.__logger.debug("root_set_register")
|
self.__logger.debug("root_set_register")
|
||||||
_account = None
|
_account = None
|
||||||
|
if not "name" in x_data or x_data["name"].value == "":
|
||||||
|
# TODO : use handle_error
|
||||||
|
iq_error = info_query.make_error_response("not-acceptable")
|
||||||
|
text = iq_error.get_error().xmlnode.newTextChild(\
|
||||||
|
None,
|
||||||
|
"text",
|
||||||
|
lang_class.mandatory_field % ("name"))
|
||||||
|
text.setNs(text.newNs(error.STANZA_ERROR_NS, None))
|
||||||
|
return [iq_error]
|
||||||
try:
|
try:
|
||||||
info_querys = self.account_manager.create_default_account(\
|
info_queries = self.account_manager.create_default_account(\
|
||||||
x_data["name"].value,
|
x_data["name"].value,
|
||||||
info_query.get_from(),
|
info_query.get_from(),
|
||||||
lang_class,
|
lang_class,
|
||||||
x_data)
|
x_data)
|
||||||
info_querys.insert(0, info_query.make_result_response())
|
info_queries.insert(0, info_query.make_result_response())
|
||||||
except FieldError, field_error:
|
except FieldError, field_error:
|
||||||
return self.handle_error(field_error,
|
return self.handle_error(field_error,
|
||||||
info_query, lang_class)
|
info_query, lang_class)
|
||||||
return info_querys
|
return info_queries
|
||||||
|
|
||||||
class AccountSetRegisterHandler(SetRegisterHandler):
|
class AccountSetRegisterHandler(SetRegisterHandler):
|
||||||
|
|
||||||
@@ -91,44 +102,50 @@ class AccountSetRegisterHandler(SetRegisterHandler):
|
|||||||
SetRegisterHandler.__init__(self, component)
|
SetRegisterHandler.__init__(self, component)
|
||||||
self.__logger = logging.getLogger("jcl.jabber.AccountSetRegisterHandler")
|
self.__logger = logging.getLogger("jcl.jabber.AccountSetRegisterHandler")
|
||||||
|
|
||||||
|
def filter(self, stanza, lang_class, x_data):
|
||||||
|
""""""
|
||||||
|
return jabber.account_filter(self, stanza, lang_class)
|
||||||
|
|
||||||
def handle(self, info_query, lang_class, data, x_data):
|
def handle(self, info_query, lang_class, data, x_data):
|
||||||
""""""
|
""""""
|
||||||
self.__logger.debug("account_set_register")
|
self.__logger.debug("account_set_register")
|
||||||
_account = None
|
_account = None
|
||||||
try:
|
try:
|
||||||
info_querys = self.account_manager.update_account(\
|
info_queries = self.account_manager.update_account(\
|
||||||
x_data["name"].value,
|
x_data["name"].value,
|
||||||
info_query.get_from(),
|
info_query.get_from(),
|
||||||
lang_class,
|
lang_class,
|
||||||
x_data)
|
x_data)
|
||||||
info_querys.insert(0, info_query.make_result_response())
|
info_queries.insert(0, info_query.make_result_response())
|
||||||
except FieldError, field_error:
|
except FieldError, field_error:
|
||||||
return self.handle_error(field_error,
|
return self.handle_error(field_error,
|
||||||
info_query, lang_class)
|
info_query, lang_class)
|
||||||
return info_querys
|
return info_queries
|
||||||
|
|
||||||
class AccountTypeSetRegisterHandler(SetRegisterHandler):
|
class AccountTypeSetRegisterHandler(SetRegisterHandler):
|
||||||
|
|
||||||
filter = jabber.account_type_filter
|
|
||||||
|
|
||||||
def __init__(self, component):
|
def __init__(self, component):
|
||||||
SetRegisterHandler.__init__(self, component)
|
SetRegisterHandler.__init__(self, component)
|
||||||
self.__logger = logging.getLogger("jcl.jabber.AccountTypeSetRegisterHandler")
|
self.__logger = logging.getLogger("jcl.jabber.AccountTypeSetRegisterHandler")
|
||||||
|
|
||||||
|
def filter(self, stanza, lang_class, x_data):
|
||||||
|
""""""
|
||||||
|
return jabber.account_type_filter(self, stanza, lang_class)
|
||||||
|
|
||||||
def handle(self, info_query, lang_class, data, x_data):
|
def handle(self, info_query, lang_class, data, x_data):
|
||||||
""""""
|
""""""
|
||||||
self.__logger.debug("account_type_set_register")
|
self.__logger.debug("account_type_set_register")
|
||||||
account_type = data
|
account_type = data
|
||||||
_account = None
|
_account = None
|
||||||
try:
|
try:
|
||||||
info_querys = self.account_manager.create_account_from_type(\
|
info_queries = self.account_manager.create_account_from_type(\
|
||||||
x_data["name"].value,
|
x_data["name"].value,
|
||||||
info_query.get_from(),
|
info_query.get_from(),
|
||||||
account_type,
|
account_type,
|
||||||
lang_class,
|
lang_class,
|
||||||
x_data)
|
x_data)
|
||||||
info_querys.insert(0, info_query.make_result_response())
|
info_queries.insert(0, info_query.make_result_response())
|
||||||
except FieldError, field_error:
|
except FieldError, field_error:
|
||||||
return self.handle_error(field_error,
|
return self.handle_error(field_error,
|
||||||
info_query, lang_class)
|
info_query, lang_class)
|
||||||
return info_querys
|
return info_queries
|
||||||
|
|||||||
@@ -72,10 +72,10 @@ class Lang:
|
|||||||
|
|
||||||
class en:
|
class en:
|
||||||
component_name = u"Jabber Component Library generic component"
|
component_name = u"Jabber Component Library generic component"
|
||||||
register_title = u"Connection registration"
|
register_title = u"Create new account"
|
||||||
register_instructions = u"Enter connection parameters"
|
register_instructions = u"Enter account parameters"
|
||||||
message_status = u" accounts registered."
|
message_status = u" accounts registered."
|
||||||
account_name = u"Connection name"
|
account_name = u"Account name"
|
||||||
|
|
||||||
password_saved_for_session = u"Password will be kept during your " \
|
password_saved_for_session = u"Password will be kept during your " \
|
||||||
u"Jabber session"
|
u"Jabber session"
|
||||||
@@ -236,10 +236,10 @@ class Lang:
|
|||||||
|
|
||||||
class fr:
|
class fr:
|
||||||
component_name = u"composant générique Jabber Component Library"
|
component_name = u"composant générique Jabber Component Library"
|
||||||
register_title = u"Enregistrement d'une nouvelle connexion"
|
register_title = u"Enregistrement d'un nouveau compte"
|
||||||
register_instructions = u"Entrer les paramètres de connexion"
|
register_instructions = u"Entrer les paramètres du compte"
|
||||||
message_status = u" comptes enregistrés."
|
message_status = u" comptes enregistrés."
|
||||||
account_name = u"Nom de la connexion"
|
account_name = u"Nom du compte"
|
||||||
|
|
||||||
password_saved_for_session = u"Le mot de passe sera garder tout au " \
|
password_saved_for_session = u"Le mot de passe sera garder tout au " \
|
||||||
u"long de la session Jabber."
|
u"long de la session Jabber."
|
||||||
|
|||||||
Reference in New Issue
Block a user