diff options
Diffstat (limited to 'lib/kernel/src')
| -rw-r--r-- | lib/kernel/src/net_kernel.erl | 38 | 
1 files changed, 34 insertions, 4 deletions
| diff --git a/lib/kernel/src/net_kernel.erl b/lib/kernel/src/net_kernel.erl index 0a9f9316b0..9921a0adfd 100644 --- a/lib/kernel/src/net_kernel.erl +++ b/lib/kernel/src/net_kernel.erl @@ -1262,11 +1262,22 @@ create_name(Name, LongOrShortNames, Try) ->      {Head,Host1} = create_hostpart(Name, LongOrShortNames),      case Host1 of  	{ok,HostPart} -> -	    {ok,list_to_atom(Head ++ HostPart)}; +            case valid_name_head(Head) of +                true -> +                    {ok,list_to_atom(Head ++ HostPart)}; +                false -> +                    error_logger:info_msg("Invalid node name!\n" +                                          "Please check your configuration\n"), +                    {error, badarg} +            end;  	{error,long} when Try =:= 1 ->  	    %% It could be we haven't read domain name from resolv file yet  	    inet_config:do_load_resolv(os:type(), longnames),  	    create_name(Name, LongOrShortNames, 0); +        {error, hostname_not_allowed} -> +            error_logger:info_msg("Invalid node name!\n" +                                  "Please check your configuration\n"), +            {error, badarg};  	{error,Type} ->  	    error_logger:info_msg(  	      lists:concat(["Can\'t set ", @@ -1279,12 +1290,13 @@ create_name(Name, LongOrShortNames, Try) ->  create_hostpart(Name, LongOrShortNames) ->      {Head,Host} = split_node(Name),      Host1 = case {Host,LongOrShortNames} of -		{[$@,_|_],longnames} -> -		    {ok,Host}; +		{[$@,_|_] = Host,longnames} -> +                    validate_hostname(Host);  		{[$@,_|_],shortnames} ->  		    case lists:member($.,Host) of  			true -> {error,short}; -			_ -> {ok,Host} +			_ -> +                            validate_hostname(Host)  		    end;  		{_,shortnames} ->  		    case inet_db:gethostname() of @@ -1304,6 +1316,24 @@ create_hostpart(Name, LongOrShortNames) ->  	    end,      {Head,Host1}. +validate_hostname([$@|HostPart] = Host) -> +    {ok, MP} = re:compile("^[!-ΓΏ]*$", [unicode]), +    case re:run(HostPart, MP) of +        {match, _} -> +            {ok, Host}; +        nomatch -> +            {error, hostname_not_allowed} +    end. + +valid_name_head(Head) -> +    {ok, MP} = re:compile("^[0-9A-Za-z_\\-]*$", [unicode]), +        case re:run(Head, MP) of +            {match, _} -> +                true; +            nomatch -> +                false +    end. +  split_node(Name) ->      lists:splitwith(fun(C) -> C =/= $@ end, atom_to_list(Name)). | 
