1
1
mirror of https://github.com/profanity-im/profanity.git synced 2025-01-03 14:57:42 -05:00

Added validation to /role and /affiliation

This commit is contained in:
James Booth 2014-10-12 01:32:15 +01:00
parent 77684cda00
commit da373e9097
2 changed files with 34 additions and 29 deletions

View File

@ -311,14 +311,13 @@ static struct cmd_t command_defs[] =
NULL } } }, NULL } } },
{ "/room", { "/room",
cmd_room, parse_args_with_freetext, 1, 5, NULL, cmd_room, parse_args, 1, 1, NULL,
{ "/room accept|destroy|config|info", "Room configuration.", { "/room accept|destroy|config", "Room configuration.",
{ "/room accept|destroy|config|info", { "/room accept|destroy|config",
"--------------------------------", "---------------------------",
"accept - Accept default room configuration.", "accept - Accept default room configuration.",
"destroy - Reject default room configuration.", "destroy - Reject default room configuration.",
"config - Edit room configuration.", "config - Edit room configuration.",
"info - Show room details.",
NULL } } }, NULL } } },
{ "/kick", { "/kick",
@ -331,7 +330,7 @@ static struct cmd_t command_defs[] =
NULL } } }, NULL } } },
{ "/ban", { "/ban",
cmd_ban, parse_args, 1, 2, NULL, cmd_ban, parse_args_with_freetext, 1, 2, NULL,
{ "/ban jid [reason]", "Ban users from chat rooms.", { "/ban jid [reason]", "Ban users from chat rooms.",
{ "/ban jid [reason]", { "/ban jid [reason]",
"-----------------", "-----------------",

View File

@ -2244,18 +2244,9 @@ cmd_affiliation(gchar **args, struct cmd_help_t help)
return TRUE; return TRUE;
} }
char *room = ui_current_recipient();
char *affiliation = args[1]; char *affiliation = args[1];
if (!affiliation) { if ((affiliation != NULL) &&
iq_room_affiliation_list(room, "owner"); (g_strcmp0(affiliation, "owner") != 0) &&
iq_room_affiliation_list(room, "admin");
iq_room_affiliation_list(room, "member");
iq_room_affiliation_list(room, "outcast");
return TRUE;
}
if ((g_strcmp0(affiliation, "owner") != 0) &&
(g_strcmp0(affiliation, "admin") != 0) && (g_strcmp0(affiliation, "admin") != 0) &&
(g_strcmp0(affiliation, "member") != 0) && (g_strcmp0(affiliation, "member") != 0) &&
(g_strcmp0(affiliation, "none") != 0) && (g_strcmp0(affiliation, "none") != 0) &&
@ -2264,10 +2255,16 @@ cmd_affiliation(gchar **args, struct cmd_help_t help)
return TRUE; return TRUE;
} }
char *room = ui_current_recipient();
ProfWin *window = wins_get_by_recipient(room); ProfWin *window = wins_get_by_recipient(room);
if (g_strcmp0(cmd, "list") == 0) { if (g_strcmp0(cmd, "list") == 0) {
if (g_strcmp0(affiliation, "none") == 0) { if (!affiliation) {
iq_room_affiliation_list(room, "owner");
iq_room_affiliation_list(room, "admin");
iq_room_affiliation_list(room, "member");
iq_room_affiliation_list(room, "outcast");
} else if (g_strcmp0(affiliation, "none") == 0) {
win_save_print(window, '!', NULL, 0, 0, "", "Cannot list users with no affiliation."); win_save_print(window, '!', NULL, 0, 0, "", "Cannot list users with no affiliation.");
} else { } else {
iq_room_affiliation_list(room, affiliation); iq_room_affiliation_list(room, affiliation);
@ -2276,6 +2273,11 @@ cmd_affiliation(gchar **args, struct cmd_help_t help)
} }
if (g_strcmp0(cmd, "set") == 0) { if (g_strcmp0(cmd, "set") == 0) {
if (!affiliation) {
cons_show("Usage: %s", help.usage);
return TRUE;
}
char *jid = args[2]; char *jid = args[2];
if (jid == NULL) { if (jid == NULL) {
cons_show("Usage: %s", help.usage); cons_show("Usage: %s", help.usage);
@ -2287,6 +2289,7 @@ cmd_affiliation(gchar **args, struct cmd_help_t help)
} }
} }
cons_show("Usage: %s", help.usage);
return TRUE; return TRUE;
} }
@ -2312,17 +2315,9 @@ cmd_role(gchar **args, struct cmd_help_t help)
return TRUE; return TRUE;
} }
char *room = ui_current_recipient();
char *role = args[1]; char *role = args[1];
if (!role) { if ((role != NULL ) &&
iq_room_role_list(room, "moderator"); (g_strcmp0(role, "visitor") != 0) &&
iq_room_role_list(room, "participant");
iq_room_role_list(room, "visitor");
return TRUE;
}
if ((g_strcmp0(role, "visitor") != 0) &&
(g_strcmp0(role, "participant") != 0) && (g_strcmp0(role, "participant") != 0) &&
(g_strcmp0(role, "moderator") != 0) && (g_strcmp0(role, "moderator") != 0) &&
(g_strcmp0(role, "none") != 0)) { (g_strcmp0(role, "none") != 0)) {
@ -2330,10 +2325,15 @@ cmd_role(gchar **args, struct cmd_help_t help)
return TRUE; return TRUE;
} }
char *room = ui_current_recipient();
ProfWin *window = wins_get_by_recipient(room); ProfWin *window = wins_get_by_recipient(room);
if (g_strcmp0(cmd, "list") == 0) { if (g_strcmp0(cmd, "list") == 0) {
if (g_strcmp0(role, "none") == 0) { if (!role) {
iq_room_role_list(room, "moderator");
iq_room_role_list(room, "participant");
iq_room_role_list(room, "visitor");
} else if (g_strcmp0(role, "none") == 0) {
win_save_print(window, '!', NULL, 0, 0, "", "Cannot list users with no role."); win_save_print(window, '!', NULL, 0, 0, "", "Cannot list users with no role.");
} else { } else {
iq_room_role_list(room, role); iq_room_role_list(room, role);
@ -2342,6 +2342,11 @@ cmd_role(gchar **args, struct cmd_help_t help)
} }
if (g_strcmp0(cmd, "set") == 0) { if (g_strcmp0(cmd, "set") == 0) {
if (!role) {
cons_show("Usage: %s", help.usage);
return TRUE;
}
char *nick = args[2]; char *nick = args[2];
if (nick == NULL) { if (nick == NULL) {
cons_show("Usage: %s", help.usage); cons_show("Usage: %s", help.usage);
@ -2353,6 +2358,7 @@ cmd_role(gchar **args, struct cmd_help_t help)
} }
} }
cons_show("Usage: %s", help.usage);
return TRUE; return TRUE;
} }