mirror of
https://github.com/profanity-im/profanity.git
synced 2025-01-03 14:57:42 -05:00
Handling paused status
This commit is contained in:
parent
81dd0a1556
commit
5792cd597d
@ -28,6 +28,7 @@
|
|||||||
#include "chat_session.h"
|
#include "chat_session.h"
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
|
|
||||||
|
#define PAUSED_TIMOUT 10.0
|
||||||
#define INACTIVE_TIMOUT 120.0
|
#define INACTIVE_TIMOUT 120.0
|
||||||
#define GONE_TIMOUT 600.0
|
#define GONE_TIMOUT 600.0
|
||||||
|
|
||||||
@ -38,6 +39,8 @@ static void _chat_session_free(ChatSession session);
|
|||||||
typedef enum {
|
typedef enum {
|
||||||
CHAT_STATE_STARTED,
|
CHAT_STATE_STARTED,
|
||||||
CHAT_STATE_ACTIVE,
|
CHAT_STATE_ACTIVE,
|
||||||
|
CHAT_STATE_PAUSED,
|
||||||
|
CHAT_STATE_COMPOSING,
|
||||||
CHAT_STATE_INACTIVE,
|
CHAT_STATE_INACTIVE,
|
||||||
CHAT_STATE_GONE
|
CHAT_STATE_GONE
|
||||||
} chat_state_t;
|
} chat_state_t;
|
||||||
@ -85,14 +88,17 @@ chat_session_start(const char * const recipient, gboolean recipient_supports)
|
|||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
chat_session_set_active(const char * const recipient)
|
chat_session_set_composing(const char * const recipient)
|
||||||
{
|
{
|
||||||
ChatSession session = g_hash_table_lookup(sessions, recipient);
|
ChatSession session = g_hash_table_lookup(sessions, recipient);
|
||||||
|
|
||||||
if (session == NULL) {
|
if (session == NULL) {
|
||||||
log_error("No chat session found for %s.", recipient);
|
log_error("No chat session found for %s.", recipient);
|
||||||
} else {
|
} else {
|
||||||
session->state = CHAT_STATE_ACTIVE;
|
if (session->state != CHAT_STATE_COMPOSING) {
|
||||||
|
session->sent = FALSE;
|
||||||
|
}
|
||||||
|
session->state = CHAT_STATE_COMPOSING;
|
||||||
g_timer_start(session->active_timer);
|
g_timer_start(session->active_timer);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -118,6 +124,11 @@ chat_session_no_activity(const char * const recipient)
|
|||||||
session->sent = FALSE;
|
session->sent = FALSE;
|
||||||
}
|
}
|
||||||
session->state = CHAT_STATE_INACTIVE;
|
session->state = CHAT_STATE_INACTIVE;
|
||||||
|
} else if (elapsed > PAUSED_TIMOUT) {
|
||||||
|
if (session->state != CHAT_STATE_PAUSED) {
|
||||||
|
session->sent = FALSE;
|
||||||
|
}
|
||||||
|
session->state = CHAT_STATE_PAUSED;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -167,6 +178,32 @@ chat_session_inactive(const char * const recipient)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
chat_session_set_active(const char * const recipient)
|
||||||
|
{
|
||||||
|
ChatSession session = g_hash_table_lookup(sessions, recipient);
|
||||||
|
|
||||||
|
if (session == NULL) {
|
||||||
|
log_error("No chat session found for %s.", recipient);
|
||||||
|
} else {
|
||||||
|
session->state = CHAT_STATE_ACTIVE;
|
||||||
|
session->sent = FALSE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
gboolean
|
||||||
|
chat_session_paused(const char * const recipient)
|
||||||
|
{
|
||||||
|
ChatSession session = g_hash_table_lookup(sessions, recipient);
|
||||||
|
|
||||||
|
if (session == NULL) {
|
||||||
|
log_error("No chat session found for %s.", recipient);
|
||||||
|
return FALSE;
|
||||||
|
} else {
|
||||||
|
return (session->state == CHAT_STATE_PAUSED);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
gboolean
|
gboolean
|
||||||
chat_session_gone(const char * const recipient)
|
chat_session_gone(const char * const recipient)
|
||||||
{
|
{
|
||||||
|
@ -37,9 +37,11 @@ gboolean chat_session_get_recipient_supports(const char * const recipient);
|
|||||||
void chat_session_set_recipient_supports(const char * const recipient,
|
void chat_session_set_recipient_supports(const char * const recipient,
|
||||||
gboolean recipient_supports);
|
gboolean recipient_supports);
|
||||||
|
|
||||||
void chat_session_set_active(const char * const recipient);
|
void chat_session_set_composing(const char * const recipient);
|
||||||
void chat_session_no_activity(const char * const recipient);
|
void chat_session_no_activity(const char * const recipient);
|
||||||
gboolean chat_session_inactive(const char * const recipient);
|
gboolean chat_session_inactive(const char * const recipient);
|
||||||
|
void chat_session_set_active(const char * const recipient);
|
||||||
|
gboolean chat_session_paused(const char * const recipient);
|
||||||
gboolean chat_session_gone(const char * const recipient);
|
gboolean chat_session_gone(const char * const recipient);
|
||||||
void chat_session_set_sent(const char * const recipient);
|
void chat_session_set_sent(const char * const recipient);
|
||||||
gboolean chat_session_get_sent(const char * const recipient);
|
gboolean chat_session_get_sent(const char * const recipient);
|
||||||
|
@ -152,6 +152,9 @@ inp_get_char(int *ch, char *input, int *size)
|
|||||||
} else if (chat_session_inactive(recipient) &&
|
} else if (chat_session_inactive(recipient) &&
|
||||||
!chat_session_get_sent(recipient)) {
|
!chat_session_get_sent(recipient)) {
|
||||||
jabber_send_inactive(recipient);
|
jabber_send_inactive(recipient);
|
||||||
|
} else if (chat_session_paused(recipient) &&
|
||||||
|
!chat_session_get_sent(recipient)) {
|
||||||
|
jabber_send_paused(recipient);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -160,7 +163,11 @@ inp_get_char(int *ch, char *input, int *size)
|
|||||||
if (*ch != ERR) {
|
if (*ch != ERR) {
|
||||||
if (win_in_chat()) {
|
if (win_in_chat()) {
|
||||||
char *recipient = win_get_recipient();
|
char *recipient = win_get_recipient();
|
||||||
chat_session_set_active(recipient);
|
chat_session_set_composing(recipient);
|
||||||
|
if (!chat_session_get_sent(recipient) ||
|
||||||
|
chat_session_paused(recipient)) {
|
||||||
|
jabber_send_composing(recipient);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
43
src/jabber.c
43
src/jabber.c
@ -164,6 +164,7 @@ jabber_send(const char * const msg, const char * const recipient)
|
|||||||
|
|
||||||
// always send <active/> with messages when recipient supports chat states
|
// always send <active/> with messages when recipient supports chat states
|
||||||
if (chat_session_get_recipient_supports(recipient)) {
|
if (chat_session_get_recipient_supports(recipient)) {
|
||||||
|
chat_session_set_active(recipient);
|
||||||
active = xmpp_stanza_new(jabber_conn.ctx);
|
active = xmpp_stanza_new(jabber_conn.ctx);
|
||||||
xmpp_stanza_set_name(active, "active");
|
xmpp_stanza_set_name(active, "active");
|
||||||
xmpp_stanza_set_ns(active, "http://jabber.org/protocol/chatstates");
|
xmpp_stanza_set_ns(active, "http://jabber.org/protocol/chatstates");
|
||||||
@ -202,6 +203,48 @@ jabber_send_inactive(const char * const recipient)
|
|||||||
chat_session_set_sent(recipient);
|
chat_session_set_sent(recipient);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
jabber_send_composing(const char * const recipient)
|
||||||
|
{
|
||||||
|
xmpp_stanza_t *message, *composing;
|
||||||
|
|
||||||
|
message = xmpp_stanza_new(jabber_conn.ctx);
|
||||||
|
xmpp_stanza_set_name(message, "message");
|
||||||
|
xmpp_stanza_set_type(message, "chat");
|
||||||
|
xmpp_stanza_set_attribute(message, "to", recipient);
|
||||||
|
|
||||||
|
composing = xmpp_stanza_new(jabber_conn.ctx);
|
||||||
|
xmpp_stanza_set_name(composing, "composing");
|
||||||
|
xmpp_stanza_set_ns(composing, "http://jabber.org/protocol/chatstates");
|
||||||
|
xmpp_stanza_add_child(message, composing);
|
||||||
|
|
||||||
|
xmpp_send(jabber_conn.conn, message);
|
||||||
|
xmpp_stanza_release(message);
|
||||||
|
|
||||||
|
chat_session_set_sent(recipient);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
jabber_send_paused(const char * const recipient)
|
||||||
|
{
|
||||||
|
xmpp_stanza_t *message, *paused;
|
||||||
|
|
||||||
|
message = xmpp_stanza_new(jabber_conn.ctx);
|
||||||
|
xmpp_stanza_set_name(message, "message");
|
||||||
|
xmpp_stanza_set_type(message, "chat");
|
||||||
|
xmpp_stanza_set_attribute(message, "to", recipient);
|
||||||
|
|
||||||
|
paused = xmpp_stanza_new(jabber_conn.ctx);
|
||||||
|
xmpp_stanza_set_name(paused, "paused");
|
||||||
|
xmpp_stanza_set_ns(paused, "http://jabber.org/protocol/chatstates");
|
||||||
|
xmpp_stanza_add_child(message, paused);
|
||||||
|
|
||||||
|
xmpp_send(jabber_conn.conn, message);
|
||||||
|
xmpp_stanza_release(message);
|
||||||
|
|
||||||
|
chat_session_set_sent(recipient);
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
jabber_send_gone(const char * const recipient)
|
jabber_send_gone(const char * const recipient)
|
||||||
{
|
{
|
||||||
|
@ -48,6 +48,8 @@ void jabber_process_events(void);
|
|||||||
void jabber_subscribe(const char * const recipient);
|
void jabber_subscribe(const char * const recipient);
|
||||||
void jabber_send(const char * const msg, const char * const recipient);
|
void jabber_send(const char * const msg, const char * const recipient);
|
||||||
void jabber_send_inactive(const char * const recipient);
|
void jabber_send_inactive(const char * const recipient);
|
||||||
|
void jabber_send_composing(const char * const recipient);
|
||||||
|
void jabber_send_paused(const char * const recipient);
|
||||||
void jabber_send_gone(const char * const recipient);
|
void jabber_send_gone(const char * const recipient);
|
||||||
void jabber_update_presence(jabber_presence_t status, const char * const msg);
|
void jabber_update_presence(jabber_presence_t status, const char * const msg);
|
||||||
const char * jabber_get_jid(void);
|
const char * jabber_get_jid(void);
|
||||||
|
Loading…
Reference in New Issue
Block a user