mirror of
https://github.com/profanity-im/profanity.git
synced 2025-01-03 14:57:42 -05:00
Refactor show and status stanza handling
This commit is contained in:
parent
e22970b304
commit
8d2e0656b4
@ -333,14 +333,7 @@ _unavailable_handler(xmpp_conn_t * const conn,
|
|||||||
Jid *my_jid = jid_create(jid);
|
Jid *my_jid = jid_create(jid);
|
||||||
Jid *from_jid = jid_create(from);
|
Jid *from_jid = jid_create(from);
|
||||||
|
|
||||||
char *status_str;
|
char *status_str = stanza_get_status(stanza, NULL);
|
||||||
xmpp_stanza_t *status =
|
|
||||||
xmpp_stanza_get_child_by_name(stanza, STANZA_NAME_STATUS);
|
|
||||||
|
|
||||||
if (status != NULL)
|
|
||||||
status_str = xmpp_stanza_get_text(status);
|
|
||||||
else
|
|
||||||
status_str = NULL;
|
|
||||||
|
|
||||||
if (strcmp(my_jid->barejid, from_jid->barejid) !=0) {
|
if (strcmp(my_jid->barejid, from_jid->barejid) !=0) {
|
||||||
if (from_jid->resourcepart != NULL) {
|
if (from_jid->resourcepart != NULL) {
|
||||||
@ -387,7 +380,8 @@ _available_handler(xmpp_conn_t * const conn,
|
|||||||
Jid *my_jid = jid_create(jid);
|
Jid *my_jid = jid_create(jid);
|
||||||
Jid *from_jid = jid_create(from);
|
Jid *from_jid = jid_create(from);
|
||||||
|
|
||||||
char *show_str, *status_str;
|
char *show_str = stanza_get_show(stanza, "online");
|
||||||
|
char *status_str = stanza_get_status(stanza, NULL);
|
||||||
char *caps_key = _get_caps_key(stanza);
|
char *caps_key = _get_caps_key(stanza);
|
||||||
int idle_seconds = stanza_get_idle_time(stanza);
|
int idle_seconds = stanza_get_idle_time(stanza);
|
||||||
GDateTime *last_activity = NULL;
|
GDateTime *last_activity = NULL;
|
||||||
@ -398,21 +392,6 @@ _available_handler(xmpp_conn_t * const conn,
|
|||||||
g_date_time_unref(now);
|
g_date_time_unref(now);
|
||||||
}
|
}
|
||||||
|
|
||||||
xmpp_stanza_t *show = xmpp_stanza_get_child_by_name(stanza, STANZA_NAME_SHOW);
|
|
||||||
|
|
||||||
if (show != NULL)
|
|
||||||
show_str = xmpp_stanza_get_text(show);
|
|
||||||
else
|
|
||||||
show_str = "online";
|
|
||||||
|
|
||||||
xmpp_stanza_t *status =
|
|
||||||
xmpp_stanza_get_child_by_name(stanza, STANZA_NAME_STATUS);
|
|
||||||
|
|
||||||
if (status != NULL)
|
|
||||||
status_str = xmpp_stanza_get_text(status);
|
|
||||||
else
|
|
||||||
status_str = NULL;
|
|
||||||
|
|
||||||
// get priority
|
// get priority
|
||||||
int priority = 0;
|
int priority = 0;
|
||||||
xmpp_stanza_t *priority_stanza =
|
xmpp_stanza_t *priority_stanza =
|
||||||
@ -601,12 +580,7 @@ _room_presence_handler(xmpp_conn_t * const conn, xmpp_stanza_t * const stanza,
|
|||||||
|
|
||||||
log_debug("Room presence received from %s", from_jid->fulljid);
|
log_debug("Room presence received from %s", from_jid->fulljid);
|
||||||
|
|
||||||
xmpp_stanza_t *status = xmpp_stanza_get_child_by_name(stanza, STANZA_NAME_STATUS);
|
status_str = stanza_get_status(stanza, NULL);
|
||||||
if (status != NULL) {
|
|
||||||
status_str = xmpp_stanza_get_text(status);
|
|
||||||
} else {
|
|
||||||
status_str = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ((type != NULL) && (strcmp(type, STANZA_TYPE_UNAVAILABLE) == 0)) {
|
if ((type != NULL) && (strcmp(type, STANZA_TYPE_UNAVAILABLE) == 0)) {
|
||||||
|
|
||||||
@ -618,12 +592,7 @@ _room_presence_handler(xmpp_conn_t * const conn, xmpp_stanza_t * const stanza,
|
|||||||
prof_handle_room_member_offline(room, nick, "offline", status_str);
|
prof_handle_room_member_offline(room, nick, "offline", status_str);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
xmpp_stanza_t *show = xmpp_stanza_get_child_by_name(stanza, STANZA_NAME_SHOW);
|
show_str = stanza_get_show(stanza, "online");
|
||||||
if (show != NULL) {
|
|
||||||
show_str = xmpp_stanza_get_text(show);
|
|
||||||
} else {
|
|
||||||
show_str = "online";
|
|
||||||
}
|
|
||||||
if (!muc_get_roster_received(room)) {
|
if (!muc_get_roster_received(room)) {
|
||||||
muc_add_to_roster(room, nick, show_str, status_str, caps_key);
|
muc_add_to_roster(room, nick, show_str, status_str, caps_key);
|
||||||
} else {
|
} else {
|
||||||
|
@ -280,6 +280,32 @@ stanza_get_delay(xmpp_stanza_t * const stanza, GTimeVal *tv_stamp)
|
|||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char *
|
||||||
|
stanza_get_status(xmpp_stanza_t *stanza, char *def)
|
||||||
|
{
|
||||||
|
xmpp_stanza_t *status =
|
||||||
|
xmpp_stanza_get_child_by_name(stanza, STANZA_NAME_STATUS);
|
||||||
|
|
||||||
|
if (status != NULL) {
|
||||||
|
return xmpp_stanza_get_text(status);
|
||||||
|
} else {
|
||||||
|
return def;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
char *
|
||||||
|
stanza_get_show(xmpp_stanza_t *stanza, char *def)
|
||||||
|
{
|
||||||
|
xmpp_stanza_t *show =
|
||||||
|
xmpp_stanza_get_child_by_name(stanza, STANZA_NAME_SHOW);
|
||||||
|
|
||||||
|
if (show != NULL) {
|
||||||
|
return xmpp_stanza_get_text(show);
|
||||||
|
} else {
|
||||||
|
return def;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
gboolean
|
gboolean
|
||||||
stanza_is_muc_presence(xmpp_stanza_t * const stanza)
|
stanza_is_muc_presence(xmpp_stanza_t * const stanza)
|
||||||
{
|
{
|
||||||
|
@ -167,4 +167,7 @@ xmpp_stanza_t * stanza_create_software_version_iq(xmpp_ctx_t *ctx, const char *
|
|||||||
xmpp_stanza_t * stanza_create_disco_items_iq(xmpp_ctx_t *ctx, const char * const id,
|
xmpp_stanza_t * stanza_create_disco_items_iq(xmpp_ctx_t *ctx, const char * const id,
|
||||||
const char * const jid);
|
const char * const jid);
|
||||||
|
|
||||||
|
char * stanza_get_status(xmpp_stanza_t *stanza, char *def);
|
||||||
|
char * stanza_get_show(xmpp_stanza_t *stanza, char *def);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user