Pass data form to set_register filters

darcs-hash:20071008054253-86b55-d93c18ba8336484edfbfd3631c5b54fbeb207df5.gz
This commit is contained in:
David Rousselie
2007-10-08 07:42:53 +02:00
parent 3f7820bf11
commit ad6c5dddd0
3 changed files with 43 additions and 33 deletions

View File

@@ -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))

View File

@@ -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

View File

@@ -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."