diff options
Diffstat (limited to 'lib/ssl/src/tls_connection.erl')
| -rw-r--r-- | lib/ssl/src/tls_connection.erl | 27 | 
1 files changed, 19 insertions, 8 deletions
| diff --git a/lib/ssl/src/tls_connection.erl b/lib/ssl/src/tls_connection.erl index 39f3ed996e..cf2f3a2b62 100644 --- a/lib/ssl/src/tls_connection.erl +++ b/lib/ssl/src/tls_connection.erl @@ -63,7 +63,7 @@  %% gen_statem state functions  -export([init/3, error/3, downgrade/3, %% Initiation and take down states  	 hello/3, certify/3, cipher/3, abbreviated/3, %% Handshake states  -	 connection/3]).  +	 connection/3, death_row/3]).  %% gen_statem callbacks  -export([callback_mode/0, terminate/3, code_change/4, format_status/2]). @@ -437,11 +437,15 @@ init(Type, Event, State) ->  %%--------------------------------------------------------------------  error({call, From}, {start, _Timeout}, {Error, State}) -> -    {stop_and_reply, normal, {reply, From, {error, Error}}, State}; -error({call, From}, {start, _Timeout}, #state{protocol_specific = #{error := Error}} = State) -> -    {stop_and_reply, normal, {reply, From, {error, Error}}, State}; +    ssl_connection:stop_and_reply( +      normal, {reply, From, {error, Error}}, State); +error({call, From}, {start, _Timeout},  +      #state{protocol_specific = #{error := Error}} = State) -> +    ssl_connection:stop_and_reply( +      normal, {reply, From, {error, Error}}, State);  error({call, _} = Call, Msg, {Error, #state{protocol_specific = Map} = State}) -> -    gen_handshake(?FUNCTION_NAME, Call, Msg, State#state{protocol_specific = Map#{error => Error}}); +    gen_handshake(?FUNCTION_NAME, Call, Msg,  +                  State#state{protocol_specific = Map#{error => Error}});  error(_, _, _) ->       {keep_state_and_data, [postpone]}. @@ -567,6 +571,13 @@ connection(Type, Event, State) ->      ssl_connection:?FUNCTION_NAME(Type, Event, State, ?MODULE).  %%-------------------------------------------------------------------- +-spec death_row(gen_statem:event_type(), term(), #state{}) -> +		       gen_statem:state_function_result(). +%%-------------------------------------------------------------------- +death_row(Type, Event, State) -> +     ssl_connection:death_row(Type, Event, State, ?MODULE). + +%%--------------------------------------------------------------------  -spec downgrade(gen_statem:event_type(), term(), #state{}) ->  		       gen_statem:state_function_result().  %%-------------------------------------------------------------------- @@ -654,7 +665,7 @@ handle_info({Protocol, _, Data}, StateName,  	    next_event(StateName, Record, State);  	#alert{} = Alert ->  	    ssl_connection:handle_normal_shutdown(Alert, StateName, State0),  -	    {stop, {shutdown, own_alert}} +	    ssl_connection:stop({shutdown, own_alert}, State0)      end;  handle_info({CloseTag, Socket}, StateName,              #state{socket = Socket, close_tag = CloseTag, @@ -681,7 +692,7 @@ handle_info({CloseTag, Socket}, StateName,              end,              ssl_connection:handle_normal_shutdown(?ALERT_REC(?FATAL, ?CLOSE_NOTIFY), StateName, State), -            {stop, {shutdown, transport_closed}}; +            ssl_connection:stop({shutdown, transport_closed}, State);          true ->              %% Fixes non-delivery of final TLS record in {active, once}.              %% Basically allows the application the opportunity to set {active, once} again @@ -693,7 +704,7 @@ handle_info(Msg, StateName, State) ->  handle_alerts([], Result) ->      Result; -handle_alerts(_, {stop,_} = Stop) -> +handle_alerts(_, {stop, _, _} = Stop) ->      Stop;  handle_alerts([Alert | Alerts], {next_state, StateName, State}) ->       handle_alerts(Alerts, ssl_connection:handle_alert(Alert, StateName, State)); | 
