diff options
author | James Booth <boothj5@gmail.com> | 2015-10-27 00:19:22 +0000 |
---|---|---|
committer | James Booth <boothj5@gmail.com> | 2015-10-27 00:19:22 +0000 |
commit | 124aaa9809ee13b382f47f6f3e175bd7fdb98dc5 (patch) | |
tree | 8346aecaa20402dc9ac3c84b5fee8573d5341741 /src/otr | |
parent | 8bd74cefcf73772a52b40c919a1e70da90be8a33 (diff) | |
download | profani-tty-124aaa9809ee13b382f47f6f3e175bd7fdb98dc5.tar.gz |
remaining otr functions take ProfChatWin
Diffstat (limited to 'src/otr')
-rw-r--r-- | src/otr/otr.c | 14 | ||||
-rw-r--r-- | src/otr/otrlibv3.c | 40 | ||||
-rw-r--r-- | src/otr/otrlibv4.c | 28 |
3 files changed, 42 insertions, 40 deletions
diff --git a/src/otr/otr.c b/src/otr/otr.c index 8d1ee545..bdecf22d 100644 --- a/src/otr/otr.c +++ b/src/otr/otr.c @@ -573,13 +573,18 @@ otr_smp_secret(const char *const recipient, const char *secret) } // if recipient initiated SMP, send response, else initialise + ProfChatWin *chatwin = wins_get_chat(recipient); if (g_hash_table_contains(smp_initiators, recipient)) { otrl_message_respond_smp(user_state, &ops, NULL, context, (const unsigned char*)secret, strlen(secret)); - ui_otr_authenticating(recipient); + if (chatwin) { + ui_otr_authenticating(chatwin); + } g_hash_table_remove(smp_initiators, context->username); } else { otrl_message_initiate_smp(user_state, &ops, NULL, context, (const unsigned char*)secret, strlen(secret)); - ui_otr_authetication_waiting(recipient); + if (chatwin) { + ui_otr_authetication_waiting(chatwin); + } } } @@ -597,7 +602,10 @@ otr_smp_question(const char *const recipient, const char *question, const char * } otrl_message_initiate_smp_q(user_state, &ops, NULL, context, question, (const unsigned char*)answer, strlen(answer)); - ui_otr_authetication_waiting(recipient); + ProfChatWin *chatwin = wins_get_chat(recipient); + if (chatwin) { + ui_otr_authetication_waiting(chatwin); + } } void diff --git a/src/otr/otrlibv3.c b/src/otr/otrlibv3.c index 05083dea..8343f19f 100644 --- a/src/otr/otrlibv3.c +++ b/src/otr/otrlibv3.c @@ -176,24 +176,22 @@ otrlib_handle_tlvs(OtrlUserState user_state, OtrlMessageAppOps *ops, ConnContext otrl_message_abort_smp(user_state, ops, NULL, context); } else { context->smstate->nextExpected = OTRL_SMP_EXPECT1; - if (context->smstate->received_question == 0) { - ProfChatWin *chatwin = wins_get_chat(context->username); - if (context->active_fingerprint->trust && (context->active_fingerprint->trust[0] != '\0')) { - if (chatwin) { + ProfChatWin *chatwin = wins_get_chat(context->username); + if (chatwin) { + if (context->smstate->received_question == 0) { + if (context->active_fingerprint->trust && (context->active_fingerprint->trust[0] != '\0')) { ui_smp_successful(chatwin); - } - ui_trust(context->username); - } else { - if (chatwin) { + ui_trust(chatwin); + } else { ui_smp_unsuccessful_sender(chatwin); + ui_untrust(chatwin); } - ui_untrust(context->username); - } - } else { - if (context->smstate->sm_prog_state == OTRL_SMP_PROG_SUCCEEDED) { - ui_smp_answer_success(context->username); } else { - ui_smp_answer_failure(context->username); + if (context->smstate->sm_prog_state == OTRL_SMP_PROG_SUCCEEDED) { + ui_smp_answer_success(chatwin); + } else { + ui_smp_answer_failure(chatwin); + } } } } @@ -205,16 +203,14 @@ otrlib_handle_tlvs(OtrlUserState user_state, OtrlMessageAppOps *ops, ConnContext } else { context->smstate->nextExpected = OTRL_SMP_EXPECT1; ProfChatWin *chatwin = wins_get_chat(context->username); - if (context->active_fingerprint->trust && (context->active_fingerprint->trust[0] != '\0')) { - if (chatwin) { + if (chatwin) { + if (context->active_fingerprint->trust && (context->active_fingerprint->trust[0] != '\0')) { ui_smp_successful(chatwin); - } - ui_trust(context->username); - } else { - if (chatwin) { + ui_trust(chatwin); + } else { ui_smp_unsuccessful_receiver(chatwin); + ui_untrust(chatwin); } - ui_untrust(context->username); } } } @@ -224,8 +220,8 @@ otrlib_handle_tlvs(OtrlUserState user_state, OtrlMessageAppOps *ops, ConnContext ProfChatWin *chatwin = wins_get_chat(context->username); if (chatwin) { ui_smp_aborted(chatwin); + ui_untrust(chatwin); } - ui_untrust(context->username); otr_untrust(context->username); } } diff --git a/src/otr/otrlibv4.c b/src/otr/otrlibv4.c index 29d6d57a..a82a98a8 100644 --- a/src/otr/otrlibv4.c +++ b/src/otr/otrlibv4.c @@ -195,30 +195,28 @@ cb_handle_smp_event(void *opdata, OtrlSMPEvent smp_event, break; case OTRL_SMPEVENT_SUCCESS: - if (context->smstate->received_question == 0) { - if (chatwin) { + if (chatwin) { + if (context->smstate->received_question == 0) { ui_smp_successful(chatwin); + ui_trust(chatwin); + } else { + ui_smp_answer_success(chatwin); } - ui_trust(context->username); - } else { - ui_smp_answer_success(context->username); } break; case OTRL_SMPEVENT_FAILURE: - if (context->smstate->received_question == 0) { - if (nextMsg == OTRL_SMP_EXPECT3) { - if (chatwin) { + if (chatwin) { + if (context->smstate->received_question == 0) { + if (nextMsg == OTRL_SMP_EXPECT3) { ui_smp_unsuccessful_sender(chatwin); - } - } else if (nextMsg == OTRL_SMP_EXPECT4) { - if (chatwin) { + } else if (nextMsg == OTRL_SMP_EXPECT4) { ui_smp_unsuccessful_receiver(chatwin); } + ui_untrust(chatwin); + } else { + ui_smp_answer_failure(chatwin); } - ui_untrust(context->username); - } else { - ui_smp_answer_failure(context->username); } break; @@ -233,8 +231,8 @@ cb_handle_smp_event(void *opdata, OtrlSMPEvent smp_event, case OTRL_SMPEVENT_ABORT: if (chatwin) { ui_smp_aborted(chatwin); + ui_untrust(chatwin); } - ui_untrust(context->username); break; case OTRL_SMPEVENT_IN_PROGRESS: |