From 5ef60bf5948acd1c8b193c5312e66d4802a1ab6e Mon Sep 17 00:00:00 2001 From: Evgeniy Khramtsov Date: Mon, 2 Jan 2017 15:02:03 +0300 Subject: [PATCH] Correctly process errors from new cyrsasl API --- src/ejabberd_c2s.erl | 26 ++++++++++++++++++-------- 1 file changed, 18 insertions(+), 8 deletions(-) diff --git a/src/ejabberd_c2s.erl b/src/ejabberd_c2s.erl index 6d84d8d93..8693fcee5 100644 --- a/src/ejabberd_c2s.erl +++ b/src/ejabberd_c2s.erl @@ -719,17 +719,22 @@ wait_for_feature_request(#sasl_auth{mechanism = Mech, fsm_next_state(wait_for_sasl_response, StateData#state{sasl_state = NewSASLState}); {error, Error, Username} -> - ?INFO_MSG("(~w) Failed authentication for ~s@~s from ~s", + {Reason, ErrTxt} = cyrsasl:format_error(Mech, Error), + ?INFO_MSG("(~w) Failed authentication for ~s@~s from ~s: ~s", [StateData#state.socket, Username, StateData#state.server, - ejabberd_config:may_hide_data(jlib:ip_to_list(StateData#state.ip))]), + ejabberd_config:may_hide_data(jlib:ip_to_list(StateData#state.ip)), + ErrTxt]), ejabberd_hooks:run(c2s_auth_result, StateData#state.server, [false, Username, StateData#state.server, StateData#state.ip]), - send_element(StateData, #sasl_failure{reason = Error}), + send_element(StateData, #sasl_failure{reason = Reason, + text = xmpp:mk_text(ErrTxt)}), fsm_next_state(wait_for_feature_request, StateData); {error, Error} -> - send_element(StateData, #sasl_failure{reason = Error}), + {Reason, ErrTxt} = cyrsasl:format_error(Mech, Error), + send_element(StateData, #sasl_failure{reason = Reason, + text = xmpp:mk_text(ErrTxt)}), fsm_next_state(wait_for_feature_request, StateData) end; wait_for_feature_request(#starttls{}, @@ -839,17 +844,22 @@ wait_for_sasl_response(#sasl_response{text = ClientIn}, StateData) -> fsm_next_state(wait_for_sasl_response, StateData#state{sasl_state = NewSASLState}); {error, Error, Username} -> - ?INFO_MSG("(~w) Failed authentication for ~s@~s from ~s", + {Reason, ErrTxt} = cyrsasl:format_error(StateData#state.sasl_state, Error), + ?INFO_MSG("(~w) Failed authentication for ~s@~s from ~s: ~s", [StateData#state.socket, Username, StateData#state.server, - ejabberd_config:may_hide_data(jlib:ip_to_list(StateData#state.ip))]), + ejabberd_config:may_hide_data(jlib:ip_to_list(StateData#state.ip)), + ErrTxt]), ejabberd_hooks:run(c2s_auth_result, StateData#state.server, [false, Username, StateData#state.server, StateData#state.ip]), - send_element(StateData, #sasl_failure{reason = Error}), + send_element(StateData, #sasl_failure{reason = Reason, + text = xmpp:mk_text(ErrTxt)}), fsm_next_state(wait_for_feature_request, StateData); {error, Error} -> - send_element(StateData, #sasl_failure{reason = Error}), + {Reason, ErrTxt} = cyrsasl:format_error(StateData#state.sasl_state, Error), + send_element(StateData, #sasl_failure{reason = Reason, + text = xmpp:mk_text(ErrTxt)}), fsm_next_state(wait_for_feature_request, StateData) end; wait_for_sasl_response(timeout, StateData) -> -- 2.40.0