1
1
mirror of https://github.com/profanity-im/profanity.git synced 2025-01-03 14:57:42 -05:00

xep-0084: Add correct file extension

This commit is contained in:
Michael Vetter 2019-12-18 15:20:07 +01:00
parent 0ea1d3f85d
commit fe41459d86

View File

@ -49,10 +49,23 @@
char *looking_for = NULL; char *looking_for = NULL;
typedef struct avatar_metadata {
char *type;
} avatar_metadata;
static int _avatar_metadata_nofication(xmpp_stanza_t *const stanza, void *const userdata); static int _avatar_metadata_nofication(xmpp_stanza_t *const stanza, void *const userdata);
void avatar_request_item_by_id(const char *jid, const char *id); void avatar_request_item_by_id(const char *jid, const char *id, const char *type);
int avatar_request_item_handler(xmpp_stanza_t *const stanza, void *const userdata); int avatar_request_item_handler(xmpp_stanza_t *const stanza, void *const userdata);
static void
_free_avatar_data(avatar_metadata *data)
{
if (data) {
free(data->type);
free(data);
}
}
void void
avatar_pep_subscribe(void) avatar_pep_subscribe(void)
{ {
@ -81,7 +94,7 @@ _avatar_metadata_nofication(xmpp_stanza_t *const stanza, void *const userdata)
const char *from = xmpp_stanza_get_attribute(stanza, STANZA_ATTR_FROM); const char *from = xmpp_stanza_get_attribute(stanza, STANZA_ATTR_FROM);
if (!(looking_for && if (!(looking_for &&
(g_strcmp0(looking_for, from) == 0))) { (g_strcmp0(looking_for, from) == 0))) {
return 1; return 1;
} }
@ -115,24 +128,29 @@ _avatar_metadata_nofication(xmpp_stanza_t *const stanza, void *const userdata)
return 1; return 1;
xmpp_stanza_t *info = xmpp_stanza_get_child_by_name(metadata, "info"); xmpp_stanza_t *info = xmpp_stanza_get_child_by_name(metadata, "info");
const char *id = xmpp_stanza_get_id(info); const char *id = xmpp_stanza_get_id(info);
const char *type = xmpp_stanza_get_attribute(info, "type");
log_debug("Avatar ID for %s is: %s", from, id); log_debug("Avatar ID for %s is: %s", from, id);
avatar_request_item_by_id(from, id); avatar_request_item_by_id(from, id, type);
} }
return 1; return 1;
} }
void void
avatar_request_item_by_id(const char *jid, const char *id) avatar_request_item_by_id(const char *jid, const char *id, const char *type)
{ {
caps_remove_feature(XMPP_FEATURE_USER_AVATAR_METADATA_NOTIFY); caps_remove_feature(XMPP_FEATURE_USER_AVATAR_METADATA_NOTIFY);
xmpp_ctx_t * const ctx = connection_get_ctx(); xmpp_ctx_t * const ctx = connection_get_ctx();
avatar_metadata *data = malloc(sizeof(avatar_metadata));
data->type = strdup(type);
xmpp_stanza_t *iq = stanza_create_avatar_retrieve_data_request(ctx, id, jid); xmpp_stanza_t *iq = stanza_create_avatar_retrieve_data_request(ctx, id, jid);
iq_id_handler_add("retrieve1", avatar_request_item_handler, free, NULL); iq_id_handler_add("retrieve1", avatar_request_item_handler, (ProfIqFreeCallback)_free_avatar_data, data);
iq_send_stanza(iq); iq_send_stanza(iq);
@ -169,12 +187,12 @@ avatar_request_item_handler(xmpp_stanza_t *const stanza, void *const userdata)
return 1; return 1;
} }
xmpp_stanza_t *data = stanza_get_child_by_name_and_ns(item, "data", STANZA_NS_USER_AVATAR_DATA); xmpp_stanza_t *st_data = stanza_get_child_by_name_and_ns(item, "data", STANZA_NS_USER_AVATAR_DATA);
if (!data) { if (!st_data) {
return 1; return 1;
} }
char *buf = xmpp_stanza_get_text(data); char *buf = xmpp_stanza_get_text(st_data);
gsize size; gsize size;
gchar *de = (gchar*)g_base64_decode(buf, &size); gchar *de = (gchar*)g_base64_decode(buf, &size);
free(buf); free(buf);
@ -198,7 +216,21 @@ avatar_request_item_handler(xmpp_stanza_t *const stanza, void *const userdata)
gchar *from = str_replace(from_attr, "@", "_at_"); gchar *from = str_replace(from_attr, "@", "_at_");
g_string_append(filename, from); g_string_append(filename, from);
g_string_append(filename, ".png");
avatar_metadata *data = (avatar_metadata*)userdata;
// check a few image types ourselves
// if none matches we won't add an extension but linux will
// be able to open it anyways
// TODO: we could use /etc/mime-types
if (g_strcmp0(data->type, "image/png") == 0) {
g_string_append(filename, ".png");
} else if (g_strcmp0(data->type, "image/jpeg") == 0) {
g_string_append(filename, ".jpeg");
} else if (g_strcmp0(data->type, "image/webp") == 0) {
g_string_append(filename, ".webp");
}
free(from); free(from);
GError *err = NULL; GError *err = NULL;