mirror of
https://github.com/profanity-im/profanity.git
synced 2024-11-03 19:37:16 -05:00
Rework omemo_start_device_session_handle_bundle exit
In some conditions we just returned without freeing allocated variables. Should fix following valgrind reported leak: ``` ==17941== 19 bytes in 1 blocks are definitely lost in loss record 613 of 3,674 ==17941== at 0x483677F: malloc (in /usr/lib64/valgrind/vgpreload_memcheck-amd64-linux.so) ==17941== by 0x5BB0DAA: strdup (strdup.c:42) ==17941== by 0x4B1592: omemo_start_device_session_handle_bundle (omemo.c:126) ==17941== by 0x43405E: _iq_handler (iq.c:214) ==17941== by 0x5AF118E: ??? (in /usr/lib64/libmesode.so.0.0.0) ==17941== by 0x5AEDBDA: ??? (in /usr/lib64/libmesode.so.0.0.0) ==17941== by 0x5AFA43E: ??? (in /usr/lib64/libmesode.so.0.0.0) ==17941== by 0x6818AA4: ??? (in /usr/lib64/libexpat.so.1.6.8) ==17941== by 0x681A3AB: ??? (in /usr/lib64/libexpat.so.1.6.8) ==17941== by 0x681D7EB: XML_ParseBuffer (in /usr/lib64/libexpat.so.1.6.8) ==17941== by 0x5AF0A63: xmpp_run_once (in /usr/lib64/libmesode.so.0.0.0) ==17941== by 0x432E5D: connection_check_events (connection.c:104) ==17941== by 0x4323B3: session_process_events (session.c:255) ==17941== by 0x42C097: prof_run (profanity.c:128) ==17941== by 0x4B2610: main (main.c:172) ```
This commit is contained in:
parent
0410802753
commit
e3443f5c9a
@ -111,8 +111,13 @@ omemo_bundle_request(const char * const jid, uint32_t device_id, ProfIqCallback
|
|||||||
int
|
int
|
||||||
omemo_start_device_session_handle_bundle(xmpp_stanza_t *const stanza, void *const userdata)
|
omemo_start_device_session_handle_bundle(xmpp_stanza_t *const stanza, void *const userdata)
|
||||||
{
|
{
|
||||||
|
GList *prekeys_list = NULL;
|
||||||
|
unsigned char *signed_prekey_raw = NULL;
|
||||||
|
unsigned char *signed_prekey_signature_raw = NULL;
|
||||||
char *from = NULL;
|
char *from = NULL;
|
||||||
|
|
||||||
const char *from_attr = xmpp_stanza_get_attribute(stanza, STANZA_ATTR_FROM);
|
const char *from_attr = xmpp_stanza_get_attribute(stanza, STANZA_ATTR_FROM);
|
||||||
|
|
||||||
if (!from_attr) {
|
if (!from_attr) {
|
||||||
Jid *jid = jid_create(connection_get_fulljid());
|
Jid *jid = jid_create(connection_get_fulljid());
|
||||||
from = strdup(jid->barejid);
|
from = strdup(jid->barejid);
|
||||||
@ -122,54 +127,53 @@ omemo_start_device_session_handle_bundle(xmpp_stanza_t *const stanza, void *cons
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (g_strcmp0(from, userdata) != 0) {
|
if (g_strcmp0(from, userdata) != 0) {
|
||||||
return 1;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
xmpp_stanza_t *pubsub = xmpp_stanza_get_child_by_ns(stanza, STANZA_NS_PUBSUB);
|
xmpp_stanza_t *pubsub = xmpp_stanza_get_child_by_ns(stanza, STANZA_NS_PUBSUB);
|
||||||
if (!pubsub) {
|
if (!pubsub) {
|
||||||
return 1;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
xmpp_stanza_t *items = xmpp_stanza_get_child_by_name(pubsub, "items");
|
xmpp_stanza_t *items = xmpp_stanza_get_child_by_name(pubsub, "items");
|
||||||
if (!items) {
|
if (!items) {
|
||||||
return 1;
|
goto out;
|
||||||
}
|
}
|
||||||
const char *node = xmpp_stanza_get_attribute(items, "node");
|
const char *node = xmpp_stanza_get_attribute(items, "node");
|
||||||
char *device_id_str = strstr(node, ":");
|
char *device_id_str = strstr(node, ":");
|
||||||
if (!device_id_str) {
|
if (!device_id_str) {
|
||||||
return 1;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t device_id = strtoul(++device_id_str, NULL, 10);
|
uint32_t device_id = strtoul(++device_id_str, NULL, 10);
|
||||||
|
|
||||||
xmpp_stanza_t *item = xmpp_stanza_get_child_by_name(items, "item");
|
xmpp_stanza_t *item = xmpp_stanza_get_child_by_name(items, "item");
|
||||||
if (!item) {
|
if (!item) {
|
||||||
return 1;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
xmpp_stanza_t *bundle = xmpp_stanza_get_child_by_ns(item, STANZA_NS_OMEMO);
|
xmpp_stanza_t *bundle = xmpp_stanza_get_child_by_ns(item, STANZA_NS_OMEMO);
|
||||||
if (!bundle) {
|
if (!bundle) {
|
||||||
return 1;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
xmpp_stanza_t *prekeys = xmpp_stanza_get_child_by_name(bundle, "prekeys");
|
xmpp_stanza_t *prekeys = xmpp_stanza_get_child_by_name(bundle, "prekeys");
|
||||||
if (!prekeys) {
|
if (!prekeys) {
|
||||||
return 1;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
GList *prekeys_list = NULL;
|
|
||||||
xmpp_stanza_t *prekey;
|
xmpp_stanza_t *prekey;
|
||||||
for (prekey = xmpp_stanza_get_children(prekeys); prekey != NULL; prekey = xmpp_stanza_get_next(prekey)) {
|
for (prekey = xmpp_stanza_get_children(prekeys); prekey != NULL; prekey = xmpp_stanza_get_next(prekey)) {
|
||||||
omemo_key_t *key = malloc(sizeof(omemo_key_t));
|
omemo_key_t *key = malloc(sizeof(omemo_key_t));
|
||||||
|
|
||||||
const char *prekey_id_text = xmpp_stanza_get_attribute(prekey, "preKeyId");
|
const char *prekey_id_text = xmpp_stanza_get_attribute(prekey, "preKeyId");
|
||||||
if (!prekey_id_text) {
|
if (!prekey_id_text) {
|
||||||
return 1;
|
goto out;
|
||||||
}
|
}
|
||||||
key->id = strtoul(prekey_id_text, NULL, 10);
|
key->id = strtoul(prekey_id_text, NULL, 10);
|
||||||
xmpp_stanza_t *prekey_text = xmpp_stanza_get_children(prekey);
|
xmpp_stanza_t *prekey_text = xmpp_stanza_get_children(prekey);
|
||||||
if (!prekey_text) {
|
if (!prekey_text) {
|
||||||
return 1;
|
goto out;
|
||||||
}
|
}
|
||||||
char *prekey_b64 = xmpp_stanza_get_text(prekey_text);
|
char *prekey_b64 = xmpp_stanza_get_text(prekey_text);
|
||||||
key->data = g_base64_decode(prekey_b64, &key->length);
|
key->data = g_base64_decode(prekey_b64, &key->length);
|
||||||
@ -182,42 +186,44 @@ omemo_start_device_session_handle_bundle(xmpp_stanza_t *const stanza, void *cons
|
|||||||
|
|
||||||
xmpp_stanza_t *signed_prekey = xmpp_stanza_get_child_by_name(bundle, "signedPreKeyPublic");
|
xmpp_stanza_t *signed_prekey = xmpp_stanza_get_child_by_name(bundle, "signedPreKeyPublic");
|
||||||
if (!signed_prekey) {
|
if (!signed_prekey) {
|
||||||
return 1;
|
goto out;
|
||||||
}
|
}
|
||||||
const char *signed_prekey_id_text = xmpp_stanza_get_attribute(signed_prekey, "signedPreKeyId");
|
const char *signed_prekey_id_text = xmpp_stanza_get_attribute(signed_prekey, "signedPreKeyId");
|
||||||
if (!signed_prekey_id_text) {
|
if (!signed_prekey_id_text) {
|
||||||
return 1;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t signed_prekey_id = strtoul(signed_prekey_id_text, NULL, 10);
|
uint32_t signed_prekey_id = strtoul(signed_prekey_id_text, NULL, 10);
|
||||||
xmpp_stanza_t *signed_prekey_text = xmpp_stanza_get_children(signed_prekey);
|
xmpp_stanza_t *signed_prekey_text = xmpp_stanza_get_children(signed_prekey);
|
||||||
if (!signed_prekey_text) {
|
if (!signed_prekey_text) {
|
||||||
return 1;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
size_t signed_prekey_len;
|
size_t signed_prekey_len;
|
||||||
char *signed_prekey_b64 = xmpp_stanza_get_text(signed_prekey_text);
|
char *signed_prekey_b64 = xmpp_stanza_get_text(signed_prekey_text);
|
||||||
unsigned char *signed_prekey_raw = g_base64_decode(signed_prekey_b64, &signed_prekey_len);
|
signed_prekey_raw = g_base64_decode(signed_prekey_b64, &signed_prekey_len);
|
||||||
free(signed_prekey_b64);
|
free(signed_prekey_b64);
|
||||||
|
|
||||||
xmpp_stanza_t *signed_prekey_signature = xmpp_stanza_get_child_by_name(bundle, "signedPreKeySignature");
|
xmpp_stanza_t *signed_prekey_signature = xmpp_stanza_get_child_by_name(bundle, "signedPreKeySignature");
|
||||||
if (!signed_prekey_signature) {
|
if (!signed_prekey_signature) {
|
||||||
return 1;
|
goto out;
|
||||||
}
|
}
|
||||||
xmpp_stanza_t *signed_prekey_signature_text = xmpp_stanza_get_children(signed_prekey_signature);
|
xmpp_stanza_t *signed_prekey_signature_text = xmpp_stanza_get_children(signed_prekey_signature);
|
||||||
if (!signed_prekey_signature_text) {
|
if (!signed_prekey_signature_text) {
|
||||||
return 1;
|
goto out;
|
||||||
}
|
}
|
||||||
size_t signed_prekey_signature_len;
|
size_t signed_prekey_signature_len;
|
||||||
char *signed_prekey_signature_b64 = xmpp_stanza_get_text(signed_prekey_signature_text);
|
char *signed_prekey_signature_b64 = xmpp_stanza_get_text(signed_prekey_signature_text);
|
||||||
unsigned char *signed_prekey_signature_raw = g_base64_decode(signed_prekey_signature_b64, &signed_prekey_signature_len);
|
signed_prekey_signature_raw = g_base64_decode(signed_prekey_signature_b64, &signed_prekey_signature_len);
|
||||||
free(signed_prekey_signature_b64);
|
free(signed_prekey_signature_b64);
|
||||||
|
|
||||||
xmpp_stanza_t *identity_key = xmpp_stanza_get_child_by_name(bundle, "identityKey");
|
xmpp_stanza_t *identity_key = xmpp_stanza_get_child_by_name(bundle, "identityKey");
|
||||||
if (!identity_key) {
|
if (!identity_key) {
|
||||||
return 1;
|
goto out;
|
||||||
}
|
}
|
||||||
xmpp_stanza_t *identity_key_text = xmpp_stanza_get_children(identity_key);
|
xmpp_stanza_t *identity_key_text = xmpp_stanza_get_children(identity_key);
|
||||||
if (!identity_key_text) {
|
if (!identity_key_text) {
|
||||||
return 1;
|
goto out;
|
||||||
}
|
}
|
||||||
size_t identity_key_len;
|
size_t identity_key_len;
|
||||||
char *identity_key_b64 = xmpp_stanza_get_text(identity_key_text);
|
char *identity_key_b64 = xmpp_stanza_get_text(identity_key_text);
|
||||||
@ -228,11 +234,19 @@ omemo_start_device_session_handle_bundle(xmpp_stanza_t *const stanza, void *cons
|
|||||||
signed_prekey_raw, signed_prekey_len, signed_prekey_signature_raw,
|
signed_prekey_raw, signed_prekey_len, signed_prekey_signature_raw,
|
||||||
signed_prekey_signature_len, identity_key_raw, identity_key_len);
|
signed_prekey_signature_len, identity_key_raw, identity_key_len);
|
||||||
|
|
||||||
free(from);
|
|
||||||
g_list_free_full(prekeys_list, (GDestroyNotify)omemo_key_free);
|
|
||||||
g_free(signed_prekey_raw);
|
|
||||||
g_free(identity_key_raw);
|
g_free(identity_key_raw);
|
||||||
|
|
||||||
|
out:
|
||||||
|
free(from);
|
||||||
|
if (signed_prekey_raw) {
|
||||||
|
g_free(signed_prekey_raw);
|
||||||
|
}
|
||||||
|
if (signed_prekey_signature_raw) {
|
||||||
g_free(signed_prekey_signature_raw);
|
g_free(signed_prekey_signature_raw);
|
||||||
|
}
|
||||||
|
if (prekeys_list) {
|
||||||
|
g_list_free_full(prekeys_list, (GDestroyNotify)omemo_key_free);
|
||||||
|
}
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -292,12 +306,12 @@ omemo_receive_message(xmpp_stanza_t *const stanza, gboolean *trusted)
|
|||||||
goto skip;
|
goto skip;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
const char *rid_text = xmpp_stanza_get_attribute(key_stanza, "rid");
|
const char *rid_text = xmpp_stanza_get_attribute(key_stanza, "rid");
|
||||||
key->device_id = strtoul(rid_text, NULL, 10);
|
key->device_id = strtoul(rid_text, NULL, 10);
|
||||||
if (!key->device_id) {
|
if (!key->device_id) {
|
||||||
goto skip;
|
goto skip;
|
||||||
}
|
}
|
||||||
|
|
||||||
key->data = g_base64_decode(key_text, &key->length);
|
key->data = g_base64_decode(key_text, &key->length);
|
||||||
free(key_text);
|
free(key_text);
|
||||||
key->prekey = g_strcmp0(xmpp_stanza_get_attribute(key_stanza, "prekey"), "true") == 0;
|
key->prekey = g_strcmp0(xmpp_stanza_get_attribute(key_stanza, "prekey"), "true") == 0;
|
||||||
|
Loading…
Reference in New Issue
Block a user