mirror of
https://github.com/profanity-im/profanity.git
synced 2024-12-04 14:46:46 -05:00
Use Jid in groupchat message handler
This commit is contained in:
parent
ec75b5e04a
commit
b768296a93
14
src/jabber.c
14
src/jabber.c
@ -527,10 +527,9 @@ _message_handler(xmpp_conn_t * const conn,
|
|||||||
static int
|
static int
|
||||||
_groupchat_message_handler(xmpp_stanza_t * const stanza)
|
_groupchat_message_handler(xmpp_stanza_t * const stanza)
|
||||||
{
|
{
|
||||||
char *room = NULL;
|
|
||||||
char *nick = NULL;
|
|
||||||
char *message = NULL;
|
char *message = NULL;
|
||||||
char *room_jid = xmpp_stanza_get_attribute(stanza, STANZA_ATTR_FROM);
|
char *room_jid = xmpp_stanza_get_attribute(stanza, STANZA_ATTR_FROM);
|
||||||
|
Jid *jid = jid_create(room_jid);
|
||||||
|
|
||||||
// handle room broadcasts
|
// handle room broadcasts
|
||||||
if (jid_is_room(room_jid)) {
|
if (jid_is_room(room_jid)) {
|
||||||
@ -540,8 +539,7 @@ _groupchat_message_handler(xmpp_stanza_t * const stanza)
|
|||||||
if (subject != NULL) {
|
if (subject != NULL) {
|
||||||
message = xmpp_stanza_get_text(subject);
|
message = xmpp_stanza_get_text(subject);
|
||||||
if (message != NULL) {
|
if (message != NULL) {
|
||||||
room = get_room_from_full_jid(room_jid);
|
prof_handle_room_subject(jid->barejid, message);
|
||||||
prof_handle_room_subject(room, message);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
@ -560,7 +558,6 @@ _groupchat_message_handler(xmpp_stanza_t * const stanza)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Jid *jid = jid_create(room_jid);
|
|
||||||
|
|
||||||
if (!jid_is_valid_room_form(jid)) {
|
if (!jid_is_valid_room_form(jid)) {
|
||||||
log_error("Invalid room JID: %s", jid->str);
|
log_error("Invalid room JID: %s", jid->str);
|
||||||
@ -582,14 +579,13 @@ _groupchat_message_handler(xmpp_stanza_t * const stanza)
|
|||||||
if (body != NULL) {
|
if (body != NULL) {
|
||||||
char *message = xmpp_stanza_get_text(body);
|
char *message = xmpp_stanza_get_text(body);
|
||||||
if (delayed) {
|
if (delayed) {
|
||||||
prof_handle_room_history(room, nick, tv_stamp, message);
|
prof_handle_room_history(jid->barejid, jid->resourcepart, tv_stamp, message);
|
||||||
} else {
|
} else {
|
||||||
prof_handle_room_message(room, nick, message);
|
prof_handle_room_message(jid->barejid, jid->resourcepart, message);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
free(room);
|
jid_destroy(jid);
|
||||||
free(nick);
|
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user