'get-registered-users-list' ad-hoc command implementation

darcs-hash:20070812192349-86b55-bd12aec438cbf3194e4e7707779afd0052c359dd.gz
This commit is contained in:
David Rousselie
2007-08-12 21:23:49 +02:00
parent 6b18a10952
commit bfbadc8e98
4 changed files with 214 additions and 49 deletions

View File

@@ -226,13 +226,17 @@ class JCLCommandManager(CommandManager):
""" """
JCLCommandManager constructor JCLCommandManager constructor
Not implemented commands: Not implemented commands:
"http://jabber.org/protocol/admin#user-stats", 'http://jabber.org/protocol/admin#user-stats',
"http://jabber.org/protocol/admin#edit-blacklist", 'http://jabber.org/protocol/admin#edit-blacklist',
"http://jabber.org/protocol/admin#add-to-blacklist-in", 'http://jabber.org/protocol/admin#add-to-blacklist-in',
"http://jabber.org/protocol/admin#add-to-blacklist-out", 'http://jabber.org/protocol/admin#add-to-blacklist-out',
"http://jabber.org/protocol/admin#edit-whitelist", 'http://jabber.org/protocol/admin#edit-whitelist',
"http://jabber.org/protocol/admin#add-to-whitelist-in", 'http://jabber.org/protocol/admin#add-to-whitelist-in',
"http://jabber.org/protocol/admin#add-to-whitelist-out", 'http://jabber.org/protocol/admin#add-to-whitelist-out',
'http://jabber.org/protocol/admin#get-active-users-num',
'http://jabber.org/protocol/admin#get-idle-users-num',
'http://jabber.org/protocol/admin#get-active-users',
'http://jabber.org/protocol/admin#get-idle-users',
""" """
CommandManager.__init__(self, component, account_manager) CommandManager.__init__(self, component, account_manager)
self.__logger = logging.getLogger("jcl.jabber.command.JCLCommandManager") self.__logger = logging.getLogger("jcl.jabber.command.JCLCommandManager")
@@ -249,13 +253,9 @@ class JCLCommandManager(CommandManager):
"http://jabber.org/protocol/admin#get-registered-users-num", "http://jabber.org/protocol/admin#get-registered-users-num",
"http://jabber.org/protocol/admin#get-disabled-users-num", "http://jabber.org/protocol/admin#get-disabled-users-num",
"http://jabber.org/protocol/admin#get-online-users-num", "http://jabber.org/protocol/admin#get-online-users-num",
"http://jabber.org/protocol/admin#get-active-users-num",
"http://jabber.org/protocol/admin#get-idle-users-num",
"http://jabber.org/protocol/admin#get-registered-users-list", "http://jabber.org/protocol/admin#get-registered-users-list",
"http://jabber.org/protocol/admin#get-disabled-users-list", "http://jabber.org/protocol/admin#get-disabled-users-list",
"http://jabber.org/protocol/admin#get-online-users", "http://jabber.org/protocol/admin#get-online-users",
"http://jabber.org/protocol/admin#get-active-users",
"http://jabber.org/protocol/admin#get-idle-users",
"http://jabber.org/protocol/admin#announce", "http://jabber.org/protocol/admin#announce",
"http://jabber.org/protocol/admin#set-motd", "http://jabber.org/protocol/admin#set-motd",
"http://jabber.org/protocol/admin#edit-motd", "http://jabber.org/protocol/admin#edit-motd",
@@ -448,7 +448,7 @@ class JCLCommandManager(CommandManager):
return (None, result) return (None, result)
execute_disable_user_1 = select_user_jids_step_1 execute_disable_user_1 = select_user_jids_step_1
def execute_disable_user_2(self, info_query, session_context, def execute_disable_user_2(self, info_query, session_context,
command_node, lang_class): command_node, lang_class):
self.__logger.debug("Executing 'disable-user' step 2") self.__logger.debug("Executing 'disable-user' step 2")
@@ -592,7 +592,7 @@ class JCLCommandManager(CommandManager):
execute_get_user_lastlogin_1 = select_user_jid_step_1 execute_get_user_lastlogin_1 = select_user_jid_step_1
execute_get_user_lastlogin_2 = select_account_step_2 execute_get_user_lastlogin_2 = select_account_step_2
def execute_get_user_lastlogin_3(self, info_query, session_context, def execute_get_user_lastlogin_3(self, info_query, session_context,
command_node, lang_class): command_node, lang_class):
self.__logger.debug("Executing command 'get-user-roster' step 2") self.__logger.debug("Executing command 'get-user-roster' step 2")
@@ -654,14 +654,50 @@ class JCLCommandManager(CommandManager):
command_node.setProp("status", STATUS_COMPLETED) command_node.setProp("status", STATUS_COMPLETED)
return (result_form, []) return (result_form, [])
def execute_get_active_users_num(self, info_query): def add_form_list_accounts(self, command_node, lang_class,
filter=None, limit=None):
result_form = Form(xmlnode_or_type="result")
result_form.add_field(field_type="hidden",
name="FORM_TYPE",
value="http://jabber.org/protocol/admin")
accounts = account.get_all_accounts(filter=filter, limit=limit)
accounts_labels = []
for _account in accounts:
accounts_labels += [_account.user_jid + " (" + _account.name
+ " " + str(_account.__class__.__name__) + ")"]
result_form.fields.append(FieldNoType(name="registeredusers",
label="TODO",
values=accounts_labels))
result_form.as_xml(command_node)
command_node.setProp("status", STATUS_COMPLETED)
return (result_form, [])
def execute_get_registered_users_list_1(self, info_query, session_context,
command_node, lang_class):
num_accounts = account.get_all_accounts_count()
if num_accounts < 25:
return self.add_form_list_accounts(command_node, lang_class)
else:
self.add_actions(command_node, [ACTION_NEXT])
result_form = Form(xmlnode_or_type="result")
result_form.add_field(field_type="hidden",
name="FORM_TYPE",
value="http://jabber.org/protocol/admin")
max_items_field = result_form.add_field(name="max_items",
field_type="list-single",
label="TODO")
for value in ["25", "50", "75", "100", "150", "200"]:
max_items_field.add_option(label=value,
values=[value])
result_form.as_xml(command_node)
return (result_form, [])
return [] return []
def execute_get_idle_users_num(self, info_query): def execute_get_registered_users_list_2(self, info_query, session_context,
return [] command_node, lang_class):
limit = int(session_context["max_items"][0])
def execute_get_registered_users_list(self, info_query): return self.add_form_list_accounts(command_node, lang_class,
return [] limit=limit)
def execute_get_disabled_users_list(self, info_query): def execute_get_disabled_users_list(self, info_query):
return [] return []

View File

@@ -1635,32 +1635,164 @@ class JCLCommandManager_TestCase(JCLTestCase):
self.assertEquals(fields[1].children.name, "value") self.assertEquals(fields[1].children.name, "value")
self.assertEquals(fields[1].children.content, "3") self.assertEquals(fields[1].children.content, "3")
# def test_execute_get_active_users_num(self): def test_execute_get_registered_users_list(self):
# #TODO : implement command self.comp.account_manager.account_classes = (ExampleAccount,
# info_query = Iq(stanza_type="set", Example2Account)
# from_jid="user1@test.com", model.db_connect()
# to_jid="jcl.test.com") account11 = ExampleAccount(user_jid="test1@test.com",
# result = self.command_manager.execute_add_user(info_query) name="account11",
# self.assertNotEquals(result, None) jid="account11@jcl.test.com")
# self.assertEquals(len(result), 1) account12 = Example2Account(user_jid="test1@test.com",
name="account12",
jid="account12@jcl.test.com")
account21 = ExampleAccount(user_jid="test2@test.com",
name="account21",
jid="account21@jcl.test.com")
account22 = ExampleAccount(user_jid="test2@test.com",
name="account11",
jid="account11@jcl.test.com")
model.db_disconnect()
info_query = Iq(stanza_type="set",
from_jid="user1@test.com",
to_jid="jcl.test.com")
command_node = info_query.set_new_content(command.COMMAND_NS, "command")
command_node.setProp("node", "http://jabber.org/protocol/admin#get-registered-users-list")
result = self.command_manager.apply_command_action(info_query,
"http://jabber.org/protocol/admin#get-registered-users-list",
"execute")
self.assertNotEquals(result, None)
self.assertEquals(len(result), 1)
xml_command = result[0].xpath_eval("c:command",
{"c": "http://jabber.org/protocol/commands"})[0]
self.assertEquals(xml_command.prop("status"), "completed")
self.assertNotEquals(xml_command.prop("sessionid"), None)
self.__check_actions(result[0])
fields = result[0].xpath_eval("c:command/data:x/data:field",
{"c": "http://jabber.org/protocol/commands",
"data": "jabber:x:data"})
self.assertEquals(len(fields), 2)
self.assertEquals(fields[1].prop("var"), "registeredusers")
values = result[0].xpath_eval("c:command/data:x/data:field[2]/data:value",
{"c": "http://jabber.org/protocol/commands",
"data": "jabber:x:data"})
self.assertEquals(len(values), 4)
self.assertEquals(values[0].content,
"test1@test.com (account11 ExampleAccount)")
self.assertEquals(values[1].content,
"test1@test.com (account12 Example2Account)")
self.assertEquals(values[2].content,
"test2@test.com (account21 ExampleAccount)")
self.assertEquals(values[3].content,
"test2@test.com (account11 ExampleAccount)")
# def test_execute_get_idle_users_num(self): def test_execute_get_registered_users_list_max(self):
# #TODO : implement command self.comp.account_manager.account_classes = (ExampleAccount,
# info_query = Iq(stanza_type="set", Example2Account)
# from_jid="user1@test.com", model.db_connect()
# to_jid="jcl.test.com") for i in xrange(10):
# result = self.command_manager.execute_add_user(info_query) ExampleAccount(user_jid="test1@test.com",
# self.assertNotEquals(result, None) name="account11" + str(i),
# self.assertEquals(len(result), 1) jid="account11" + str(i) + "@jcl.test.com")
Example2Account(user_jid="test1@test.com",
name="account12" + str(i),
jid="account12" + str(i) + "@jcl.test.com")
ExampleAccount(user_jid="test2@test.com",
name="account2" + str(i),
jid="account2" + str(i) + "@jcl.test.com")
model.db_disconnect()
info_query = Iq(stanza_type="set",
from_jid="user1@test.com",
to_jid="jcl.test.com")
command_node = info_query.set_new_content(command.COMMAND_NS, "command")
command_node.setProp("node", "http://jabber.org/protocol/admin#get-registered-users-list")
result = self.command_manager.apply_command_action(info_query,
"http://jabber.org/protocol/admin#get-registered-users-list",
"execute")
self.assertNotEquals(result, None)
self.assertEquals(len(result), 1)
xml_command = result[0].xpath_eval("c:command",
{"c": "http://jabber.org/protocol/commands"})[0]
self.assertEquals(xml_command.prop("status"), "executing")
self.assertNotEquals(xml_command.prop("sessionid"), None)
self.__check_actions(result[0], ["next"])
fields = result[0].xpath_eval("c:command/data:x/data:field",
{"c": "http://jabber.org/protocol/commands",
"data": "jabber:x:data"})
self.assertEquals(len(fields), 2)
self.assertEquals(fields[1].prop("var"), "max_items")
self.assertEquals(fields[1].prop("type"), "list-single")
options = result[0].xpath_eval("c:command/data:x/data:field[2]/data:option",
{"c": "http://jabber.org/protocol/commands",
"data": "jabber:x:data"})
self.assertEquals(len(options), 6)
self.assertEquals(options[0].prop("label"), "25")
self.assertEquals(options[0].content, "25")
self.assertEquals(options[1].prop("label"), "50")
self.assertEquals(options[1].content, "50")
self.assertEquals(options[2].prop("label"), "75")
self.assertEquals(options[2].content, "75")
self.assertEquals(options[3].prop("label"), "100")
self.assertEquals(options[3].content, "100")
self.assertEquals(options[4].prop("label"), "150")
self.assertEquals(options[4].content, "150")
self.assertEquals(options[5].prop("label"), "200")
self.assertEquals(options[5].content, "200")
# def test_execute_get_registered_users_list(self): # Second step
# #TODO : implement command info_query = Iq(stanza_type="set",
# info_query = Iq(stanza_type="set", from_jid="user1@test.com",
# from_jid="user1@test.com", to_jid="jcl.test.com")
# to_jid="jcl.test.com") command_node = info_query.set_new_content(command.COMMAND_NS, "command")
# result = self.command_manager.execute_add_user(info_query) command_node.setProp("node",
# self.assertNotEquals(result, None) "http://jabber.org/protocol/admin#get-registered-users-list")
# self.assertEquals(len(result), 1) session_id = xml_command.prop("sessionid")
command_node.setProp("sessionid", session_id)
command_node.setProp("action", "next")
submit_form = Form(xmlnode_or_type="submit")
submit_form.add_field(field_type="list-single",
name="max_items",
value="25")
submit_form.as_xml(command_node)
result = self.command_manager.apply_command_action(\
info_query,
"http://jabber.org/protocol/admin#get-registered-users-list",
"execute")
self.assertNotEquals(result, None)
self.assertEquals(len(result), 1)
xml_command = result[0].xpath_eval("c:command",
{"c": "http://jabber.org/protocol/commands"})[0]
self.assertEquals(xml_command.prop("status"), "completed")
self.assertEquals(xml_command.prop("sessionid"), session_id)
self.__check_actions(result[0])
context_session = self.command_manager.sessions[session_id][1]
self.assertEquals(context_session["max_items"],
["25"])
fields = result[0].xpath_eval("c:command/data:x/data:field",
{"c": "http://jabber.org/protocol/commands",
"data": "jabber:x:data"})
self.assertEquals(len(fields), 2)
self.assertEquals(fields[0].prop("var"), "FORM_TYPE")
self.assertEquals(fields[0].prop("type"), "hidden")
self.assertEquals(fields[0].children.name, "value")
self.assertEquals(fields[0].children.content,
"http://jabber.org/protocol/admin")
self.assertEquals(fields[1].prop("var"), "registeredusers")
values = result[0].xpath_eval("c:command/data:x/data:field[2]/data:value",
{"c": "http://jabber.org/protocol/commands",
"data": "jabber:x:data"})
self.assertEquals(len(values), 25)
while i < 7:
self.assertEquals(values[i * 3].content,
"test1@test.com (account11" + str(i)
+ " ExampleAccount)")
self.assertEquals(values[i * 3 + 1].content,
"test1@test.com (account12" + str(i)
+ " Example2Account)")
self.assertEquals(values[i * 3 + 2].content,
"test2@test.com (account2" + str(i)
+ " ExampleAccount)")
self.assertEquals(values[24].content,
"test1@test.com (account118 ExampleAccount)")
# def test_execute_get_disabled_users_list(self): # def test_execute_get_disabled_users_list(self):
# #TODO : implement command # #TODO : implement command

View File

@@ -737,7 +737,7 @@ class JCLComponent_TestCase(JCLTestCase):
to_jid="jcl.test.com") to_jid="jcl.test.com")
disco_items = self.comp.disco_get_items("http://jabber.org/protocol/commands", disco_items = self.comp.disco_get_items("http://jabber.org/protocol/commands",
info_query) info_query)
self.assertEquals(len(disco_items.get_items()), 29) self.assertEquals(len(disco_items.get_items()), 25)
item = disco_items.get_items()[0] item = disco_items.get_items()[0]
self.assertEquals(item.get_node(), "list") self.assertEquals(item.get_node(), "list")
self.assertEquals(item.get_name(), Lang.en.command_list) self.assertEquals(item.get_name(), Lang.en.command_list)

View File

@@ -170,12 +170,9 @@ def get_accounts(bare_user_jid, account_class=Account, filter=None):
yield _account yield _account
model.db_disconnect() model.db_disconnect()
def get_all_accounts(account_class=Account): def get_all_accounts(account_class=Account, filter=None, limit=None):
model.db_connect() model.db_connect()
accounts = account_class.select() accounts = account_class.select(clause=filter, limit=limit)
if accounts.count() == 0:
model.db_disconnect()
return
for _account in accounts: for _account in accounts:
yield _account yield _account
model.db_disconnect() model.db_disconnect()