about summary refs log tree commit diff stats
diff options
context:
space:
mode:
authorJames Booth <boothj5@gmail.com>2016-08-14 00:07:08 +0100
committerJames Booth <boothj5@gmail.com>2016-08-14 00:07:08 +0100
commitd5f14abd4e7dfe194b33c452da72cf8de3020b82 (patch)
tree79187a4f316729a8cecaf50ff5ee82085023c901
parent9c4e02db77fd3333c038c46ffa7a40ed9e33b949 (diff)
downloadprofani-tty-d5f14abd4e7dfe194b33c452da72cf8de3020b82.tar.gz
Move caps_create_sha1_str -> stanza_create_caps_sha1_from_query
-rw-r--r--src/xmpp/capabilities.c143
-rw-r--r--src/xmpp/capabilities.h1
-rw-r--r--src/xmpp/iq.c2
-rw-r--r--src/xmpp/stanza.c101
-rw-r--r--src/xmpp/stanza.h1
5 files changed, 124 insertions, 124 deletions
diff --git a/src/xmpp/capabilities.c b/src/xmpp/capabilities.c
index d64c79a0..1c6fc37d 100644
--- a/src/xmpp/capabilities.c
+++ b/src/xmpp/capabilities.c
@@ -228,138 +228,37 @@ _caps_copy(EntityCapabilities *caps)
 {
     if (!caps) {
         return NULL;
-    } else {
-        EntityCapabilities *result = (EntityCapabilities *)malloc(sizeof(EntityCapabilities));
-
-        if (caps->identity) {
-            DiscoIdentity *identity = (DiscoIdentity*)malloc(sizeof(DiscoIdentity));
-            identity->category = caps->identity->category ? strdup(caps->identity->category) : NULL;
-            identity->type = caps->identity->type ? strdup(caps->identity->type) : NULL;
-            identity->name = caps->identity->name ? strdup(caps->identity->name) : NULL;
-            result->identity = identity;
-        } else {
-            result->identity = NULL;
-        }
-
-        if (caps->software_version) {
-            SoftwareVersion *software_version = (SoftwareVersion*)malloc(sizeof(SoftwareVersion));
-            software_version->software = caps->software_version->software ? strdup(caps->software_version->software) : NULL;
-            software_version->software_version = caps->software_version->software_version ? strdup(caps->software_version->software_version) : NULL;
-            software_version->os = caps->software_version->os ? strdup(caps->software_version->os) : NULL;
-            software_version->os_version = caps->software_version->os_version ? strdup(caps->software_version->os_version) : NULL;
-        } else {
-            result->software_version = NULL;
-        }
-
-        result->features = NULL;
-        GSList *curr = caps->features;
-        while (curr) {
-            result->features = g_slist_append(result->features, strdup(curr->data));
-            curr = g_slist_next(curr);
-        }
-
-        return result;
-    }
-}
-
-char*
-caps_create_sha1_str(xmpp_stanza_t *const query)
-{
-    GSList *identities = NULL;
-    GSList *features = NULL;
-    GSList *form_names = NULL;
-    GHashTable *forms = g_hash_table_new_full(g_str_hash, g_str_equal, g_free, (GDestroyNotify)form_destroy);
-
-    xmpp_stanza_t *child = xmpp_stanza_get_children(query);
-    while (child) {
-        if (g_strcmp0(xmpp_stanza_get_name(child), STANZA_NAME_IDENTITY) == 0) {
-            const char *category = xmpp_stanza_get_attribute(child, "category");
-            const char *type = xmpp_stanza_get_attribute(child, "type");
-            const char *lang = xmpp_stanza_get_attribute(child, "xml:lang");
-            const char *name = xmpp_stanza_get_attribute(child, "name");
-
-            GString *identity_str = g_string_new(category);
-            g_string_append(identity_str, "/");
-            if (type) {
-                g_string_append(identity_str, type);
-            }
-            g_string_append(identity_str, "/");
-            if (lang) {
-                g_string_append(identity_str, lang);
-            }
-            g_string_append(identity_str, "/");
-            if (name) {
-                g_string_append(identity_str, name);
-            }
-            g_string_append(identity_str, "<");
-            identities = g_slist_insert_sorted(identities, g_strdup(identity_str->str), (GCompareFunc)strcmp);
-            g_string_free(identity_str, TRUE);
-        } else if (g_strcmp0(xmpp_stanza_get_name(child), STANZA_NAME_FEATURE) == 0) {
-            const char *feature_str = xmpp_stanza_get_attribute(child, "var");
-            features = g_slist_insert_sorted(features, g_strdup(feature_str), (GCompareFunc)strcmp);
-        } else if (g_strcmp0(xmpp_stanza_get_name(child), STANZA_NAME_X) == 0) {
-            if (g_strcmp0(xmpp_stanza_get_ns(child), STANZA_NS_DATA) == 0) {
-                DataForm *form = form_create(child);
-                char *form_type = form_get_form_type_field(form);
-                form_names = g_slist_insert_sorted(form_names, g_strdup(form_type), (GCompareFunc)strcmp);
-                g_hash_table_insert(forms, g_strdup(form_type), form);
-            }
-        }
-        child = xmpp_stanza_get_next(child);
     }
 
-    GString *s = g_string_new("");
+    EntityCapabilities *result = (EntityCapabilities *)malloc(sizeof(EntityCapabilities));
 
-    GSList *curr = identities;
-    while (curr) {
-        g_string_append(s, curr->data);
-        curr = g_slist_next(curr);
+    if (caps->identity) {
+        DiscoIdentity *identity = (DiscoIdentity*)malloc(sizeof(DiscoIdentity));
+        identity->category = caps->identity->category ? strdup(caps->identity->category) : NULL;
+        identity->type = caps->identity->type ? strdup(caps->identity->type) : NULL;
+        identity->name = caps->identity->name ? strdup(caps->identity->name) : NULL;
+        result->identity = identity;
+    } else {
+        result->identity = NULL;
     }
 
-    curr = features;
-    while (curr) {
-        g_string_append(s, curr->data);
-        g_string_append(s, "<");
-        curr = g_slist_next(curr);
+    if (caps->software_version) {
+        SoftwareVersion *software_version = (SoftwareVersion*)malloc(sizeof(SoftwareVersion));
+        software_version->software = caps->software_version->software ? strdup(caps->software_version->software) : NULL;
+        software_version->software_version = caps->software_version->software_version ? strdup(caps->software_version->software_version) : NULL;
+        software_version->os = caps->software_version->os ? strdup(caps->software_version->os) : NULL;
+        software_version->os_version = caps->software_version->os_version ? strdup(caps->software_version->os_version) : NULL;
+    } else {
+        result->software_version = NULL;
     }
 
-    curr = form_names;
+    result->features = NULL;
+    GSList *curr = caps->features;
     while (curr) {
-        DataForm *form = g_hash_table_lookup(forms, curr->data);
-        char *form_type = form_get_form_type_field(form);
-        g_string_append(s, form_type);
-        g_string_append(s, "<");
-
-        GSList *sorted_fields = form_get_non_form_type_fields_sorted(form);
-        GSList *curr_field = sorted_fields;
-        while (curr_field) {
-            FormField *field = curr_field->data;
-            g_string_append(s, field->var);
-            g_string_append(s, "<");
-
-            GSList *sorted_values = form_get_field_values_sorted(field);
-            GSList *curr_value = sorted_values;
-            while (curr_value) {
-                g_string_append(s, curr_value->data);
-                g_string_append(s, "<");
-                curr_value = g_slist_next(curr_value);
-            }
-            g_slist_free(sorted_values);
-            curr_field = g_slist_next(curr_field);
-        }
-        g_slist_free(sorted_fields);
-
+        result->features = g_slist_append(result->features, strdup(curr->data));
         curr = g_slist_next(curr);
     }
 
-    char *result = p_sha1_hash(s->str);
-
-    g_string_free(s, TRUE);
-    g_slist_free_full(identities, g_free);
-    g_slist_free_full(features, g_free);
-    g_slist_free_full(form_names, g_free);
-    g_hash_table_destroy(forms);
-
     return result;
 }
 
@@ -503,7 +402,7 @@ caps_get_my_sha1(xmpp_ctx_t *const ctx)
 {
     if (my_sha1 == NULL) {
         xmpp_stanza_t *query = stanza_create_caps_query_element(ctx);
-        my_sha1 = caps_create_sha1_str(query);
+        my_sha1 = stanza_create_caps_sha1_from_query(query);
         xmpp_stanza_release(query);
     }
 
diff --git a/src/xmpp/capabilities.h b/src/xmpp/capabilities.h
index 675022d2..ecf586b6 100644
--- a/src/xmpp/capabilities.h
+++ b/src/xmpp/capabilities.h
@@ -56,7 +56,6 @@ gboolean caps_cache_contains(const char *const ver);
 
 GList* caps_get_features(void);
 
-char* caps_create_sha1_str(xmpp_stanza_t *const query);
 EntityCapabilities* caps_create(xmpp_stanza_t *query);
 char* caps_get_my_sha1(xmpp_ctx_t *const ctx);
 
diff --git a/src/xmpp/iq.c b/src/xmpp/iq.c
index d4dbb7b6..dd811ed6 100644
--- a/src/xmpp/iq.c
+++ b/src/xmpp/iq.c
@@ -733,7 +733,7 @@ _caps_response_id_handler(xmpp_stanza_t *const stanza, void *const userdata)
     // validate sha1
     gchar **split = g_strsplit(node, "#", -1);
     char *given_sha1 = split[1];
-    char *generated_sha1 = caps_create_sha1_str(query);
+    char *generated_sha1 = stanza_create_caps_sha1_from_query(query);
 
     if (g_strcmp0(given_sha1, generated_sha1) != 0) {
         log_warning("Generated sha-1 does not match given:");
diff --git a/src/xmpp/stanza.c b/src/xmpp/stanza.c
index 0bbc99dd..fa7d9e52 100644
--- a/src/xmpp/stanza.c
+++ b/src/xmpp/stanza.c
@@ -1133,6 +1133,107 @@ stanza_create_ping_iq(xmpp_ctx_t *ctx, const char *const target)
     return iq;
 }
 
+char*
+stanza_create_caps_sha1_from_query(xmpp_stanza_t *const query)
+{
+    GSList *identities = NULL;
+    GSList *features = NULL;
+    GSList *form_names = NULL;
+    GHashTable *forms = g_hash_table_new_full(g_str_hash, g_str_equal, g_free, (GDestroyNotify)form_destroy);
+
+    xmpp_stanza_t *child = xmpp_stanza_get_children(query);
+    while (child) {
+        if (g_strcmp0(xmpp_stanza_get_name(child), STANZA_NAME_IDENTITY) == 0) {
+            const char *category = xmpp_stanza_get_attribute(child, "category");
+            const char *type = xmpp_stanza_get_attribute(child, "type");
+            const char *lang = xmpp_stanza_get_attribute(child, "xml:lang");
+            const char *name = xmpp_stanza_get_attribute(child, "name");
+
+            GString *identity_str = g_string_new(category);
+            g_string_append(identity_str, "/");
+            if (type) {
+                g_string_append(identity_str, type);
+            }
+            g_string_append(identity_str, "/");
+            if (lang) {
+                g_string_append(identity_str, lang);
+            }
+            g_string_append(identity_str, "/");
+            if (name) {
+                g_string_append(identity_str, name);
+            }
+            g_string_append(identity_str, "<");
+            identities = g_slist_insert_sorted(identities, g_strdup(identity_str->str), (GCompareFunc)strcmp);
+            g_string_free(identity_str, TRUE);
+        } else if (g_strcmp0(xmpp_stanza_get_name(child), STANZA_NAME_FEATURE) == 0) {
+            const char *feature_str = xmpp_stanza_get_attribute(child, "var");
+            features = g_slist_insert_sorted(features, g_strdup(feature_str), (GCompareFunc)strcmp);
+        } else if (g_strcmp0(xmpp_stanza_get_name(child), STANZA_NAME_X) == 0) {
+            if (g_strcmp0(xmpp_stanza_get_ns(child), STANZA_NS_DATA) == 0) {
+                DataForm *form = form_create(child);
+                char *form_type = form_get_form_type_field(form);
+                form_names = g_slist_insert_sorted(form_names, g_strdup(form_type), (GCompareFunc)strcmp);
+                g_hash_table_insert(forms, g_strdup(form_type), form);
+            }
+        }
+        child = xmpp_stanza_get_next(child);
+    }
+
+    GString *s = g_string_new("");
+
+    GSList *curr = identities;
+    while (curr) {
+        g_string_append(s, curr->data);
+        curr = g_slist_next(curr);
+    }
+
+    curr = features;
+    while (curr) {
+        g_string_append(s, curr->data);
+        g_string_append(s, "<");
+        curr = g_slist_next(curr);
+    }
+
+    curr = form_names;
+    while (curr) {
+        DataForm *form = g_hash_table_lookup(forms, curr->data);
+        char *form_type = form_get_form_type_field(form);
+        g_string_append(s, form_type);
+        g_string_append(s, "<");
+
+        GSList *sorted_fields = form_get_non_form_type_fields_sorted(form);
+        GSList *curr_field = sorted_fields;
+        while (curr_field) {
+            FormField *field = curr_field->data;
+            g_string_append(s, field->var);
+            g_string_append(s, "<");
+
+            GSList *sorted_values = form_get_field_values_sorted(field);
+            GSList *curr_value = sorted_values;
+            while (curr_value) {
+                g_string_append(s, curr_value->data);
+                g_string_append(s, "<");
+                curr_value = g_slist_next(curr_value);
+            }
+            g_slist_free(sorted_values);
+            curr_field = g_slist_next(curr_field);
+        }
+        g_slist_free(sorted_fields);
+
+        curr = g_slist_next(curr);
+    }
+
+    char *result = p_sha1_hash(s->str);
+
+    g_string_free(s, TRUE);
+    g_slist_free_full(identities, g_free);
+    g_slist_free_full(features, g_free);
+    g_slist_free_full(form_names, g_free);
+    g_hash_table_destroy(forms);
+
+    return result;
+}
+
 GDateTime*
 stanza_get_delay(xmpp_stanza_t *const stanza)
 {
diff --git a/src/xmpp/stanza.h b/src/xmpp/stanza.h
index f4d76971..a7de205b 100644
--- a/src/xmpp/stanza.h
+++ b/src/xmpp/stanza.h
@@ -292,6 +292,7 @@ void stanza_attach_show(xmpp_ctx_t *const ctx, xmpp_stanza_t *const presence, co
 void stanza_attach_status(xmpp_ctx_t *const ctx, xmpp_stanza_t *const presence, const char *const status);
 
 xmpp_stanza_t* stanza_create_caps_query_element(xmpp_ctx_t *ctx);
+char* stanza_create_caps_sha1_from_query(xmpp_stanza_t *const query);
 
 const char* stanza_get_presence_string_from_type(resource_presence_t presence_type);
 xmpp_stanza_t* stanza_create_software_version_iq(xmpp_ctx_t *ctx, const char *const fulljid);