diff options
author | Dmitry Podgorny <pasis.ua@gmail.com> | 2020-04-09 15:22:11 +0300 |
---|---|---|
committer | Dmitry Podgorny <pasis.ua@gmail.com> | 2020-04-09 15:22:11 +0300 |
commit | 44377c6a5ca96ec6334619d49d6a4f486c5a8d21 (patch) | |
tree | 2e59613f829fed04c0b427ea248eb92c55af5fd3 /src/xmpp | |
parent | 401ebce84e87ab35746f488e58bba25dfe5b4c2f (diff) | |
download | profani-tty-44377c6a5ca96ec6334619d49d6a4f486c5a8d21.tar.gz |
Fix use-after-free in stanza_create_caps_from_query_element()
The function creates a form to find such strings as software, os, etc. It remembers the strings allocated by form_create() and use them below in caps_create(). The issue is that the form is destroyed before and as result the strings are freed too. As solution, allocate own copy of strings.
Diffstat (limited to 'src/xmpp')
-rw-r--r-- | src/xmpp/stanza.c | 12 |
1 files changed, 8 insertions, 4 deletions
diff --git a/src/xmpp/stanza.c b/src/xmpp/stanza.c index 8791100b..56185843 100644 --- a/src/xmpp/stanza.c +++ b/src/xmpp/stanza.c @@ -1784,13 +1784,13 @@ stanza_create_caps_from_query_element(xmpp_stanza_t *query) formField = field->data; if (formField->values) { if (strcmp(formField->var, "software") == 0) { - software = formField->values->data; + software = strdup(formField->values->data); } else if (strcmp(formField->var, "software_version") == 0) { - software_version = formField->values->data; + software_version = strdup(formField->values->data); } else if (strcmp(formField->var, "os") == 0) { - os = formField->values->data; + os = strdup(formField->values->data); } else if (strcmp(formField->var, "os_version") == 0) { - os_version = formField->values->data; + os_version = strdup(formField->values->data); } } field = g_slist_next(field); @@ -1872,6 +1872,10 @@ stanza_create_caps_from_query_element(xmpp_stanza_t *query) EntityCapabilities *result = caps_create(category, type, name, software, software_version, os, os_version, features); g_slist_free_full(features, free); + free(software); + free(software_version); + free(os); + free(os_version); return result; } |