mirror of
https://github.com/profanity-im/profanity.git
synced 2025-01-03 14:57:42 -05:00
Use resource in chat sessions
This commit is contained in:
parent
4898ed10a4
commit
42a5c431c7
@ -66,11 +66,11 @@ typedef struct chat_session_t {
|
|||||||
static GHashTable *sessions;
|
static GHashTable *sessions;
|
||||||
|
|
||||||
static ChatSession*
|
static ChatSession*
|
||||||
_chat_session_new(const char * const barejid, gboolean supported)
|
_chat_session_new(const char * const barejid, const char * const resource, gboolean supported)
|
||||||
{
|
{
|
||||||
ChatSession *new_session = malloc(sizeof(struct chat_session_t));
|
ChatSession *new_session = malloc(sizeof(struct chat_session_t));
|
||||||
new_session->barejid = strdup(barejid);
|
new_session->barejid = strdup(barejid);
|
||||||
new_session->resource = NULL;
|
new_session->resource = strdup(resource);
|
||||||
new_session->supported = supported;
|
new_session->supported = supported;
|
||||||
new_session->state = CHAT_STATE_STARTED;
|
new_session->state = CHAT_STATE_STARTED;
|
||||||
new_session->active_timer = g_timer_new();
|
new_session->active_timer = g_timer_new();
|
||||||
@ -84,6 +84,7 @@ _chat_session_free(ChatSession *session)
|
|||||||
{
|
{
|
||||||
if (session != NULL) {
|
if (session != NULL) {
|
||||||
free(session->barejid);
|
free(session->barejid);
|
||||||
|
free(session->resource);
|
||||||
if (session->active_timer != NULL) {
|
if (session->active_timer != NULL) {
|
||||||
g_timer_destroy(session->active_timer);
|
g_timer_destroy(session->active_timer);
|
||||||
session->active_timer = NULL;
|
session->active_timer = NULL;
|
||||||
@ -106,18 +107,32 @@ chat_sessions_clear(void)
|
|||||||
g_hash_table_remove_all(sessions);
|
g_hash_table_remove_all(sessions);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
gboolean
|
||||||
|
chat_session_exists(const char * const barejid)
|
||||||
|
{
|
||||||
|
ChatSession *session = g_hash_table_lookup(sessions, barejid);
|
||||||
|
return (session != NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
char*
|
||||||
|
chat_session_get_resource(const char * const barejid)
|
||||||
|
{
|
||||||
|
ChatSession *session = g_hash_table_lookup(sessions, barejid);
|
||||||
|
if (session) {
|
||||||
|
return session->resource;
|
||||||
|
} else {
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
gboolean
|
gboolean
|
||||||
chat_session_on_message_send(const char * const barejid)
|
chat_session_on_message_send(const char * const barejid)
|
||||||
{
|
{
|
||||||
gboolean send_state = FALSE;
|
gboolean send_state = FALSE;
|
||||||
|
|
||||||
if (prefs_get_boolean(PREF_STATES)) {
|
if (prefs_get_boolean(PREF_STATES)) {
|
||||||
ChatSession *session = g_hash_table_lookup(sessions, barejid);
|
ChatSession *session = g_hash_table_lookup(sessions, barejid);
|
||||||
if (!session) {
|
if (session && session->supported) {
|
||||||
session = _chat_session_new(barejid, TRUE);
|
|
||||||
g_hash_table_insert(sessions, strdup(barejid), session);
|
|
||||||
|
|
||||||
}
|
|
||||||
if (session->supported) {
|
|
||||||
session->state = CHAT_STATE_ACTIVE;
|
session->state = CHAT_STATE_ACTIVE;
|
||||||
g_timer_start(session->active_timer);
|
g_timer_start(session->active_timer);
|
||||||
session->sent = TRUE;
|
session->sent = TRUE;
|
||||||
@ -129,26 +144,28 @@ chat_session_on_message_send(const char * const barejid)
|
|||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
chat_session_on_incoming_message(const char * const barejid, gboolean supported)
|
chat_session_on_incoming_message(const char * const barejid, const char * const resource, gboolean supported)
|
||||||
{
|
{
|
||||||
ChatSession *session = g_hash_table_lookup(sessions, barejid);
|
ChatSession *session = g_hash_table_lookup(sessions, barejid);
|
||||||
if (!session) {
|
|
||||||
session = _chat_session_new(barejid, supported);
|
|
||||||
g_hash_table_insert(sessions, strdup(barejid), session);
|
|
||||||
} else {
|
|
||||||
session->supported = supported;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
if (resource) {
|
||||||
chat_session_on_window_open(const char * const barejid)
|
if (session) {
|
||||||
{
|
if (g_strcmp0(session->resource, resource) != 0) {
|
||||||
if (prefs_get_boolean(PREF_STATES)) {
|
log_info("Replacing chat session %s/%s, with new session %s/%s", session->barejid, session->resource, barejid, resource);
|
||||||
ChatSession *session = g_hash_table_lookup(sessions, barejid);
|
g_hash_table_remove(sessions, session);
|
||||||
if (!session) {
|
session = _chat_session_new(barejid, resource, supported);
|
||||||
session = _chat_session_new(barejid, TRUE);
|
g_hash_table_insert(sessions, strdup(barejid), session);
|
||||||
|
} else {
|
||||||
|
session->supported = supported;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
log_info("Starting chat session with %s/%s", barejid, resource);
|
||||||
|
session = _chat_session_new(barejid, resource, supported);
|
||||||
g_hash_table_insert(sessions, strdup(barejid), session);
|
g_hash_table_insert(sessions, strdup(barejid), session);
|
||||||
}
|
}
|
||||||
|
} else if (session) {
|
||||||
|
log_info("Ending chat session with %s/%s, message received with no resource", session->barejid, session->resource);
|
||||||
|
g_hash_table_remove(sessions, session);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -158,7 +175,7 @@ chat_session_on_window_close(const char * const barejid)
|
|||||||
if (prefs_get_boolean(PREF_STATES)) {
|
if (prefs_get_boolean(PREF_STATES)) {
|
||||||
ChatSession *session = g_hash_table_lookup(sessions, barejid);
|
ChatSession *session = g_hash_table_lookup(sessions, barejid);
|
||||||
// send <gone/> chat state before closing
|
// send <gone/> chat state before closing
|
||||||
if (session->supported) {
|
if (session && session->supported) {
|
||||||
session->state = CHAT_STATE_GONE;
|
session->state = CHAT_STATE_GONE;
|
||||||
message_send_gone(barejid);
|
message_send_gone(barejid);
|
||||||
session->sent = TRUE;
|
session->sent = TRUE;
|
||||||
@ -182,19 +199,19 @@ void
|
|||||||
chat_session_on_activity(const char * const barejid)
|
chat_session_on_activity(const char * const barejid)
|
||||||
{
|
{
|
||||||
ChatSession *session = g_hash_table_lookup(sessions, barejid);
|
ChatSession *session = g_hash_table_lookup(sessions, barejid);
|
||||||
if (session) {
|
if (session && session->supported) {
|
||||||
if (session->supported) {
|
if (session->state != CHAT_STATE_COMPOSING) {
|
||||||
if (session->state != CHAT_STATE_COMPOSING) {
|
session->sent = FALSE;
|
||||||
session->sent = FALSE;
|
}
|
||||||
}
|
|
||||||
|
|
||||||
session->state = CHAT_STATE_COMPOSING;
|
session->state = CHAT_STATE_COMPOSING;
|
||||||
g_timer_start(session->active_timer);
|
g_timer_start(session->active_timer);
|
||||||
|
|
||||||
if (!session->sent || session->state == CHAT_STATE_PAUSED) {
|
if (!session->sent || session->state == CHAT_STATE_PAUSED) {
|
||||||
message_send_composing(barejid);
|
Jid *jidp = jid_create_from_bare_and_resource(session->barejid, session->resource);
|
||||||
session->sent = TRUE;
|
message_send_composing(jidp->fulljid);
|
||||||
}
|
session->sent = TRUE;
|
||||||
|
jid_destroy(jidp);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -228,16 +245,18 @@ chat_session_on_inactivity(const char * const barejid)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (session->sent == FALSE) {
|
if (session->sent == FALSE) {
|
||||||
|
Jid *jidp = jid_create_from_bare_and_resource(session->barejid, session->resource);
|
||||||
if (session->state == CHAT_STATE_GONE) {
|
if (session->state == CHAT_STATE_GONE) {
|
||||||
message_send_gone(barejid);
|
message_send_gone(jidp->fulljid);
|
||||||
session->sent = TRUE;
|
session->sent = TRUE;
|
||||||
} else if (session->state == CHAT_STATE_INACTIVE) {
|
} else if (session->state == CHAT_STATE_INACTIVE) {
|
||||||
message_send_inactive(barejid);
|
message_send_inactive(jidp->fulljid);
|
||||||
session->sent = TRUE;
|
session->sent = TRUE;
|
||||||
} else if (session->state == CHAT_STATE_PAUSED && prefs_get_boolean(PREF_OUTTYPE)) {
|
} else if (session->state == CHAT_STATE_PAUSED && prefs_get_boolean(PREF_OUTTYPE)) {
|
||||||
message_send_paused(barejid);
|
message_send_paused(jidp->fulljid);
|
||||||
session->sent = TRUE;
|
session->sent = TRUE;
|
||||||
}
|
}
|
||||||
|
jid_destroy(jidp);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -40,10 +40,11 @@
|
|||||||
void chat_sessions_init(void);
|
void chat_sessions_init(void);
|
||||||
void chat_sessions_clear(void);
|
void chat_sessions_clear(void);
|
||||||
|
|
||||||
|
gboolean chat_session_exists(const char * const barejid);
|
||||||
|
char* chat_session_get_resource(const char * const barejid);
|
||||||
gboolean chat_session_on_message_send(const char * const barejid);
|
gboolean chat_session_on_message_send(const char * const barejid);
|
||||||
void chat_session_on_window_open(const char * const barejid);
|
|
||||||
void chat_session_on_window_close(const char * const barejid);
|
void chat_session_on_window_close(const char * const barejid);
|
||||||
void chat_session_on_incoming_message(const char * const barejid, gboolean supported);
|
void chat_session_on_incoming_message(const char * const barejid, const char * const resource, gboolean supported);
|
||||||
void chat_session_on_cancel(const char * const jid);
|
void chat_session_on_cancel(const char * const jid);
|
||||||
void chat_session_on_activity(const char * const barejid);
|
void chat_session_on_activity(const char * const barejid);
|
||||||
void chat_session_on_inactivity(const char * const recipient);
|
void chat_session_on_inactivity(const char * const recipient);
|
||||||
|
@ -1814,8 +1814,15 @@ cmd_execute_default(const char * inp)
|
|||||||
if (otr_is_secure(chatwin->barejid)) {
|
if (otr_is_secure(chatwin->barejid)) {
|
||||||
char *encrypted = otr_encrypt_message(chatwin->barejid, inp);
|
char *encrypted = otr_encrypt_message(chatwin->barejid, inp);
|
||||||
if (encrypted != NULL) {
|
if (encrypted != NULL) {
|
||||||
gboolean send_state = chat_session_on_message_send(chatwin->barejid);
|
char *resource = NULL;
|
||||||
message_send_chat(chatwin->barejid, chatwin->resource, encrypted, send_state);
|
gboolean send_state = FALSE;
|
||||||
|
if (chat_session_exists(chatwin->barejid)) {
|
||||||
|
resource = chat_session_get_resource(chatwin->barejid);
|
||||||
|
send_state = chat_session_on_message_send(chatwin->barejid);
|
||||||
|
} else {
|
||||||
|
send_state = TRUE;
|
||||||
|
}
|
||||||
|
message_send_chat(chatwin->barejid, resource, encrypted, send_state);
|
||||||
otr_free_message(encrypted);
|
otr_free_message(encrypted);
|
||||||
if (prefs_get_boolean(PREF_CHLOG)) {
|
if (prefs_get_boolean(PREF_CHLOG)) {
|
||||||
const char *jid = jabber_get_fulljid();
|
const char *jid = jabber_get_fulljid();
|
||||||
@ -1835,8 +1842,15 @@ cmd_execute_default(const char * inp)
|
|||||||
cons_show_error("Failed to send message.");
|
cons_show_error("Failed to send message.");
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
gboolean send_state = chat_session_on_message_send(chatwin->barejid);
|
char *resource = NULL;
|
||||||
message_send_chat(chatwin->barejid, chatwin->resource, inp, send_state);
|
gboolean send_state = FALSE;
|
||||||
|
if (chat_session_exists(chatwin->barejid)) {
|
||||||
|
resource = chat_session_get_resource(chatwin->barejid);
|
||||||
|
send_state = chat_session_on_message_send(chatwin->barejid);
|
||||||
|
} else {
|
||||||
|
send_state = TRUE;
|
||||||
|
}
|
||||||
|
message_send_chat(chatwin->barejid, resource, inp, send_state);
|
||||||
if (prefs_get_boolean(PREF_CHLOG)) {
|
if (prefs_get_boolean(PREF_CHLOG)) {
|
||||||
const char *jid = jabber_get_fulljid();
|
const char *jid = jabber_get_fulljid();
|
||||||
Jid *jidp = jid_create(jid);
|
Jid *jidp = jid_create(jid);
|
||||||
@ -1847,8 +1861,15 @@ cmd_execute_default(const char * inp)
|
|||||||
ui_outgoing_chat_msg("me", chatwin->barejid, inp);
|
ui_outgoing_chat_msg("me", chatwin->barejid, inp);
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
gboolean send_state = chat_session_on_message_send(chatwin->barejid);
|
char *resource = NULL;
|
||||||
message_send_chat(chatwin->barejid, chatwin->resource, inp, send_state);
|
gboolean send_state = FALSE;
|
||||||
|
if (chat_session_exists(chatwin->barejid)) {
|
||||||
|
resource = chat_session_get_resource(chatwin->barejid);
|
||||||
|
send_state = chat_session_on_message_send(chatwin->barejid);
|
||||||
|
} else {
|
||||||
|
send_state = TRUE;
|
||||||
|
}
|
||||||
|
message_send_chat(chatwin->barejid, resource, inp, send_state);
|
||||||
if (prefs_get_boolean(PREF_CHLOG)) {
|
if (prefs_get_boolean(PREF_CHLOG)) {
|
||||||
const char *jid = jabber_get_fulljid();
|
const char *jid = jabber_get_fulljid();
|
||||||
Jid *jidp = jid_create(jid);
|
Jid *jidp = jid_create(jid);
|
||||||
|
@ -1219,7 +1219,14 @@ cmd_msg(gchar **args, struct cmd_help_t help)
|
|||||||
if (otr_is_secure(barejid)) {
|
if (otr_is_secure(barejid)) {
|
||||||
char *encrypted = otr_encrypt_message(barejid, msg);
|
char *encrypted = otr_encrypt_message(barejid, msg);
|
||||||
if (encrypted != NULL) {
|
if (encrypted != NULL) {
|
||||||
gboolean send_state = chat_session_on_message_send(barejid);
|
resource = NULL;
|
||||||
|
gboolean send_state = FALSE;
|
||||||
|
if (chat_session_exists(barejid)) {
|
||||||
|
resource = chat_session_get_resource(barejid);
|
||||||
|
send_state = chat_session_on_message_send(barejid);
|
||||||
|
} else {
|
||||||
|
send_state = TRUE;
|
||||||
|
}
|
||||||
message_send_chat(barejid, resource, encrypted, send_state);
|
message_send_chat(barejid, resource, encrypted, send_state);
|
||||||
otr_free_message(encrypted);
|
otr_free_message(encrypted);
|
||||||
ui_outgoing_chat_msg("me", barejid, msg);
|
ui_outgoing_chat_msg("me", barejid, msg);
|
||||||
@ -1249,12 +1256,26 @@ cmd_msg(gchar **args, struct cmd_help_t help)
|
|||||||
GString *otr_message = g_string_new(msg);
|
GString *otr_message = g_string_new(msg);
|
||||||
g_string_append(otr_message, OTRL_MESSAGE_TAG_BASE);
|
g_string_append(otr_message, OTRL_MESSAGE_TAG_BASE);
|
||||||
g_string_append(otr_message, OTRL_MESSAGE_TAG_V2);
|
g_string_append(otr_message, OTRL_MESSAGE_TAG_V2);
|
||||||
gboolean send_state = chat_session_on_message_send(barejid);
|
resource = NULL;
|
||||||
|
gboolean send_state = FALSE;
|
||||||
|
if (chat_session_exists(barejid)) {
|
||||||
|
resource = chat_session_get_resource(barejid);
|
||||||
|
send_state = chat_session_on_message_send(barejid);
|
||||||
|
} else {
|
||||||
|
send_state = TRUE;
|
||||||
|
}
|
||||||
message_send_chat(barejid, resource, otr_message->str, send_state);
|
message_send_chat(barejid, resource, otr_message->str, send_state);
|
||||||
|
|
||||||
g_string_free(otr_message, TRUE);
|
g_string_free(otr_message, TRUE);
|
||||||
} else {
|
} else {
|
||||||
gboolean send_state = chat_session_on_message_send(barejid);
|
resource = NULL;
|
||||||
|
gboolean send_state = FALSE;
|
||||||
|
if (chat_session_exists(barejid)) {
|
||||||
|
resource = chat_session_get_resource(barejid);
|
||||||
|
send_state = chat_session_on_message_send(barejid);
|
||||||
|
} else {
|
||||||
|
send_state = TRUE;
|
||||||
|
}
|
||||||
message_send_chat(barejid, resource, msg, send_state);
|
message_send_chat(barejid, resource, msg, send_state);
|
||||||
}
|
}
|
||||||
ui_outgoing_chat_msg("me", barejid, msg);
|
ui_outgoing_chat_msg("me", barejid, msg);
|
||||||
@ -1268,7 +1289,14 @@ cmd_msg(gchar **args, struct cmd_help_t help)
|
|||||||
}
|
}
|
||||||
return TRUE;
|
return TRUE;
|
||||||
#else
|
#else
|
||||||
gboolean send_state = chat_session_on_message_send(barejid);
|
resource = NULL;
|
||||||
|
gboolean send_state = FALSE;
|
||||||
|
if (chat_session_exists(barejid)) {
|
||||||
|
resource = chat_session_get_resource(barejid);
|
||||||
|
send_state = chat_session_on_message_send(barejid);
|
||||||
|
} else {
|
||||||
|
send_state = TRUE;
|
||||||
|
}
|
||||||
message_send_chat(barejid, resource, msg, send_state);
|
message_send_chat(barejid, resource, msg, send_state);
|
||||||
ui_outgoing_chat_msg("me", barejid, msg);
|
ui_outgoing_chat_msg("me", barejid, msg);
|
||||||
|
|
||||||
@ -1282,7 +1310,6 @@ cmd_msg(gchar **args, struct cmd_help_t help)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
} else { // msg == NULL
|
} else { // msg == NULL
|
||||||
chat_session_on_window_open(barejid);
|
|
||||||
ui_new_chat_win(barejid);
|
ui_new_chat_win(barejid);
|
||||||
#ifdef HAVE_LIBOTR
|
#ifdef HAVE_LIBOTR
|
||||||
if (otr_is_secure(barejid)) {
|
if (otr_is_secure(barejid)) {
|
||||||
@ -3009,8 +3036,15 @@ cmd_tiny(gchar **args, struct cmd_help_t help)
|
|||||||
if (otr_is_secure(chatwin->barejid)) {
|
if (otr_is_secure(chatwin->barejid)) {
|
||||||
char *encrypted = otr_encrypt_message(chatwin->barejid, tiny);
|
char *encrypted = otr_encrypt_message(chatwin->barejid, tiny);
|
||||||
if (encrypted != NULL) {
|
if (encrypted != NULL) {
|
||||||
gboolean send_state = chat_session_on_message_send(chatwin->barejid);
|
char *resource = NULL;
|
||||||
message_send_chat(chatwin->barejid, chatwin->resource, encrypted, send_state);
|
gboolean send_state = FALSE;
|
||||||
|
if (chat_session_exists(chatwin->barejid)) {
|
||||||
|
resource = chat_session_get_resource(chatwin->barejid);
|
||||||
|
send_state = chat_session_on_message_send(chatwin->barejid);
|
||||||
|
} else {
|
||||||
|
send_state = TRUE;
|
||||||
|
}
|
||||||
|
message_send_chat(chatwin->barejid, resource, encrypted, send_state);
|
||||||
otr_free_message(encrypted);
|
otr_free_message(encrypted);
|
||||||
if (prefs_get_boolean(PREF_CHLOG)) {
|
if (prefs_get_boolean(PREF_CHLOG)) {
|
||||||
const char *jid = jabber_get_fulljid();
|
const char *jid = jabber_get_fulljid();
|
||||||
@ -3030,8 +3064,15 @@ cmd_tiny(gchar **args, struct cmd_help_t help)
|
|||||||
cons_show_error("Failed to send message.");
|
cons_show_error("Failed to send message.");
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
gboolean send_state = chat_session_on_message_send(chatwin->barejid);
|
char *resource = NULL;
|
||||||
message_send_chat(chatwin->barejid, chatwin->resource, tiny, send_state);
|
gboolean send_state = FALSE;
|
||||||
|
if (chat_session_exists(chatwin->barejid)) {
|
||||||
|
resource = chat_session_get_resource(chatwin->barejid);
|
||||||
|
send_state = chat_session_on_message_send(chatwin->barejid);
|
||||||
|
} else {
|
||||||
|
send_state = TRUE;
|
||||||
|
}
|
||||||
|
message_send_chat(chatwin->barejid, resource, tiny, send_state);
|
||||||
if (prefs_get_boolean(PREF_CHLOG)) {
|
if (prefs_get_boolean(PREF_CHLOG)) {
|
||||||
const char *jid = jabber_get_fulljid();
|
const char *jid = jabber_get_fulljid();
|
||||||
Jid *jidp = jid_create(jid);
|
Jid *jidp = jid_create(jid);
|
||||||
@ -3042,8 +3083,15 @@ cmd_tiny(gchar **args, struct cmd_help_t help)
|
|||||||
ui_outgoing_chat_msg("me", chatwin->barejid, tiny);
|
ui_outgoing_chat_msg("me", chatwin->barejid, tiny);
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
gboolean send_state = chat_session_on_message_send(chatwin->barejid);
|
char *resource = NULL;
|
||||||
message_send_chat(chatwin->barejid, chatwin->resource, tiny, send_state);
|
gboolean send_state = FALSE;
|
||||||
|
if (chat_session_exists(chatwin->barejid)) {
|
||||||
|
resource = chat_session_get_resource(chatwin->barejid);
|
||||||
|
send_state = chat_session_on_message_send(chatwin->barejid);
|
||||||
|
} else {
|
||||||
|
send_state = TRUE;
|
||||||
|
}
|
||||||
|
message_send_chat(chatwin->barejid, resource, tiny, send_state);
|
||||||
if (prefs_get_boolean(PREF_CHLOG)) {
|
if (prefs_get_boolean(PREF_CHLOG)) {
|
||||||
const char *jid = jabber_get_fulljid();
|
const char *jid = jabber_get_fulljid();
|
||||||
Jid *jidp = jid_create(jid);
|
Jid *jidp = jid_create(jid);
|
||||||
@ -3951,7 +3999,6 @@ cmd_otr(gchar **args, struct cmd_help_t help)
|
|||||||
barejid = contact;
|
barejid = contact;
|
||||||
}
|
}
|
||||||
|
|
||||||
chat_session_on_window_open(barejid);
|
|
||||||
ui_new_chat_win(barejid);
|
ui_new_chat_win(barejid);
|
||||||
|
|
||||||
if (ui_current_win_is_otr()) {
|
if (ui_current_win_is_otr()) {
|
||||||
@ -3961,8 +4008,15 @@ cmd_otr(gchar **args, struct cmd_help_t help)
|
|||||||
ui_current_print_formatted_line('!', 0, "You have not generated or loaded a private key, use '/otr gen'");
|
ui_current_print_formatted_line('!', 0, "You have not generated or loaded a private key, use '/otr gen'");
|
||||||
} else if (!otr_is_secure(barejid)) {
|
} else if (!otr_is_secure(barejid)) {
|
||||||
char *otr_query_message = otr_start_query();
|
char *otr_query_message = otr_start_query();
|
||||||
gboolean send_state = chat_session_on_message_send(barejid);
|
char *resource = NULL;
|
||||||
message_send_chat(barejid, NULL, otr_query_message, send_state);
|
gboolean send_state = FALSE;
|
||||||
|
if (chat_session_exists(barejid)) {
|
||||||
|
resource = chat_session_get_resource(barejid);
|
||||||
|
send_state = chat_session_on_message_send(barejid);
|
||||||
|
} else {
|
||||||
|
send_state = TRUE;
|
||||||
|
}
|
||||||
|
message_send_chat(barejid, resource, otr_query_message, send_state);
|
||||||
} else {
|
} else {
|
||||||
ui_gone_secure(barejid, otr_is_trusted(barejid));
|
ui_gone_secure(barejid, otr_is_trusted(barejid));
|
||||||
}
|
}
|
||||||
@ -3980,8 +4034,15 @@ cmd_otr(gchar **args, struct cmd_help_t help)
|
|||||||
} else {
|
} else {
|
||||||
ProfChatWin *chatwin = ui_get_current_chat();
|
ProfChatWin *chatwin = ui_get_current_chat();
|
||||||
char *otr_query_message = otr_start_query();
|
char *otr_query_message = otr_start_query();
|
||||||
gboolean send_state = chat_session_on_message_send(chatwin->barejid);
|
char *resource = NULL;
|
||||||
message_send_chat(chatwin->barejid, NULL, otr_query_message, send_state);
|
gboolean send_state = FALSE;
|
||||||
|
if (chat_session_exists(chatwin->barejid)) {
|
||||||
|
resource = chat_session_get_resource(chatwin->barejid);
|
||||||
|
send_state = chat_session_on_message_send(chatwin->barejid);
|
||||||
|
} else {
|
||||||
|
send_state = TRUE;
|
||||||
|
}
|
||||||
|
message_send_chat(chatwin->barejid, resource, otr_query_message, send_state);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -110,8 +110,15 @@ static void
|
|||||||
cb_inject_message(void *opdata, const char *accountname,
|
cb_inject_message(void *opdata, const char *accountname,
|
||||||
const char *protocol, const char *recipient, const char *message)
|
const char *protocol, const char *recipient, const char *message)
|
||||||
{
|
{
|
||||||
gboolean send_state = chat_session_on_message_send(recipient);
|
char *resource = NULL;
|
||||||
message_send_chat(recipient, NULL, message, send_state);
|
gboolean send_state = FALSE;
|
||||||
|
if (chat_session_exists(recipient)) {
|
||||||
|
resource = chat_session_get_resource(recipient);
|
||||||
|
send_state = chat_session_on_message_send(recipient);
|
||||||
|
} else {
|
||||||
|
send_state = TRUE;
|
||||||
|
}
|
||||||
|
message_send_chat(recipient, resource, message, send_state);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -318,8 +318,15 @@ handle_incoming_message(char *barejid, char *message)
|
|||||||
memmove(whitespace_base, whitespace_base+tag_length, tag_length);
|
memmove(whitespace_base, whitespace_base+tag_length, tag_length);
|
||||||
char *otr_query_message = otr_start_query();
|
char *otr_query_message = otr_start_query();
|
||||||
cons_show("OTR Whitespace pattern detected. Attempting to start OTR session...");
|
cons_show("OTR Whitespace pattern detected. Attempting to start OTR session...");
|
||||||
gboolean send_state = chat_session_on_message_send(barejid);
|
char *resource = NULL;
|
||||||
message_send_chat(barejid, NULL, otr_query_message, send_state);
|
gboolean send_state = FALSE;
|
||||||
|
if (chat_session_exists(barejid)) {
|
||||||
|
resource = chat_session_get_resource(barejid);
|
||||||
|
send_state = chat_session_on_message_send(barejid);
|
||||||
|
} else {
|
||||||
|
send_state = TRUE;
|
||||||
|
}
|
||||||
|
message_send_chat(barejid, resource, otr_query_message, send_state);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -333,8 +340,15 @@ handle_incoming_message(char *barejid, char *message)
|
|||||||
if (policy == PROF_OTRPOLICY_ALWAYS && !was_decrypted && !whitespace_base) {
|
if (policy == PROF_OTRPOLICY_ALWAYS && !was_decrypted && !whitespace_base) {
|
||||||
char *otr_query_message = otr_start_query();
|
char *otr_query_message = otr_start_query();
|
||||||
cons_show("Attempting to start OTR session...");
|
cons_show("Attempting to start OTR session...");
|
||||||
gboolean send_state = chat_session_on_message_send(barejid);
|
char *resource = NULL;
|
||||||
message_send_chat(barejid, NULL, otr_query_message, send_state);
|
gboolean send_state = FALSE;
|
||||||
|
if (chat_session_exists(barejid)) {
|
||||||
|
resource = chat_session_get_resource(barejid);
|
||||||
|
send_state = chat_session_on_message_send(barejid);
|
||||||
|
} else {
|
||||||
|
send_state = TRUE;
|
||||||
|
}
|
||||||
|
message_send_chat(barejid, resource, otr_query_message, send_state);
|
||||||
}
|
}
|
||||||
|
|
||||||
ui_incoming_msg(barejid, newmessage, NULL);
|
ui_incoming_msg(barejid, newmessage, NULL);
|
||||||
|
@ -149,23 +149,22 @@ message_send_invite(const char * const roomjid, const char * const contact,
|
|||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
message_send_composing(const char * const barejid)
|
message_send_composing(const char * const fulljid)
|
||||||
{
|
{
|
||||||
xmpp_conn_t * const conn = connection_get_conn();
|
xmpp_conn_t * const conn = connection_get_conn();
|
||||||
xmpp_ctx_t * const ctx = connection_get_ctx();
|
xmpp_ctx_t * const ctx = connection_get_ctx();
|
||||||
xmpp_stanza_t *stanza = stanza_create_chat_state(ctx, barejid,
|
xmpp_stanza_t *stanza = stanza_create_chat_state(ctx, fulljid, STANZA_NAME_COMPOSING);
|
||||||
STANZA_NAME_COMPOSING);
|
|
||||||
|
|
||||||
xmpp_send(conn, stanza);
|
xmpp_send(conn, stanza);
|
||||||
xmpp_stanza_release(stanza);
|
xmpp_stanza_release(stanza);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
message_send_paused(const char * const barejid)
|
message_send_paused(const char * const fulljid)
|
||||||
{
|
{
|
||||||
xmpp_conn_t * const conn = connection_get_conn();
|
xmpp_conn_t * const conn = connection_get_conn();
|
||||||
xmpp_ctx_t * const ctx = connection_get_ctx();
|
xmpp_ctx_t * const ctx = connection_get_ctx();
|
||||||
xmpp_stanza_t *stanza = stanza_create_chat_state(ctx, barejid,
|
xmpp_stanza_t *stanza = stanza_create_chat_state(ctx, fulljid,
|
||||||
STANZA_NAME_PAUSED);
|
STANZA_NAME_PAUSED);
|
||||||
|
|
||||||
xmpp_send(conn, stanza);
|
xmpp_send(conn, stanza);
|
||||||
@ -173,11 +172,11 @@ message_send_paused(const char * const barejid)
|
|||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
message_send_inactive(const char * const barejid)
|
message_send_inactive(const char * const fulljid)
|
||||||
{
|
{
|
||||||
xmpp_conn_t * const conn = connection_get_conn();
|
xmpp_conn_t * const conn = connection_get_conn();
|
||||||
xmpp_ctx_t * const ctx = connection_get_ctx();
|
xmpp_ctx_t * const ctx = connection_get_ctx();
|
||||||
xmpp_stanza_t *stanza = stanza_create_chat_state(ctx, barejid,
|
xmpp_stanza_t *stanza = stanza_create_chat_state(ctx, fulljid,
|
||||||
STANZA_NAME_INACTIVE);
|
STANZA_NAME_INACTIVE);
|
||||||
|
|
||||||
xmpp_send(conn, stanza);
|
xmpp_send(conn, stanza);
|
||||||
@ -185,11 +184,11 @@ message_send_inactive(const char * const barejid)
|
|||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
message_send_gone(const char * const barejid)
|
message_send_gone(const char * const fulljid)
|
||||||
{
|
{
|
||||||
xmpp_conn_t * const conn = connection_get_conn();
|
xmpp_conn_t * const conn = connection_get_conn();
|
||||||
xmpp_ctx_t * const ctx = connection_get_ctx();
|
xmpp_ctx_t * const ctx = connection_get_ctx();
|
||||||
xmpp_stanza_t *stanza = stanza_create_chat_state(ctx, barejid,
|
xmpp_stanza_t *stanza = stanza_create_chat_state(ctx, fulljid,
|
||||||
STANZA_NAME_GONE);
|
STANZA_NAME_GONE);
|
||||||
|
|
||||||
xmpp_send(conn, stanza);
|
xmpp_send(conn, stanza);
|
||||||
@ -469,7 +468,7 @@ _chat_handler(xmpp_conn_t * const conn, xmpp_stanza_t * const stanza,
|
|||||||
}
|
}
|
||||||
|
|
||||||
// create or update chat session
|
// create or update chat session
|
||||||
chat_session_on_incoming_message(jid->barejid, recipient_supports);
|
chat_session_on_incoming_message(jid->barejid, jid->resourcepart, recipient_supports);
|
||||||
|
|
||||||
// determine if the notifications happened whilst offline
|
// determine if the notifications happened whilst offline
|
||||||
GTimeVal tv_stamp;
|
GTimeVal tv_stamp;
|
||||||
|
@ -199,15 +199,14 @@ stanza_create_bookmarks_pubsub_add(xmpp_ctx_t *ctx, const char * const jid,
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
xmpp_stanza_t *
|
xmpp_stanza_t *
|
||||||
stanza_create_chat_state(xmpp_ctx_t *ctx, const char * const recipient,
|
stanza_create_chat_state(xmpp_ctx_t *ctx, const char * const fulljid, const char * const state)
|
||||||
const char * const state)
|
|
||||||
{
|
{
|
||||||
xmpp_stanza_t *msg, *chat_state;
|
xmpp_stanza_t *msg, *chat_state;
|
||||||
|
|
||||||
msg = xmpp_stanza_new(ctx);
|
msg = xmpp_stanza_new(ctx);
|
||||||
xmpp_stanza_set_name(msg, STANZA_NAME_MESSAGE);
|
xmpp_stanza_set_name(msg, STANZA_NAME_MESSAGE);
|
||||||
xmpp_stanza_set_type(msg, STANZA_TYPE_CHAT);
|
xmpp_stanza_set_type(msg, STANZA_TYPE_CHAT);
|
||||||
xmpp_stanza_set_attribute(msg, STANZA_ATTR_TO, recipient);
|
xmpp_stanza_set_attribute(msg, STANZA_ATTR_TO, fulljid);
|
||||||
char *id = create_unique_id(NULL);
|
char *id = create_unique_id(NULL);
|
||||||
xmpp_stanza_set_id(msg, id);
|
xmpp_stanza_set_id(msg, id);
|
||||||
free(id);
|
free(id);
|
||||||
|
@ -179,7 +179,7 @@ typedef enum {
|
|||||||
xmpp_stanza_t* stanza_create_bookmarks_storage_request(xmpp_ctx_t *ctx);
|
xmpp_stanza_t* stanza_create_bookmarks_storage_request(xmpp_ctx_t *ctx);
|
||||||
|
|
||||||
xmpp_stanza_t* stanza_create_chat_state(xmpp_ctx_t *ctx,
|
xmpp_stanza_t* stanza_create_chat_state(xmpp_ctx_t *ctx,
|
||||||
const char * const recipient, const char * const state);
|
const char * const fulljid, const char * const state);
|
||||||
|
|
||||||
xmpp_stanza_t* stanza_create_message(xmpp_ctx_t *ctx,
|
xmpp_stanza_t* stanza_create_message(xmpp_ctx_t *ctx,
|
||||||
const char * const recipient, const char * const type,
|
const char * const recipient, const char * const type,
|
||||||
|
@ -151,10 +151,10 @@ void message_send_private(const char * const fulljid, const char * const msg);
|
|||||||
void message_send_groupchat(const char * const roomjid, const char * const msg);
|
void message_send_groupchat(const char * const roomjid, const char * const msg);
|
||||||
void message_send_groupchat_subject(const char * const roomjid, const char * const subject);
|
void message_send_groupchat_subject(const char * const roomjid, const char * const subject);
|
||||||
|
|
||||||
void message_send_inactive(const char * const barejid);
|
void message_send_inactive(const char * const fulljid);
|
||||||
void message_send_composing(const char * const barejid);
|
void message_send_composing(const char * const fulljid);
|
||||||
void message_send_paused(const char * const barejid);
|
void message_send_paused(const char * const fulljid);
|
||||||
void message_send_gone(const char * const barejid);
|
void message_send_gone(const char * const fulljid);
|
||||||
|
|
||||||
void message_send_invite(const char * const room, const char * const contact,
|
void message_send_invite(const char * const room, const char * const contact,
|
||||||
const char * const reason);
|
const char * const reason);
|
||||||
|
@ -130,11 +130,12 @@ void handle_message_error_when_recipient_cancel_disables_chat_session(void **sta
|
|||||||
{
|
{
|
||||||
char *err_msg = "Some error.";
|
char *err_msg = "Some error.";
|
||||||
char *from = "bob@server.com";
|
char *from = "bob@server.com";
|
||||||
|
char *resource = "resource";
|
||||||
char *type = "cancel";
|
char *type = "cancel";
|
||||||
|
|
||||||
prefs_set_boolean(PREF_STATES, TRUE);
|
prefs_set_boolean(PREF_STATES, TRUE);
|
||||||
chat_sessions_init();
|
chat_sessions_init();
|
||||||
chat_session_on_incoming_message(from, TRUE);
|
chat_session_on_incoming_message(from, resource, TRUE);
|
||||||
|
|
||||||
expect_any(ui_handle_recipient_not_found, recipient);
|
expect_any(ui_handle_recipient_not_found, recipient);
|
||||||
expect_any(ui_handle_recipient_not_found, err_msg);
|
expect_any(ui_handle_recipient_not_found, err_msg);
|
||||||
|
Loading…
Reference in New Issue
Block a user