mirror of
https://github.com/processone/ejabberd.git
synced 2024-12-30 17:43:57 +01:00
Reject request http_api request that have malformed Authentication header
This commit is contained in:
parent
096b4a50e5
commit
56baa07d48
@ -852,23 +852,23 @@ code_to_phrase(505) -> <<"HTTP Version Not Supported">>.
|
||||
|
||||
-spec parse_auth(binary()) -> {binary(), binary()} | {oauth, binary(), []} | undefined.
|
||||
parse_auth(<<"Basic ", Auth64/binary>>) ->
|
||||
Auth = try base64:decode(Auth64)
|
||||
catch _:badarg -> <<>>
|
||||
end,
|
||||
%% Auth should be a string with the format: user@server:password
|
||||
%% Note that password can contain additional characters '@' and ':'
|
||||
case str:chr(Auth, $:) of
|
||||
0 ->
|
||||
undefined;
|
||||
Pos ->
|
||||
{User, <<$:, Pass/binary>>} = erlang:split_binary(Auth, Pos-1),
|
||||
PassUtf8 = unicode:characters_to_binary(binary_to_list(Pass), utf8),
|
||||
{User, PassUtf8}
|
||||
try base64:decode(Auth64) of
|
||||
Auth ->
|
||||
case binary:split(Auth, <<":">>) of
|
||||
[User, Pass] ->
|
||||
PassUtf8 = unicode:characters_to_binary(Pass, utf8),
|
||||
{User, PassUtf8};
|
||||
_ ->
|
||||
invalid
|
||||
end
|
||||
catch _:_ ->
|
||||
invalid
|
||||
end;
|
||||
parse_auth(<<"Bearer ", SToken/binary>>) ->
|
||||
Token = str:strip(SToken),
|
||||
{oauth, Token, []};
|
||||
parse_auth(<<_/binary>>) -> undefined.
|
||||
parse_auth(<<_/binary>>) ->
|
||||
invalid.
|
||||
|
||||
parse_urlencoded(S) ->
|
||||
parse_urlencoded(S, nokey, <<>>, key).
|
||||
|
@ -254,6 +254,7 @@ get_auth_admin(Auth, HostHTTP, RPath, Method) ->
|
||||
catch _:{bad_jid, _} ->
|
||||
{unauthorized, <<"badformed-jid">>}
|
||||
end;
|
||||
invalid -> {unauthorized, <<"no-auth-provided">>};
|
||||
undefined -> {unauthorized, <<"no-auth-provided">>}
|
||||
end.
|
||||
|
||||
|
@ -139,28 +139,30 @@ depends(_Host, _Opts) ->
|
||||
|
||||
extract_auth(#request{auth = HTTPAuth, ip = {IP, _}, opts = Opts}) ->
|
||||
Info = case HTTPAuth of
|
||||
{SJID, Pass} ->
|
||||
try jid:decode(SJID) of
|
||||
{SJID, Pass} ->
|
||||
try jid:decode(SJID) of
|
||||
#jid{luser = User, lserver = Server} ->
|
||||
case ejabberd_auth:check_password(User, <<"">>, Server, Pass) of
|
||||
case ejabberd_auth:check_password(User, <<"">>, Server, Pass) of
|
||||
true ->
|
||||
#{usr => {User, Server, <<"">>}, caller_server => Server};
|
||||
false ->
|
||||
{error, invalid_auth}
|
||||
end
|
||||
catch _:{bad_jid, _} ->
|
||||
{error, invalid_auth}
|
||||
end;
|
||||
{oauth, Token, _} ->
|
||||
end
|
||||
catch _:{bad_jid, _} ->
|
||||
{error, invalid_auth}
|
||||
end;
|
||||
{oauth, Token, _} ->
|
||||
case ejabberd_oauth:check_token(Token) of
|
||||
{ok, {U, S}, Scope} ->
|
||||
#{usr => {U, S, <<"">>}, oauth_scope => Scope, caller_server => S};
|
||||
{false, Reason} ->
|
||||
{error, Reason}
|
||||
end;
|
||||
_ ->
|
||||
end;
|
||||
invalid ->
|
||||
{error, invalid_auth};
|
||||
_ ->
|
||||
#{}
|
||||
end,
|
||||
end,
|
||||
case Info of
|
||||
Map when is_map(Map) ->
|
||||
Tag = proplists:get_value(tag, Opts, <<>>),
|
||||
|
Loading…
Reference in New Issue
Block a user