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:
parent
77684cda00
commit
da373e9097
@ -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]",
|
||||||
"-----------------",
|
"-----------------",
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user