From 4106ae484c6fbbe72640c83f3ab16130cc824e66 Mon Sep 17 00:00:00 2001 From: Badlop Date: Mon, 30 Jan 2023 15:00:18 +0100 Subject: [PATCH] Add support for handling redirection HTTP Response Codes --- ejabberd_auth_http/src/ejabberd_auth_http.erl | 30 +++++++++++++++---- 1 file changed, 24 insertions(+), 6 deletions(-) diff --git a/ejabberd_auth_http/src/ejabberd_auth_http.erl b/ejabberd_auth_http/src/ejabberd_auth_http.erl index c3b1b64..8389b67 100644 --- a/ejabberd_auth_http/src/ejabberd_auth_http.erl +++ b/ejabberd_auth_http/src/ejabberd_auth_http.erl @@ -213,13 +213,22 @@ make_req(Method, Path, LUser, LServer, Password) -> Connection = cuesport:get_worker(existing_pool_name(LServer)), ?DEBUG("Making request '~s' for user ~s@~s...", [Path, LUser, LServer]), - {ok, {{Code, _Reason}, _RespHeaders, RespBody, _, _}} = case Method of - get -> fusco:request(Connection, <>, - "GET", Header, "", 2, 5000); - post -> fusco:request(Connection, <>, - "POST", [ContentType|Header], Query, 2, 5000) - end, + {Url, MethodStr, Headers, Query2} = + case Method of + get -> {<>, + "GET", + Header, + ""}; + post -> {<>, + "POST", + [ContentType|Header], + Query} + end, + http_request(Connection, Url, MethodStr, Headers, Query2, 0). +http_request(Connection, Url, MethodStr, Headers, Query, RedirectCounter) -> + {ok, {{Code, _Reason}, RespHeaders, RespBody, _, _}} = + fusco:request(Connection, Url, MethodStr, Headers, Query, 2, 5000), ?DEBUG("Request result: ~s: ~p", [Code, RespBody]), case Code of <<"409">> -> {error, conflict}; @@ -231,9 +240,18 @@ make_req(Method, Path, LUser, LServer, Password) -> <<"204">> -> {ok, <<"">>}; <<"201">> -> {ok, <<"created">>}; <<"200">> -> {ok, RespBody}; + R when (R==<<"301">>) or (R==<<"307">>) or (R==<<"308">>) -> + handle_redirect(RespHeaders, Connection, MethodStr, Headers, Query, RedirectCounter+1); _ -> {error, RespBody} end. +handle_redirect(RespHeaders, Connection, MethodStr, Headers, Query, RedirectCounter) + when RedirectCounter < 5 -> + {_, Location} = lists:keyfind(<<"location">>, 1, RespHeaders), + http_request(Connection, Location, MethodStr, Headers, Query, RedirectCounter); +handle_redirect(_, _, _, _, _, _) -> + {error, redirect_loop}. + %%%---------------------------------------------------------------------- %%% Other internal functions %%%----------------------------------------------------------------------