mirror of
https://github.com/profanity-im/profanity.git
synced 2025-01-03 14:57:42 -05:00
Added xml escaping to stanza module
This commit is contained in:
parent
29b5abfe06
commit
f90d13bd5e
@ -144,8 +144,6 @@ jabber_process_events(void)
|
|||||||
void
|
void
|
||||||
jabber_send(const char * const msg, const char * const recipient)
|
jabber_send(const char * const msg, const char * const recipient)
|
||||||
{
|
{
|
||||||
char *encoded_xml = encode_xml(msg);
|
|
||||||
|
|
||||||
if (prefs_get_states()) {
|
if (prefs_get_states()) {
|
||||||
if (!chat_session_exists(recipient)) {
|
if (!chat_session_exists(recipient)) {
|
||||||
chat_session_start(recipient, TRUE);
|
chat_session_start(recipient, TRUE);
|
||||||
@ -156,16 +154,14 @@ jabber_send(const char * const msg, const char * const recipient)
|
|||||||
if (prefs_get_states() && chat_session_get_recipient_supports(recipient)) {
|
if (prefs_get_states() && chat_session_get_recipient_supports(recipient)) {
|
||||||
chat_session_set_active(recipient);
|
chat_session_set_active(recipient);
|
||||||
message = stanza_create_message(jabber_conn.ctx, recipient, "chat",
|
message = stanza_create_message(jabber_conn.ctx, recipient, "chat",
|
||||||
encoded_xml, "active");
|
msg, "active");
|
||||||
} else {
|
} else {
|
||||||
message = stanza_create_message(jabber_conn.ctx, recipient, "chat",
|
message = stanza_create_message(jabber_conn.ctx, recipient, "chat",
|
||||||
encoded_xml, NULL);
|
msg, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
xmpp_send(jabber_conn.conn, message);
|
xmpp_send(jabber_conn.conn, message);
|
||||||
xmpp_stanza_release(message);
|
xmpp_stanza_release(message);
|
||||||
|
|
||||||
free(encoded_xml);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -22,6 +22,8 @@
|
|||||||
|
|
||||||
#include <strophe.h>
|
#include <strophe.h>
|
||||||
|
|
||||||
|
#include "common.h"
|
||||||
|
|
||||||
xmpp_stanza_t *
|
xmpp_stanza_t *
|
||||||
stanza_create_chat_state(xmpp_ctx_t *ctx, const char * const recipient,
|
stanza_create_chat_state(xmpp_ctx_t *ctx, const char * const recipient,
|
||||||
const char * const state)
|
const char * const state)
|
||||||
@ -46,6 +48,8 @@ stanza_create_message(xmpp_ctx_t *ctx, const char * const recipient,
|
|||||||
const char * const type, const char * const message,
|
const char * const type, const char * const message,
|
||||||
const char * const state)
|
const char * const state)
|
||||||
{
|
{
|
||||||
|
char *encoded_xml = encode_xml(message);
|
||||||
|
|
||||||
xmpp_stanza_t *msg, *body, *text;
|
xmpp_stanza_t *msg, *body, *text;
|
||||||
|
|
||||||
msg = xmpp_stanza_new(ctx);
|
msg = xmpp_stanza_new(ctx);
|
||||||
@ -57,7 +61,7 @@ stanza_create_message(xmpp_ctx_t *ctx, const char * const recipient,
|
|||||||
xmpp_stanza_set_name(body, "body");
|
xmpp_stanza_set_name(body, "body");
|
||||||
|
|
||||||
text = xmpp_stanza_new(ctx);
|
text = xmpp_stanza_new(ctx);
|
||||||
xmpp_stanza_set_text(text, message);
|
xmpp_stanza_set_text(text, encoded_xml);
|
||||||
xmpp_stanza_add_child(body, text);
|
xmpp_stanza_add_child(body, text);
|
||||||
xmpp_stanza_add_child(msg, body);
|
xmpp_stanza_add_child(msg, body);
|
||||||
|
|
||||||
@ -68,6 +72,8 @@ stanza_create_message(xmpp_ctx_t *ctx, const char * const recipient,
|
|||||||
xmpp_stanza_add_child(msg, chat_state);
|
xmpp_stanza_add_child(msg, chat_state);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
g_free(encoded_xml);
|
||||||
|
|
||||||
return msg;
|
return msg;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user