mirror of
https://github.com/profanity-im/profanity.git
synced 2024-12-04 14:46:46 -05:00
jabber: tidy groupchat message handler
This commit is contained in:
parent
d2a923126b
commit
82e65734c0
88
src/jabber.c
88
src/jabber.c
@ -379,57 +379,51 @@ _jabber_roster_request(void)
|
|||||||
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;
|
||||||
|
|
||||||
gchar *room_jid = xmpp_stanza_get_attribute(stanza, "from");
|
gchar *room_jid = xmpp_stanza_get_attribute(stanza, "from");
|
||||||
|
if (!room_parse_room_jid(room_jid, &room, &nick)) {
|
||||||
|
log_error("Could not parse room jid: %s", room_jid);
|
||||||
|
g_free(room);
|
||||||
|
g_free(nick);
|
||||||
|
|
||||||
if (room_is_active(room_jid)) {
|
return 1;
|
||||||
xmpp_stanza_t *delay = xmpp_stanza_get_child_by_name(stanza, "delay");
|
}
|
||||||
|
|
||||||
// handle chat room history
|
if (!room_is_active(room_jid)) {
|
||||||
if (delay != NULL) {
|
|
||||||
char *utc_stamp = xmpp_stanza_get_attribute(delay, "stamp");
|
|
||||||
GTimeVal tv_stamp;
|
|
||||||
|
|
||||||
if(g_time_val_from_iso8601(utc_stamp, &tv_stamp)) {
|
|
||||||
xmpp_stanza_t *body = xmpp_stanza_get_child_by_name(stanza, "body");
|
|
||||||
|
|
||||||
if (body != NULL) {
|
|
||||||
char *room = NULL;
|
|
||||||
char *nick = NULL;
|
|
||||||
gboolean parse_success = room_parse_room_jid(room_jid, &room, &nick);
|
|
||||||
|
|
||||||
if (parse_success) {
|
|
||||||
char *message = xmpp_stanza_get_text(body);
|
|
||||||
prof_handle_room_history(room, nick, tv_stamp, message);
|
|
||||||
g_free(room);
|
|
||||||
g_free(nick);
|
|
||||||
} else {
|
|
||||||
log_error("Could not parse room jid: %s", room_jid);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
log_error("Couldn't parse datetime string receiving room history: %s", utc_stamp);
|
|
||||||
}
|
|
||||||
|
|
||||||
// handle regular chat room message
|
|
||||||
} else {
|
|
||||||
xmpp_stanza_t *body = xmpp_stanza_get_child_by_name(stanza, "body");
|
|
||||||
if (body != NULL) {
|
|
||||||
char *room = NULL;
|
|
||||||
char *nick = NULL;
|
|
||||||
gboolean parse_success = room_parse_room_jid(room_jid, &room, &nick);
|
|
||||||
|
|
||||||
if (parse_success) {
|
|
||||||
char *message = xmpp_stanza_get_text(body);
|
|
||||||
prof_handle_room_message(room, nick, message);
|
|
||||||
g_free(room);
|
|
||||||
g_free(nick);
|
|
||||||
} else {
|
|
||||||
log_error("Could not parse room jid: %s", room_jid);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
log_error("Message recieved for inactive groupchat: %s", room_jid);
|
log_error("Message recieved for inactive groupchat: %s", room_jid);
|
||||||
|
g_free(room);
|
||||||
|
g_free(nick);
|
||||||
|
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
char *message = NULL;
|
||||||
|
xmpp_stanza_t *delay = xmpp_stanza_get_child_by_name(stanza, "delay");
|
||||||
|
xmpp_stanza_t *body = xmpp_stanza_get_child_by_name(stanza, "body");
|
||||||
|
if (body != NULL) {
|
||||||
|
message = xmpp_stanza_get_text(body);
|
||||||
|
}
|
||||||
|
|
||||||
|
// handle chat room history
|
||||||
|
if (delay != NULL) {
|
||||||
|
char *utc_stamp = xmpp_stanza_get_attribute(delay, "stamp");
|
||||||
|
GTimeVal tv_stamp;
|
||||||
|
|
||||||
|
if (g_time_val_from_iso8601(utc_stamp, &tv_stamp)) {
|
||||||
|
if (message != NULL) {
|
||||||
|
prof_handle_room_history(room, nick, tv_stamp, message);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
log_error("Couldn't parse datetime string receiving room history: %s", utc_stamp);
|
||||||
|
}
|
||||||
|
|
||||||
|
// handle regular chat room message
|
||||||
|
} else {
|
||||||
|
if (message != NULL) {
|
||||||
|
prof_handle_room_message(room, nick, message);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
|
Loading…
Reference in New Issue
Block a user