diff options
| author | Zandra Hird <[email protected]> | 2015-05-18 10:52:01 +0200 | 
|---|---|---|
| committer | Zandra Hird <[email protected]> | 2015-05-18 10:52:01 +0200 | 
| commit | bcc5248a76ee692ede18367a1f3d6cd9acd6cde7 (patch) | |
| tree | aef5714d1f5caa9292e5891ab9c580a2d53d7e14 /lib | |
| parent | 40732b962a7bf6300f82f5662a68df2f940b2026 (diff) | |
| parent | 10e8677c632df5f9433eb771076d1ff71c7ed75d (diff) | |
| download | otp-bcc5248a76ee692ede18367a1f3d6cd9acd6cde7.tar.gz otp-bcc5248a76ee692ede18367a1f3d6cd9acd6cde7.tar.bz2 otp-bcc5248a76ee692ede18367a1f3d6cd9acd6cde7.zip | |
Merge branch 'maint'
Conflicts:
	OTP_VERSION
	lib/ssh/doc/src/ssh.xml
	lib/ssh/vsn.mk
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/inets/doc/src/notes.xml | 17 | ||||
| -rw-r--r-- | lib/inets/src/http_server/httpd_request.erl | 8 | ||||
| -rw-r--r-- | lib/inets/vsn.mk | 2 | ||||
| -rw-r--r-- | lib/ssh/doc/src/notes.xml | 19 | ||||
| -rw-r--r-- | lib/ssh/doc/src/ssh.xml | 19 | ||||
| -rw-r--r-- | lib/ssh/src/ssh.erl | 4 | ||||
| -rw-r--r-- | lib/ssh/src/ssh_connection_handler.erl | 12 | ||||
| -rw-r--r-- | lib/ssh/test/ssh_basic_SUITE.erl | 90 | 
8 files changed, 159 insertions, 12 deletions
| diff --git a/lib/inets/doc/src/notes.xml b/lib/inets/doc/src/notes.xml index 12bbc2b736..bae8e327a3 100644 --- a/lib/inets/doc/src/notes.xml +++ b/lib/inets/doc/src/notes.xml @@ -32,7 +32,22 @@      <file>notes.xml</file>    </header> -  <section><title>Inets 5.10.7</title> +  <section><title>Inets 5.10.8</title> + +    <section><title>Fixed Bugs and Malfunctions</title> +      <list> +        <item> +          <p> +	    Reject messages with a Content-Length less than 0</p> +          <p> +	    Own Id: OTP-12739 Aux Id: seq12860 </p> +        </item> +      </list> +    </section> + +</section> + +<section><title>Inets 5.10.7</title>      <section><title>Improvements and New Features</title>        <list> diff --git a/lib/inets/src/http_server/httpd_request.erl b/lib/inets/src/http_server/httpd_request.erl index 6985065c3e..3ff07616f9 100644 --- a/lib/inets/src/http_server/httpd_request.erl +++ b/lib/inets/src/http_server/httpd_request.erl @@ -417,8 +417,12 @@ check_header({"content-length", Value}, Maxsizes) ->      case length(Value) =< MaxLen of  	true ->  	    try  -		_ = list_to_integer(Value), -		ok +		list_to_integer(Value) +	    of +		I when I>= 0 -> +		    ok; +		_ -> +		    {error, {size_error, Max, 411, "negative content-length"}}  	    catch _:_ ->  		    {error, {size_error, Max, 411, "content-length not an integer"}}  	    end; diff --git a/lib/inets/vsn.mk b/lib/inets/vsn.mk index e9ecb2632a..ecb84e447c 100644 --- a/lib/inets/vsn.mk +++ b/lib/inets/vsn.mk @@ -18,6 +18,6 @@  # %CopyrightEnd%  APPLICATION = inets -INETS_VSN   = 5.10.7 +INETS_VSN   = 5.10.8  PRE_VSN     =  APP_VSN     = "$(APPLICATION)-$(INETS_VSN)$(PRE_VSN)" diff --git a/lib/ssh/doc/src/notes.xml b/lib/ssh/doc/src/notes.xml index 41885c684c..579a3ae4a8 100644 --- a/lib/ssh/doc/src/notes.xml +++ b/lib/ssh/doc/src/notes.xml @@ -29,6 +29,25 @@      <file>notes.xml</file>    </header> +<section><title>Ssh 3.2.3</title> + +    <section><title>Fixed Bugs and Malfunctions</title> +      <list> +        <item> +          <p> +	    A new option for handling the SSH_MSG_DEBUG message's +	    printouts. A fun could be given in the options that will +	    be called whenever the SSH_MSG_DEBUG message arrives. +	    This enables the user to format the printout or just +	    discard it.</p> +          <p> +	    Own Id: OTP-12738 Aux Id: seq12860 </p> +        </item> +      </list> +    </section> + +</section> +  <section><title>Ssh 3.2.2</title>      <section><title>Improvements and New Features</title> diff --git a/lib/ssh/doc/src/ssh.xml b/lib/ssh/doc/src/ssh.xml index d49d3ac2a7..c7d7db0e30 100644 --- a/lib/ssh/doc/src/ssh.xml +++ b/lib/ssh/doc/src/ssh.xml @@ -227,6 +227,13 @@  	  <item>  	  <p>Sets a time-out on a connection when no channels are active.  	  Defaults to <c>infinity</c>.</p></item> +	  <tag><c><![CDATA[{ssh_msg_debug_fun, fun(ConnectionRef::ssh_connection_ref(), AlwaysDisplay::boolean(), Msg::binary(), LanguageTag::binary()) -> _}]]></c></tag> +	  <item> +	    <p>Provide a fun to implement your own logging of the SSH message SSH_MSG_DEBUG. The last three parameters are from the message, see RFC4253, section 11.3. The <c>ConnectionRef</c> is the reference to the connection on which the message arrived. The return value from the fun is not checked.</p> +	    <p>The default behaviour is ignore the message. +	    To get a printout for each message with <c>AlwaysDisplay = true</c>, use for example <c>{ssh_msg_debug_fun, fun(_,true,M,_)-> io:format("DEBUG: ~p~n", [M]) end}</c></p> +	  </item> +  	</taglist>        </desc>         </func> @@ -427,8 +434,16 @@  	  <item>  	    <p>Provides a fun to implement your own logging when a user disconnects from the server.</p>  	  </item> -        </taglist> -      </desc> + +	  <tag><c><![CDATA[{ssh_msg_debug_fun, fun(ConnectionRef::ssh_connection_ref(), AlwaysDisplay::boolean(), Msg::binary(), LanguageTag::binary()) -> _}]]></c></tag> +	  <item> +	    <p>Provide a fun to implement your own logging of the SSH message SSH_MSG_DEBUG. The last three parameters are from the message, see RFC4253, section 11.3. The <c>ConnectionRef</c> is the reference to the connection on which the message arrived. The return value from the fun is not checked.</p> +	    <p>The default behaviour is ignore the message. +	    To get a printout for each message with <c>AlwaysDisplay = true</c>, use for example <c>{ssh_msg_debug_fun, fun(_,true,M,_)-> io:format("DEBUG: ~p~n", [M]) end}</c></p> +	  </item> + +	</taglist> +      </desc>         </func> diff --git a/lib/ssh/src/ssh.erl b/lib/ssh/src/ssh.erl index d4b02a024e..71e7d77475 100644 --- a/lib/ssh/src/ssh.erl +++ b/lib/ssh/src/ssh.erl @@ -312,6 +312,8 @@ handle_option([{disconnectfun, _} = Opt | Rest], SocketOptions, SshOptions) ->      handle_option(Rest, SocketOptions, [handle_ssh_option(Opt) | SshOptions]);  handle_option([{failfun, _} = Opt | Rest],  SocketOptions, SshOptions) ->      handle_option(Rest, SocketOptions, [handle_ssh_option(Opt) | SshOptions]); +handle_option([{ssh_msg_debug_fun, _} = Opt | Rest],  SocketOptions, SshOptions) -> +    handle_option(Rest, SocketOptions, [handle_ssh_option(Opt) | SshOptions]);  %%Backwards compatibility should not be underscore between ip and v6 in API  handle_option([{ip_v6_disabled, Value} | Rest], SocketOptions, SshOptions) ->      handle_option(Rest, SocketOptions, [handle_ssh_option({ipv6_disabled, Value}) | SshOptions]); @@ -417,6 +419,8 @@ handle_ssh_option({disconnectfun , Value} = Opt) when is_function(Value) ->      Opt;  handle_ssh_option({failfun, Value} = Opt) when is_function(Value) ->      Opt; +handle_ssh_option({ssh_msg_debug_fun, Value} = Opt) when is_function(Value,4) -> +    Opt;  handle_ssh_option({ipv6_disabled, Value} = Opt) when is_boolean(Value) ->      throw({error, {{ipv6_disabled, Opt}, option_no_longer_valid_use_inet_option_instead}}); diff --git a/lib/ssh/src/ssh_connection_handler.erl b/lib/ssh/src/ssh_connection_handler.erl index 4dea284071..2c7f132916 100644 --- a/lib/ssh/src/ssh_connection_handler.erl +++ b/lib/ssh/src/ssh_connection_handler.erl @@ -581,12 +581,12 @@ handle_event(#ssh_msg_disconnect{description = Desc} = DisconnectMsg, _StateName  handle_event(#ssh_msg_ignore{}, StateName, State) ->      {next_state, StateName, next_packet(State)}; -handle_event(#ssh_msg_debug{always_display = true, message = DbgMsg},  -	     StateName, State) -> -    io:format("DEBUG: ~p\n", [DbgMsg]), -    {next_state, StateName, next_packet(State)}; - -handle_event(#ssh_msg_debug{}, StateName, State) -> +handle_event(#ssh_msg_debug{always_display = Display, message = DbgMsg, language=Lang},  +	     StateName, #state{opts = Opts} = State) -> +    F = proplists:get_value(ssh_msg_debug_fun, Opts,  +			    fun(_ConnRef, _AlwaysDisplay, _Msg, _Language) -> ok end +			   ), +    catch F(self(), Display, DbgMsg, Lang),      {next_state, StateName, next_packet(State)};  handle_event(#ssh_msg_unimplemented{}, StateName, State) -> diff --git a/lib/ssh/test/ssh_basic_SUITE.erl b/lib/ssh/test/ssh_basic_SUITE.erl index d55d09f2a2..242c9a3bd9 100644 --- a/lib/ssh/test/ssh_basic_SUITE.erl +++ b/lib/ssh/test/ssh_basic_SUITE.erl @@ -52,6 +52,8 @@ all() ->       ssh_connect_arg4_timeout,       packet_size_zero,       ssh_daemon_minimal_remote_max_packet_size_option, +     ssh_msg_debug_fun_option_client, +     ssh_msg_debug_fun_option_server,       id_string_no_opt_client,       id_string_own_string_client,       id_string_random_client, @@ -494,6 +496,94 @@ server_userpassword_option(Config) when is_list(Config) ->      ssh:stop_daemon(Pid).  %%-------------------------------------------------------------------- +ssh_msg_debug_fun_option_client() -> +    [{doc, "validate client that uses the 'ssh_msg_debug_fun' option"}]. +ssh_msg_debug_fun_option_client(Config) -> +    PrivDir = ?config(priv_dir, Config), +    UserDir = filename:join(PrivDir, nopubkey), % to make sure we don't use public-key-auth +    file:make_dir(UserDir), +    SysDir = ?config(data_dir, Config), + +    {Pid, Host, Port} = ssh_test_lib:daemon([{system_dir, SysDir}, +					     {user_dir, UserDir}, +					     {password, "morot"}, +					     {failfun, fun ssh_test_lib:failfun/2}]), +    Parent = self(), +    DbgFun = fun(ConnRef,Displ,Msg,Lang) -> Parent ! {msg_dbg,{ConnRef,Displ,Msg,Lang}} end, +		 +    ConnectionRef = +	ssh_test_lib:connect(Host, Port, [{silently_accept_hosts, true}, +					  {user, "foo"}, +					  {password, "morot"}, +					  {user_dir, UserDir}, +					  {user_interaction, false}, +					  {ssh_msg_debug_fun,DbgFun}]), +    %% Beware, implementation knowledge: +    gen_fsm:send_all_state_event(ConnectionRef,{ssh_msg_debug,false,<<"Hello">>,<<>>}), +    receive +	{msg_dbg,X={ConnectionRef,false,<<"Hello">>,<<>>}} -> +	    ct:log("Got expected dbg msg ~p",[X]), +	    ssh:stop_daemon(Pid); +	{msg_dbg,X={_,false,<<"Hello">>,<<>>}} -> +	    ct:log("Got dbg msg but bad ConnectionRef (~p expected) ~p",[ConnectionRef,X]), +	    ssh:stop_daemon(Pid), +	    {fail, "Bad ConnectionRef received"}; +	{msg_dbg,X} -> +	    ct:log("Got bad dbg msg ~p",[X]), +	    ssh:stop_daemon(Pid), +	    {fail,"Bad msg received"} +    after 1000 -> +	    ssh:stop_daemon(Pid), +	    {fail,timeout} +    end. + +%%-------------------------------------------------------------------- +ssh_msg_debug_fun_option_server() -> +    [{doc, "validate client that uses the 'ssh_msg_debug_fun' option"}]. +ssh_msg_debug_fun_option_server(Config) -> +    PrivDir = ?config(priv_dir, Config), +    UserDir = filename:join(PrivDir, nopubkey), % to make sure we don't use public-key-auth +    file:make_dir(UserDir), +    SysDir = ?config(data_dir, Config), + +    Parent = self(), +    DbgFun = fun(ConnRef,Displ,Msg,Lang) -> Parent ! {msg_dbg,{ConnRef,Displ,Msg,Lang}} end, +    ConnFun = fun(_,_,_) -> Parent ! {connection_pid,self()} end, + +    {Pid, Host, Port} = ssh_test_lib:daemon([{system_dir, SysDir}, +					     {user_dir, UserDir}, +					     {password, "morot"}, +					     {failfun, fun ssh_test_lib:failfun/2}, +					     {connectfun, ConnFun}, +					     {ssh_msg_debug_fun, DbgFun}]), +    _ConnectionRef = +	ssh_test_lib:connect(Host, Port, [{silently_accept_hosts, true}, +					  {user, "foo"}, +					  {password, "morot"}, +					  {user_dir, UserDir}, +					  {user_interaction, false}]), +    receive +	{connection_pid,Server} -> +	    %% Beware, implementation knowledge: +	    gen_fsm:send_all_state_event(Server,{ssh_msg_debug,false,<<"Hello">>,<<>>}), +	    receive +		{msg_dbg,X={_,false,<<"Hello">>,<<>>}} -> +		    ct:log("Got expected dbg msg ~p",[X]), +		    ssh:stop_daemon(Pid); +		{msg_dbg,X} -> +		    ct:log("Got bad dbg msg ~p",[X]), +		    ssh:stop_daemon(Pid), +		    {fail,"Bad msg received"} +	    after 3000 -> +		    ssh:stop_daemon(Pid), +		    {fail,timeout2} +	    end +    after 3000 -> +	    ssh:stop_daemon(Pid), +	    {fail,timeout1} +    end. + +%%--------------------------------------------------------------------  known_hosts() ->      [{doc, "check that known_hosts is updated correctly"}].  known_hosts(Config) when is_list(Config) -> | 
