about summary refs log tree commit diff stats
path: root/src
diff options
context:
space:
mode:
authorJames Booth <boothj5@gmail.com>2014-10-04 23:40:36 +0100
committerJames Booth <boothj5@gmail.com>2014-10-04 23:40:36 +0100
commit0b78a9a57e3d1a39cd2826c073eb69d6954ad32b (patch)
tree228244d26c59816f888993c17966f9cb4faac643 /src
parent719dbfaacc79fe56da8dcf1d9c9711c0de26f2bf (diff)
downloadprofani-tty-0b78a9a57e3d1a39cd2826c073eb69d6954ad32b.tar.gz
Implemented setting affiliation and listing affiliations
Diffstat (limited to 'src')
-rw-r--r--src/command/command.c9
-rw-r--r--src/command/commands.c85
-rw-r--r--src/xmpp/iq.c13
-rw-r--r--src/xmpp/stanza.c30
-rw-r--r--src/xmpp/stanza.h8
-rw-r--r--src/xmpp/xmpp.h5
6 files changed, 60 insertions, 90 deletions
diff --git a/src/command/command.c b/src/command/command.c
index 7748b1f6..868facea 100644
--- a/src/command/command.c
+++ b/src/command/command.c
@@ -1246,13 +1246,8 @@ cmd_init(void)
     autocomplete_add(room_ac, "destroy");
     autocomplete_add(room_ac, "config");
     autocomplete_add(room_ac, "info");
-    autocomplete_add(room_ac, "moderators");
-    autocomplete_add(room_ac, "participants");
-    autocomplete_add(room_ac, "visitors");
-    autocomplete_add(room_ac, "owners");
-    autocomplete_add(room_ac, "admins");
-    autocomplete_add(room_ac, "members");
-    autocomplete_add(room_ac, "outcasts");
+    autocomplete_add(room_ac, "role");
+    autocomplete_add(room_ac, "affiliation");
 
     form_ac = autocomplete_new();
     autocomplete_add(form_ac, "submit");
diff --git a/src/command/commands.c b/src/command/commands.c
index 6f962ce2..1ba8af72 100644
--- a/src/command/commands.c
+++ b/src/command/commands.c
@@ -2126,18 +2126,8 @@ cmd_room(gchar **args, struct cmd_help_t help)
     if ((g_strcmp0(args[0], "accept") != 0) &&
             (g_strcmp0(args[0], "destroy") != 0) &&
             (g_strcmp0(args[0], "config") != 0) &&
-
-            // roles
-            (g_strcmp0(args[0], "moderators") != 0) &&
-            (g_strcmp0(args[0], "participants") != 0) &&
-            (g_strcmp0(args[0], "visitors") != 0) &&
-
-            // affiliations
-            (g_strcmp0(args[0], "owners") != 0) &&
-            (g_strcmp0(args[0], "admins") != 0) &&
-            (g_strcmp0(args[0], "members") != 0) &&
-            (g_strcmp0(args[0], "outcasts") != 0) &&
-
+            (g_strcmp0(args[0], "role") != 0) &&
+            (g_strcmp0(args[0], "affiliation") != 0) &&
             (g_strcmp0(args[0], "info") != 0)) {
         cons_show("Usage: %s", help.usage);
         return TRUE;
@@ -2158,48 +2148,45 @@ cmd_room(gchar **args, struct cmd_help_t help)
         return TRUE;
     }
 
-    if (g_strcmp0(args[0], "owners") == 0) {
-        if ((g_strcmp0(args[1], "add") == 0) || (g_strcmp0(args[1], "remove") == 0)) {
-            char *nick = args[2];
-            if (!nick) {
+    if (g_strcmp0(args[0], "affiliation") == 0) {
+        char *cmd = args[1];
+        if (cmd == NULL) {
+            cons_show("Usage: %s", help.usage);
+            return TRUE;
+        }
+
+        char *affiliation = args[2];
+        if ((g_strcmp0(affiliation, "owner") != 0) &&
+                (g_strcmp0(affiliation, "admin") != 0) &&
+                (g_strcmp0(affiliation, "member") != 0) &&
+                (g_strcmp0(affiliation, "outcast") != 0) &&
+                (g_strcmp0(affiliation, "none") != 0)) {
+            cons_show("Usage: %s", help.usage);
+            return TRUE;
+        }
+
+        if (g_strcmp0(cmd, "list") == 0) {
+            iq_room_affiliation_list(room, affiliation);
+            return TRUE;
+        }
+
+        if (g_strcmp0(cmd, "set") == 0) {
+            char *jid = args[3];
+            if (jid == NULL) {
                 cons_show("Usage: %s", help.usage);
                 return TRUE;
-            }
-            Occupant *occupant = muc_roster_item(room, nick);
-            if (!occupant) {
-                win_save_vprint(window, '!', NULL, 0, 0, "", "Could not find occupant: ", nick);
-                return TRUE;
-            }
-            if (!occupant->jid) {
-                win_save_vprint(window, '!', NULL, 0, 0, "", "Could not find JID for occupant: ", nick);
-                return TRUE;
-            }
-            Jid *jidp = jid_create(occupant->jid);
-            if (!jidp->barejid) {
-                win_save_vprint(window, '!', NULL, 0, 0, "", "Could not find bare JID for occupant:", nick);
-                jid_destroy(jidp);
-                return TRUE;
-            }
-
-            char *reason = args[3];
-            if (g_strcmp0(args[1], "add") == 0) {
-                if (occupant->affiliation == MUC_AFFILIATION_OWNER) {
-                    win_save_vprint(window, '!', NULL, 0, 0, "", "%s already has owner affiliation", nick);
-                } else {
-                    iq_room_owner_add(room, jidp->barejid, reason);
-                }
             } else {
-                if (occupant->affiliation != MUC_AFFILIATION_OWNER) {
-                    const char *affiliation_str = muc_occupant_affiliation_str(occupant);
-                    win_save_vprint(window, '!', NULL, 0, 0, "",
-                        "%s does not have owner affiliation, current affiliation:", nick, affiliation_str);
-                } else {
-                    iq_room_owner_remove(room, jidp->barejid, reason);
-                }
+                char *reason = args[4];
+                iq_room_affiliation_set(room, jid, affiliation, reason);
+                return TRUE;
             }
-            jid_destroy(jidp);
-            return TRUE;
         }
+
+        return TRUE;
+    }
+
+    if (g_strcmp0(args[0], "role") == 0) {
+        cons_show("/room role...");
         return TRUE;
     }
 
diff --git a/src/xmpp/iq.c b/src/xmpp/iq.c
index 4e5a757b..d960761a 100644
--- a/src/xmpp/iq.c
+++ b/src/xmpp/iq.c
@@ -276,21 +276,22 @@ _iq_room_config_cancel(const char * const room_jid)
 }
 
 static void
-_iq_room_owner_add(const char * const room, const char * const jid, const char * const reason)
+_iq_room_affiliation_list(const char * const room, const char * const affiliation)
 {
     xmpp_conn_t * const conn = connection_get_conn();
     xmpp_ctx_t * const ctx = connection_get_ctx();
-    xmpp_stanza_t *iq = stanza_create_room_owner_add_iq(ctx, room, jid, reason);
+    xmpp_stanza_t *iq = stanza_create_room_affiliation_list_iq(ctx, room, affiliation);
     xmpp_send(conn, iq);
     xmpp_stanza_release(iq);
 }
 
 static void
-_iq_room_owner_remove(const char * const room, const char * const jid, const char * const reason)
+_iq_room_affiliation_set(const char * const room, const char * const jid, const char * const affiliation,
+    const char * const reason)
 {
     xmpp_conn_t * const conn = connection_get_conn();
     xmpp_ctx_t * const ctx = connection_get_ctx();
-    xmpp_stanza_t *iq = stanza_create_room_owner_remove_iq(ctx, room, jid, reason);
+    xmpp_stanza_t *iq = stanza_create_room_affiliation_set_iq(ctx, room, jid, affiliation, reason);
     xmpp_send(conn, iq);
     xmpp_stanza_release(iq);
 }
@@ -997,6 +998,6 @@ iq_init_module(void)
     iq_submit_room_config = _iq_submit_room_config;
     iq_send_caps_request = _iq_send_caps_request;
     iq_room_info_request = _iq_room_info_request;
-    iq_room_owner_add = _iq_room_owner_add;
-    iq_room_owner_remove = _iq_room_owner_remove;
+    iq_room_affiliation_set = _iq_room_affiliation_set;
+    iq_room_affiliation_list = _iq_room_affiliation_list;
 }
diff --git a/src/xmpp/stanza.c b/src/xmpp/stanza.c
index 4e2c829d..e17ed86e 100644
--- a/src/xmpp/stanza.c
+++ b/src/xmpp/stanza.c
@@ -529,14 +529,13 @@ stanza_create_room_config_cancel_iq(xmpp_ctx_t *ctx, const char * const room_jid
 }
 
 xmpp_stanza_t *
-stanza_create_room_owner_add_iq(xmpp_ctx_t *ctx, const char * const room, const char * const jid,
-    const char * const reason)
+stanza_create_room_affiliation_list_iq(xmpp_ctx_t *ctx, const char * const room, const char * const affiliation)
 {
     xmpp_stanza_t *iq = xmpp_stanza_new(ctx);
     xmpp_stanza_set_name(iq, STANZA_NAME_IQ);
-    xmpp_stanza_set_type(iq, STANZA_TYPE_SET);
+    xmpp_stanza_set_type(iq, STANZA_TYPE_GET);
     xmpp_stanza_set_attribute(iq, STANZA_ATTR_TO, room);
-    char *id = create_unique_id("owner_add");
+    char *id = create_unique_id("affiliation_get");
     xmpp_stanza_set_id(iq, id);
     free(id);
 
@@ -546,20 +545,7 @@ stanza_create_room_owner_add_iq(xmpp_ctx_t *ctx, const char * const room, const
 
     xmpp_stanza_t *item = xmpp_stanza_new(ctx);
     xmpp_stanza_set_name(item, STANZA_NAME_ITEM);
-    xmpp_stanza_set_attribute(item, "affiliation", "owner");
-    xmpp_stanza_set_attribute(item, STANZA_ATTR_JID, jid);
-
-    if (reason) {
-        xmpp_stanza_t *reason_st = xmpp_stanza_new(ctx);
-        xmpp_stanza_set_name(reason_st, STANZA_NAME_REASON);
-        xmpp_stanza_t *reason_text = xmpp_stanza_new(ctx);
-        xmpp_stanza_set_text(reason_text, reason);
-        xmpp_stanza_add_child(reason_st, reason_text);
-        xmpp_stanza_release(reason_text);
-
-        xmpp_stanza_add_child(item, reason_st);
-        xmpp_stanza_release(reason_st);
-    }
+    xmpp_stanza_set_attribute(item, "affiliation", affiliation);
 
     xmpp_stanza_add_child(query, item);
     xmpp_stanza_release(item);
@@ -570,14 +556,14 @@ stanza_create_room_owner_add_iq(xmpp_ctx_t *ctx, const char * const room, const
 }
 
 xmpp_stanza_t *
-stanza_create_room_owner_remove_iq(xmpp_ctx_t *ctx, const char * const room, const char * const jid,
-    const char * const reason)
+stanza_create_room_affiliation_set_iq(xmpp_ctx_t *ctx, const char * const room, const char * const jid,
+    const char * const affiliation, const char * const reason)
 {
     xmpp_stanza_t *iq = xmpp_stanza_new(ctx);
     xmpp_stanza_set_name(iq, STANZA_NAME_IQ);
     xmpp_stanza_set_type(iq, STANZA_TYPE_SET);
     xmpp_stanza_set_attribute(iq, STANZA_ATTR_TO, room);
-    char *id = create_unique_id("owner_remove");
+    char *id = create_unique_id("affiliation_set");
     xmpp_stanza_set_id(iq, id);
     free(id);
 
@@ -587,7 +573,7 @@ stanza_create_room_owner_remove_iq(xmpp_ctx_t *ctx, const char * const room, con
 
     xmpp_stanza_t *item = xmpp_stanza_new(ctx);
     xmpp_stanza_set_name(item, STANZA_NAME_ITEM);
-    xmpp_stanza_set_attribute(item, "affiliation", "admin");
+    xmpp_stanza_set_attribute(item, "affiliation", affiliation);
     xmpp_stanza_set_attribute(item, STANZA_ATTR_JID, jid);
 
     if (reason) {
diff --git a/src/xmpp/stanza.h b/src/xmpp/stanza.h
index d2e8c2cf..cf2dc482 100644
--- a/src/xmpp/stanza.h
+++ b/src/xmpp/stanza.h
@@ -205,10 +205,10 @@ xmpp_stanza_t* stanza_create_room_config_cancel_iq(xmpp_ctx_t *ctx,
     const char * const room_jid);
 xmpp_stanza_t* stanza_create_room_config_submit_iq(xmpp_ctx_t *ctx,
     const char * const room, DataForm *form);
-xmpp_stanza_t* stanza_create_room_owner_add_iq(xmpp_ctx_t *ctx, const char * const room, const char * const jid,
-    const char * const reason);
-xmpp_stanza_t* stanza_create_room_owner_remove_iq(xmpp_ctx_t *ctx, const char * const room, const char * const jid,
-    const char * const reason);
+xmpp_stanza_t* stanza_create_room_affiliation_list_iq(xmpp_ctx_t *ctx, const char * const room,
+    const char * const affiliation);
+xmpp_stanza_t* stanza_create_room_affiliation_set_iq(xmpp_ctx_t *ctx, const char * const room, const char * const jid,
+    const char * const affiliation, const char * const reason);
 
 int stanza_get_idle_time(xmpp_stanza_t * const stanza);
 char * stanza_get_caps_str(xmpp_stanza_t * const stanza);
diff --git a/src/xmpp/xmpp.h b/src/xmpp/xmpp.h
index 176e7a7b..3e0c38db 100644
--- a/src/xmpp/xmpp.h
+++ b/src/xmpp/xmpp.h
@@ -192,8 +192,9 @@ void (*iq_send_ping)(const char * const target);
 void (*iq_send_caps_request)(const char * const to, const char * const id,
     const char * const node, const char * const ver);
 void (*iq_room_info_request)(gchar *room);
-void (*iq_room_owner_add)(const char * const room, const char * const jid, const char * const reason);
-void (*iq_room_owner_remove)(const char * const room, const char * const jid, const char * const reason);
+void (*iq_room_affiliation_list)(const char * const room, const char * const affiliation);
+void (*iq_room_affiliation_set)(const char * const room, const char * const jid, const char * const affiliation,
+    const char * const reason);
 
 // caps functions
 Capabilities* (*caps_lookup)(const char * const jid);