about summary refs log tree commit diff stats
path: root/src/chat_session.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/chat_session.c')
-rw-r--r--src/chat_session.c196
1 files changed, 127 insertions, 69 deletions
diff --git a/src/chat_session.c b/src/chat_session.c
index 5aa37d4b..49a89a5d 100644
--- a/src/chat_session.c
+++ b/src/chat_session.c
@@ -38,9 +38,9 @@
 #include <glib.h>
 
 #include "chat_session.h"
-
 #include "config/preferences.h"
 #include "log.h"
+#include "xmpp/xmpp.h"
 
 #define PAUSED_TIMOUT 10.0
 #define INACTIVE_TIMOUT 30.0
@@ -65,6 +65,19 @@ typedef struct chat_session_t {
 
 static GHashTable *sessions;
 
+static void _chat_session_new(const char * const recipient, gboolean recipient_supports);
+static gboolean _chat_session_exists(const char * const recipient);
+static void _chat_session_set_composing(const char * const recipient);
+static void _chat_session_set_sent(const char * const recipient);
+static gboolean _chat_session_get_sent(const char * const recipient);
+static void _chat_session_end(const char * const recipient);
+static gboolean _chat_session_is_inactive(const char * const recipient);
+static void _chat_session_set_active(const char * const recipient);
+static gboolean _chat_session_is_paused(const char * const recipient);
+static gboolean _chat_session_is_gone(const char * const recipient);
+static void _chat_session_set_gone(const char * const recipient);
+static gboolean _chat_session_get_recipient_supports(const char * const recipient);
+static void _chat_session_set_recipient_supports(const char * const recipient, gboolean recipient_supports);
 static void _chat_session_free(ChatSession *session);
 
 void
@@ -81,8 +94,8 @@ chat_sessions_clear(void)
         g_hash_table_remove_all(sessions);
 }
 
-void
-chat_session_new(const char * const recipient, gboolean recipient_supports)
+static void
+_chat_session_new(const char * const recipient, gboolean recipient_supports)
 {
     ChatSession *new_session = malloc(sizeof(struct chat_session_t));
     new_session->recipient = strdup(recipient);
@@ -93,8 +106,8 @@ chat_session_new(const char * const recipient, gboolean recipient_supports)
     g_hash_table_insert(sessions, strdup(recipient), new_session);
 }
 
-gboolean
-chat_session_exists(const char * const recipient)
+static gboolean
+_chat_session_exists(const char * const recipient)
 {
     ChatSession *session = g_hash_table_lookup(sessions, recipient);
 
@@ -105,8 +118,8 @@ chat_session_exists(const char * const recipient)
     }
 }
 
-void
-chat_session_set_composing(const char * const recipient)
+static void
+_chat_session_set_composing(const char * const recipient)
 {
     ChatSession *session = g_hash_table_lookup(sessions, recipient);
 
@@ -119,40 +132,8 @@ chat_session_set_composing(const char * const recipient)
     }
 }
 
-void
-chat_session_no_activity(const char * const recipient)
-{
-    ChatSession *session = g_hash_table_lookup(sessions, recipient);
-
-    if (session != NULL) {
-        if (session->active_timer != NULL) {
-            gdouble elapsed = g_timer_elapsed(session->active_timer, NULL);
-
-            if ((prefs_get_gone() != 0) && (elapsed > (prefs_get_gone() * 60.0))) {
-                if (session->state != CHAT_STATE_GONE) {
-                    session->sent = FALSE;
-                }
-                session->state = CHAT_STATE_GONE;
-
-            } else if (elapsed > INACTIVE_TIMOUT) {
-                if (session->state != CHAT_STATE_INACTIVE) {
-                    session->sent = FALSE;
-                }
-                session->state = CHAT_STATE_INACTIVE;
-
-            } else if (elapsed > PAUSED_TIMOUT) {
-
-                if (session->state == CHAT_STATE_COMPOSING) {
-                    session->sent = FALSE;
-                    session->state = CHAT_STATE_PAUSED;
-                }
-            }
-        }
-    }
-}
-
-void
-chat_session_set_sent(const char * const recipient)
+static void
+_chat_session_set_sent(const char * const recipient)
 {
     ChatSession *session = g_hash_table_lookup(sessions, recipient);
 
@@ -161,8 +142,8 @@ chat_session_set_sent(const char * const recipient)
     }
 }
 
-gboolean
-chat_session_get_sent(const char * const recipient)
+static gboolean
+_chat_session_get_sent(const char * const recipient)
 {
     ChatSession *session = g_hash_table_lookup(sessions, recipient);
 
@@ -173,14 +154,14 @@ chat_session_get_sent(const char * const recipient)
     }
 }
 
-void
-chat_session_end(const char * const recipient)
+static void
+_chat_session_end(const char * const recipient)
 {
     g_hash_table_remove(sessions, recipient);
 }
 
-gboolean
-chat_session_is_inactive(const char * const recipient)
+static gboolean
+_chat_session_is_inactive(const char * const recipient)
 {
     ChatSession *session = g_hash_table_lookup(sessions, recipient);
 
@@ -191,8 +172,8 @@ chat_session_is_inactive(const char * const recipient)
     }
 }
 
-void
-chat_session_set_active(const char * const recipient)
+static void
+_chat_session_set_active(const char * const recipient)
 {
     ChatSession *session = g_hash_table_lookup(sessions, recipient);
 
@@ -203,8 +184,8 @@ chat_session_set_active(const char * const recipient)
     }
 }
 
-gboolean
-chat_session_is_paused(const char * const recipient)
+static gboolean
+_chat_session_is_paused(const char * const recipient)
 {
     ChatSession *session = g_hash_table_lookup(sessions, recipient);
 
@@ -215,8 +196,8 @@ chat_session_is_paused(const char * const recipient)
     }
 }
 
-gboolean
-chat_session_is_gone(const char * const recipient)
+static gboolean
+_chat_session_is_gone(const char * const recipient)
 {
     ChatSession *session = g_hash_table_lookup(sessions, recipient);
 
@@ -227,8 +208,8 @@ chat_session_is_gone(const char * const recipient)
     }
 }
 
-void
-chat_session_set_gone(const char * const recipient)
+static void
+_chat_session_set_gone(const char * const recipient)
 {
     ChatSession *session = g_hash_table_lookup(sessions, recipient);
 
@@ -237,8 +218,8 @@ chat_session_set_gone(const char * const recipient)
     }
 }
 
-gboolean
-chat_session_get_recipient_supports(const char * const recipient)
+static gboolean
+_chat_session_get_recipient_supports(const char * const recipient)
 {
     ChatSession *session = g_hash_table_lookup(sessions, recipient);
 
@@ -249,9 +230,8 @@ chat_session_get_recipient_supports(const char * const recipient)
     }
 }
 
-void
-chat_session_set_recipient_supports(const char * const recipient,
-    gboolean recipient_supports)
+static void
+_chat_session_set_recipient_supports(const char * const recipient, gboolean recipient_supports)
 {
     ChatSession *session = g_hash_table_lookup(sessions, recipient);
 
@@ -265,11 +245,11 @@ chat_session_on_message_send(const char * const barejid)
 {
     gboolean send_state = FALSE;
     if (prefs_get_boolean(PREF_STATES)) {
-        if (!chat_session_exists(barejid)) {
-            chat_session_new(barejid, TRUE);
+        if (!_chat_session_exists(barejid)) {
+            _chat_session_new(barejid, TRUE);
         }
-        if (chat_session_get_recipient_supports(barejid)) {
-            chat_session_set_active(barejid);
+        if (_chat_session_get_recipient_supports(barejid)) {
+            _chat_session_set_active(barejid);
             send_state = TRUE;
         }
     }
@@ -280,10 +260,10 @@ chat_session_on_message_send(const char * const barejid)
 void
 chat_session_on_incoming_message(const char * const barejid, gboolean recipient_supports)
 {
-    if (!chat_session_exists(barejid)) {
-        chat_session_new(barejid, recipient_supports);
+    if (!_chat_session_exists(barejid)) {
+        _chat_session_new(barejid, recipient_supports);
     } else {
-        chat_session_set_recipient_supports(barejid, recipient_supports);
+        _chat_session_set_recipient_supports(barejid, recipient_supports);
     }
 }
 
@@ -291,8 +271,86 @@ void
 chat_session_on_window_open(const char * const barejid)
 {
     if (prefs_get_boolean(PREF_STATES)) {
-        if (!chat_session_exists(barejid)) {
-            chat_session_new(barejid, TRUE);
+        if (!_chat_session_exists(barejid)) {
+            _chat_session_new(barejid, TRUE);
+        }
+    }
+}
+
+void
+chat_session_on_window_close(const char * const barejid)
+{
+    if (prefs_get_boolean(PREF_STATES)) {
+        // send <gone/> chat state before closing
+        if (_chat_session_get_recipient_supports(barejid)) {
+            _chat_session_set_gone(barejid);
+            message_send_gone(barejid);
+            _chat_session_set_sent(barejid);
+            _chat_session_end(barejid);
+        }
+    }
+}
+
+void
+chat_session_on_cancel(const char * const jid)
+{
+    if (prefs_get_boolean(PREF_STATES) && _chat_session_exists(jid)) {
+        _chat_session_set_recipient_supports(jid, FALSE);
+    }
+}
+
+void
+chat_session_on_activity(const char * const barejid)
+{
+    if (_chat_session_get_recipient_supports(barejid)) {
+        _chat_session_set_composing(barejid);
+        if (!_chat_session_get_sent(barejid) || _chat_session_is_paused(barejid)) {
+            message_send_composing(barejid);
+            _chat_session_set_sent(barejid);
+        }
+    }
+}
+
+void
+chat_session_on_inactivity(const char * const barejid)
+{
+    if (_chat_session_get_recipient_supports(barejid)) {
+        ChatSession *session = g_hash_table_lookup(sessions, barejid);
+        if (session != NULL) {
+            if (session->active_timer != NULL) {
+                gdouble elapsed = g_timer_elapsed(session->active_timer, NULL);
+
+                if ((prefs_get_gone() != 0) && (elapsed > (prefs_get_gone() * 60.0))) {
+                    if (session->state != CHAT_STATE_GONE) {
+                        session->sent = FALSE;
+                    }
+                    session->state = CHAT_STATE_GONE;
+
+                } else if (elapsed > INACTIVE_TIMOUT) {
+                    if (session->state != CHAT_STATE_INACTIVE) {
+                        session->sent = FALSE;
+                    }
+                    session->state = CHAT_STATE_INACTIVE;
+
+                } else if (elapsed > PAUSED_TIMOUT) {
+
+                    if (session->state == CHAT_STATE_COMPOSING) {
+                        session->sent = FALSE;
+                        session->state = CHAT_STATE_PAUSED;
+                    }
+                }
+            }
+        }
+
+        if (_chat_session_is_gone(barejid) && !_chat_session_get_sent(barejid)) {
+            message_send_gone(barejid);
+            _chat_session_set_sent(barejid);
+        } else if (_chat_session_is_inactive(barejid) && !_chat_session_get_sent(barejid)) {
+            message_send_inactive(barejid);
+            _chat_session_set_sent(barejid);
+        } else if (prefs_get_boolean(PREF_OUTTYPE) && _chat_session_is_paused(barejid) && !_chat_session_get_sent(barejid)) {
+            message_send_paused(barejid);
+            _chat_session_set_sent(barejid);
         }
     }
 }