diff options
author | DebXWoody <stefan@debxwoody.de> | 2021-06-28 21:28:58 +0200 |
---|---|---|
committer | DebXWoody <stefan@debxwoody.de> | 2021-06-28 21:28:58 +0200 |
commit | 2a011e69acb97ba6e794f970c5d67a9e4b348bd7 (patch) | |
tree | f83558162e5e5a2f79064a70d61173497e29d7c8 /src/xmpp | |
parent | 49a0d97a433da21fa6cd3c85401f76523471c115 (diff) | |
download | profani-tty-2a011e69acb97ba6e794f970c5d67a9e4b348bd7.tar.gz |
Bugfixes for OX implementation
* autocomplete for /ox discover * fixed help description * Implemented /ox char command * Validated KeyID length
Diffstat (limited to 'src/xmpp')
-rw-r--r-- | src/xmpp/message.c | 56 | ||||
-rw-r--r-- | src/xmpp/ox.c | 19 |
2 files changed, 42 insertions, 33 deletions
diff --git a/src/xmpp/message.c b/src/xmpp/message.c index e14ae07d..33e15e78 100644 --- a/src/xmpp/message.c +++ b/src/xmpp/message.c @@ -1454,39 +1454,41 @@ _handle_ox_chat(xmpp_stanza_t* const stanza, ProfMessage* message, gboolean is_m message->enc = PROF_MSG_ENC_OX; #ifdef HAVE_LIBGPGME - xmpp_ctx_t* const ctx = connection_get_ctx(); - xmpp_stanza_t* ox = xmpp_stanza_get_child_by_name_and_ns(stanza, "openpgp", STANZA_NS_OPENPGP_0); - if (!ox) { - return; - } - - char* ox_text = xmpp_stanza_get_text(ox); - if (!ox_text) { - return; - } - - message->plain = p_ox_gpg_decrypt(ox_text); - xmpp_free(ctx, ox_text); - - xmpp_stanza_t *x = xmpp_stanza_new_from_string(ctx, message->plain); - xmpp_stanza_t *p = xmpp_stanza_get_child_by_name(x, "payload"); - if (p) { - xmpp_stanza_t *b = xmpp_stanza_get_child_by_name(p, "body"); - if (b) { - message->plain = xmpp_stanza_get_text(b); - if(message->plain == NULL ) { - message->plain = xmpp_stanza_get_text(stanza); - } - message->encrypted = xmpp_stanza_get_text(ox); + if ( ox ) { + message->plain = p_ox_gpg_decrypt(xmpp_stanza_get_text(ox)); + if ( message->plain ) { + xmpp_stanza_t *x = xmpp_stanza_new_from_string(connection_get_ctx(), message->plain); + if ( x ) { + xmpp_stanza_t *p = xmpp_stanza_get_child_by_name(x, "payload"); + if ( !p ) { + log_warning("OX Stanza - no Payload"); + return; + } + xmpp_stanza_t *b = xmpp_stanza_get_child_by_name(p, "body"); + if ( !b ) { + log_warning("OX Stanza - no body"); + return; + } + message->plain = xmpp_stanza_get_text(b); + if(message->plain == NULL ) { + message->plain = xmpp_stanza_get_text(stanza); + } + message->encrypted = xmpp_stanza_get_text(ox); - if (message->plain == NULL) { - message->plain = xmpp_stanza_get_text(stanza); + if (message->plain == NULL) { + message->plain = xmpp_stanza_get_text(stanza); + } + message->encrypted = xmpp_stanza_get_text(ox); + } else { + log_warning("OX Stanza text to stanza failed"); } - message->encrypted = xmpp_stanza_get_text(ox); } + } else { + log_warning("OX Stanza without openpgp stanza"); } #endif // HAVE_LIBGPGME + } static gboolean diff --git a/src/xmpp/ox.c b/src/xmpp/ox.c index e1fb1738..195cdedd 100644 --- a/src/xmpp/ox.c +++ b/src/xmpp/ox.c @@ -45,6 +45,9 @@ #include "pgp/gpg.h" #ifdef HAVE_LIBGPGME + +#define KEYID_LENGTH 40 + static void _ox_metadata_node__public_key(const char* const fingerprint); static int _ox_metadata_result(xmpp_conn_t* const conn, xmpp_stanza_t* const stanza, void* const userdata); @@ -165,8 +168,8 @@ ox_announce_public_key(const char* const filename) void ox_discover_public_key(const char* const jid) { - assert(jid); - log_info("Discovering Public Key for %s", jid); + assert(jid && strlen(jid) > 0); + log_info("[OX] Discovering Public Key for %s", jid); cons_show("Discovering Public Key for %s", jid); // iq xmpp_ctx_t* const ctx = connection_get_ctx(); @@ -188,6 +191,7 @@ ox_discover_public_key(const char* const jid) xmpp_id_handler_add(connection_get_conn(), _ox_metadata_result, id, strdup(jid)); xmpp_send(connection_get_conn(), iq); + xmpp_stanza_release(iq); } void @@ -228,7 +232,7 @@ _ox_metadata_node__public_key(const char* const fingerprint) { log_info("Annonuce OpenPGP metadata: %s", fingerprint); assert(fingerprint); - assert(strlen(fingerprint) == 40); + assert(strlen(fingerprint) == KEYID_LENGTH); // iq xmpp_ctx_t* const ctx = connection_get_ctx(); char* id = xmpp_uuid_gen(ctx); @@ -269,7 +273,7 @@ _ox_metadata_result(xmpp_conn_t* const conn, xmpp_stanza_t* const stanza, void* log_debug("[OX] Processing result %s's metadata.", (char*)userdata); if (g_strcmp0(xmpp_stanza_get_type(stanza), "result") != 0) { - log_debug("[OX] Error: No result"); + log_debug("[OX] Error: Unable to load metadata of user %s - Not a stanza result type", (char*)userdata); return FALSE; } // pubsub @@ -301,8 +305,11 @@ _ox_metadata_result(xmpp_conn_t* const conn, xmpp_stanza_t* const stanza, void* while (pubkeymetadata) { const char* fingerprint = xmpp_stanza_get_attribute(pubkeymetadata, STANZA_ATTR_V4_FINGERPRINT); - if (fingerprint) { + if ( strlen( fingerprint ) == KEYID_LENGTH ) { cons_show(fingerprint); + } else { + cons_show("OX: Wrong char size of public key"); + log_error("[OX] Wrong chat size of public key %s", fingerprint); } pubkeymetadata = xmpp_stanza_get_next(pubkeymetadata); } @@ -332,7 +339,7 @@ _ox_request_public_key(const char* const jid, const char* const fingerprint) { assert(jid); assert(fingerprint); - assert(strlen(fingerprint) == 40); + assert(strlen(fingerprint) == KEYID_LENGTH); cons_show("Requesting Public Key %s for %s", fingerprint, jid); log_info("[OX] Request %s's public key %s.", jid, fingerprint); // iq |