Port JabberPresence from time_t to GDateTime

Thu, 13 Jan 2022 22:33:15 -0600

author
Gary Kramlich <grim@reaperworld.com>
date
Thu, 13 Jan 2022 22:33:15 -0600
changeset 41244
5535c6fdd135
parent 41243
53b46590623f
child 41245
53eea15447bd

Port JabberPresence from time_t to GDateTime

Testing Done:
Connected and XMPP account, sent some messages, and verified that a carbon message showed up fine.

Reviewed at https://reviews.imfreedom.org/r/1213/

libpurple/protocols/jabber/chat.c file | annotate | diff | comparison | revisions
libpurple/protocols/jabber/chat.h file | annotate | diff | comparison | revisions
libpurple/protocols/jabber/presence.c file | annotate | diff | comparison | revisions
libpurple/protocols/jabber/presence.h file | annotate | diff | comparison | revisions
--- a/libpurple/protocols/jabber/chat.c	Thu Jan 13 20:35:29 2022 -0600
+++ b/libpurple/protocols/jabber/chat.c	Thu Jan 13 22:33:15 2022 -0600
@@ -394,6 +394,9 @@
 	g_free(chat->handle);
 	g_hash_table_destroy(chat->members);
 	g_hash_table_destroy(chat->components);
+
+	g_clear_pointer(&chat->joined, g_date_time_unref);
+
 	g_free(chat);
 }
 
--- a/libpurple/protocols/jabber/chat.h	Thu Jan 13 20:35:29 2022 -0600
+++ b/libpurple/protocols/jabber/chat.h	Thu Jan 13 22:33:15 2022 -0600
@@ -49,7 +49,7 @@
 	void *config_dialog_handle;
 	GHashTable *members;
 	gboolean left;
-	time_t joined;
+	GDateTime *joined;
 } JabberChat;
 
 GList *jabber_chat_info(PurpleProtocolChat *protocol_chat, PurpleConnection *connection);
--- a/libpurple/protocols/jabber/presence.c	Thu Jan 13 20:35:29 2022 -0600
+++ b/libpurple/protocols/jabber/presence.c	Thu Jan 13 22:33:15 2022 -0600
@@ -591,15 +591,32 @@
 
 		jabber_chat_track_handle(chat, presence->jid_from->resource, jid, affiliation, role);
 
-		if(!jabber_chat_find_buddy(chat->conv, presence->jid_from->resource))
-			purple_chat_conversation_add_user(chat->conv, presence->jid_from->resource,
-					jid, flags, chat->joined > 0 && ((!presence->delayed) || (presence->sent > chat->joined)));
-		else
+		if(!jabber_chat_find_buddy(chat->conv, presence->jid_from->resource)) {
+			gboolean new_arrival = FALSE;
+
+			if(chat->joined != NULL) {
+				gint newer = -1;
+
+				if(presence->sent != NULL) {
+					newer = g_date_time_compare(presence->sent, chat->joined);
+				}
+
+				if(!presence->delayed || newer > 0) {
+					new_arrival = TRUE;
+				}
+			}
+
+			purple_chat_conversation_add_user(chat->conv,
+			                                  presence->jid_from->resource,
+			                                  jid, flags, new_arrival);
+		} else {
 			purple_chat_user_set_flags(purple_chat_conversation_find_user(chat->conv, presence->jid_from->resource),
 					flags);
+		}
 
-		if (is_our_resource && chat->joined == 0)
-			chat->joined = time(NULL);
+		if (is_our_resource && chat->joined == NULL) {
+			chat->joined = g_date_time_new_now_utc();
+		}
 
 	} else if (presence->type == JABBER_PRESENCE_UNAVAILABLE) {
 		gboolean nick_change = FALSE;
@@ -868,7 +885,7 @@
 	memset(&presence, 0, sizeof(presence));
 	/* defaults */
 	presence.state = JABBER_BUDDY_STATE_UNKNOWN;
-	presence.sent = time(NULL);
+	presence.sent = g_date_time_new_now_utc();
 	/* interesting values */
 	presence.from = purple_xmlnode_get_attrib(packet, "from");
 	presence.to   = purple_xmlnode_get_attrib(packet, "to");
@@ -974,8 +991,15 @@
 	}
 
 	if (presence.delayed && presence.idle && presence.adjust_idle_for_delay) {
+		GDateTime *now = g_date_time_new_now_utc();
+		GTimeSpan difference = 0;
+
+		difference = g_date_time_difference(now, presence.sent);
+
+		g_date_time_unref(now);
+
 		/* Delayed and idle, so update idle time */
-		presence.idle = presence.idle + (time(NULL) - presence.sent);
+		presence.idle = presence.idle + (difference / G_TIME_SPAN_SECOND);
 	}
 
 	/* TODO: Handle tracking jb(r) here? */
@@ -1026,6 +1050,7 @@
 	g_free(presence.vcard_avatar_hash);
 	g_free(presence.nickname);
 	jabber_id_free(presence.jid_from);
+	g_clear_pointer(&presence.sent, g_date_time_unref);
 }
 
 void jabber_presence_subscription_set(JabberStream *js, const char *who, const char *type)
@@ -1118,9 +1143,13 @@
 static void
 parse_delay(JabberStream *js, JabberPresence *presence, PurpleXmlNode *delay)
 {
+	GTimeZone *tz = g_time_zone_new_utc();
 	const char *stamp = purple_xmlnode_get_attrib(delay, "stamp");
+
 	presence->delayed = TRUE;
-	presence->sent = purple_str_to_time(stamp, TRUE, NULL, NULL, NULL);
+	presence->sent = g_date_time_new_from_iso8601(stamp, tz);
+
+	g_time_zone_unref(tz);
 }
 
 static void
--- a/libpurple/protocols/jabber/presence.h	Thu Jan 13 20:35:29 2022 -0600
+++ b/libpurple/protocols/jabber/presence.h	Thu Jan 13 22:33:15 2022 -0600
@@ -71,7 +71,7 @@
 	char *nickname;
 
 	gboolean delayed;
-	time_t sent;
+	GDateTime *sent;
 	int idle;
 	gboolean adjust_idle_for_delay;
 };

mercurial