mirror of
https://github.com/ninenines/cowboy.git
synced 2025-07-14 12:20:24 +00:00
Fix rest_basic_auth example
This commit is contained in:
parent
a4fb56018e
commit
a55679b231
3 changed files with 150 additions and 11 deletions
|
@ -9,7 +9,7 @@ $ make run
|
||||||
|
|
||||||
Then point your browser to http://localhost:8080
|
Then point your browser to http://localhost:8080
|
||||||
|
|
||||||
== Example output
|
== HTTP/1.1 example output
|
||||||
|
|
||||||
Request with no authentication:
|
Request with no authentication:
|
||||||
|
|
||||||
|
@ -38,3 +38,115 @@ content-type: text/plain
|
||||||
|
|
||||||
Hello, Alladin!
|
Hello, Alladin!
|
||||||
----
|
----
|
||||||
|
|
||||||
|
== HTTP/2 example output
|
||||||
|
|
||||||
|
Request with no authentication:
|
||||||
|
|
||||||
|
[source,bash]
|
||||||
|
----
|
||||||
|
$ nghttp -v http://localhost:8080
|
||||||
|
[ 0.000] Connected
|
||||||
|
[ 0.000] send SETTINGS frame <length=12, flags=0x00, stream_id=0>
|
||||||
|
(niv=2)
|
||||||
|
[SETTINGS_MAX_CONCURRENT_STREAMS(0x03):100]
|
||||||
|
[SETTINGS_INITIAL_WINDOW_SIZE(0x04):65535]
|
||||||
|
[ 0.000] send PRIORITY frame <length=5, flags=0x00, stream_id=3>
|
||||||
|
(dep_stream_id=0, weight=201, exclusive=0)
|
||||||
|
[ 0.000] send PRIORITY frame <length=5, flags=0x00, stream_id=5>
|
||||||
|
(dep_stream_id=0, weight=101, exclusive=0)
|
||||||
|
[ 0.000] send PRIORITY frame <length=5, flags=0x00, stream_id=7>
|
||||||
|
(dep_stream_id=0, weight=1, exclusive=0)
|
||||||
|
[ 0.000] send PRIORITY frame <length=5, flags=0x00, stream_id=9>
|
||||||
|
(dep_stream_id=7, weight=1, exclusive=0)
|
||||||
|
[ 0.000] send PRIORITY frame <length=5, flags=0x00, stream_id=11>
|
||||||
|
(dep_stream_id=3, weight=1, exclusive=0)
|
||||||
|
[ 0.000] send HEADERS frame <length=38, flags=0x25, stream_id=13>
|
||||||
|
; END_STREAM | END_HEADERS | PRIORITY
|
||||||
|
(padlen=0, dep_stream_id=11, weight=16, exclusive=0)
|
||||||
|
; Open new stream
|
||||||
|
:method: GET
|
||||||
|
:path: /
|
||||||
|
:scheme: http
|
||||||
|
:authority: localhost:8080
|
||||||
|
accept: */*
|
||||||
|
accept-encoding: gzip, deflate
|
||||||
|
user-agent: nghttp2/1.7.1
|
||||||
|
[ 0.004] recv SETTINGS frame <length=0, flags=0x00, stream_id=0>
|
||||||
|
(niv=0)
|
||||||
|
[ 0.004] recv SETTINGS frame <length=0, flags=0x01, stream_id=0>
|
||||||
|
; ACK
|
||||||
|
(niv=0)
|
||||||
|
[ 0.004] send SETTINGS frame <length=0, flags=0x01, stream_id=0>
|
||||||
|
; ACK
|
||||||
|
(niv=0)
|
||||||
|
[ 0.004] recv (stream_id=13) :status: 401
|
||||||
|
[ 0.004] recv (stream_id=13) content-length: 0
|
||||||
|
[ 0.004] recv (stream_id=13) date: Tue, 14 Jun 2016 09:15:56 GMT
|
||||||
|
[ 0.004] recv (stream_id=13) server: Cowboy
|
||||||
|
[ 0.004] recv (stream_id=13) www-authenticate: Basic realm="cowboy"
|
||||||
|
[ 0.004] recv HEADERS frame <length=56, flags=0x04, stream_id=13>
|
||||||
|
; END_HEADERS
|
||||||
|
(padlen=0)
|
||||||
|
; First response header
|
||||||
|
[ 0.004] recv DATA frame <length=0, flags=0x01, stream_id=13>
|
||||||
|
; END_STREAM
|
||||||
|
[ 0.004] send GOAWAY frame <length=8, flags=0x00, stream_id=0>
|
||||||
|
(last_stream_id=0, error_code=NO_ERROR(0x00), opaque_data(0)=[])
|
||||||
|
----
|
||||||
|
|
||||||
|
Request with authentication:
|
||||||
|
|
||||||
|
[source,bash]
|
||||||
|
----
|
||||||
|
$ nghttp -v -H "Authorization: Basic `echo -n Alladin:open sesame | base64`" http://localhost:8080
|
||||||
|
[ 0.000] Connected
|
||||||
|
[ 0.000] send SETTINGS frame <length=12, flags=0x00, stream_id=0>
|
||||||
|
(niv=2)
|
||||||
|
[SETTINGS_MAX_CONCURRENT_STREAMS(0x03):100]
|
||||||
|
[SETTINGS_INITIAL_WINDOW_SIZE(0x04):65535]
|
||||||
|
[ 0.000] send PRIORITY frame <length=5, flags=0x00, stream_id=3>
|
||||||
|
(dep_stream_id=0, weight=201, exclusive=0)
|
||||||
|
[ 0.000] send PRIORITY frame <length=5, flags=0x00, stream_id=5>
|
||||||
|
(dep_stream_id=0, weight=101, exclusive=0)
|
||||||
|
[ 0.000] send PRIORITY frame <length=5, flags=0x00, stream_id=7>
|
||||||
|
(dep_stream_id=0, weight=1, exclusive=0)
|
||||||
|
[ 0.000] send PRIORITY frame <length=5, flags=0x00, stream_id=9>
|
||||||
|
(dep_stream_id=7, weight=1, exclusive=0)
|
||||||
|
[ 0.001] send PRIORITY frame <length=5, flags=0x00, stream_id=11>
|
||||||
|
(dep_stream_id=3, weight=1, exclusive=0)
|
||||||
|
[ 0.001] send HEADERS frame <length=68, flags=0x25, stream_id=13>
|
||||||
|
; END_STREAM | END_HEADERS | PRIORITY
|
||||||
|
(padlen=0, dep_stream_id=11, weight=16, exclusive=0)
|
||||||
|
; Open new stream
|
||||||
|
:method: GET
|
||||||
|
:path: /
|
||||||
|
:scheme: http
|
||||||
|
:authority: localhost:8080
|
||||||
|
accept: */*
|
||||||
|
accept-encoding: gzip, deflate
|
||||||
|
user-agent: nghttp2/1.7.1
|
||||||
|
authorization: Basic QWxsYWRpbjpvcGVuIHNlc2FtZQ==
|
||||||
|
[ 0.002] recv SETTINGS frame <length=0, flags=0x00, stream_id=0>
|
||||||
|
(niv=0)
|
||||||
|
[ 0.002] recv SETTINGS frame <length=0, flags=0x01, stream_id=0>
|
||||||
|
; ACK
|
||||||
|
(niv=0)
|
||||||
|
[ 0.002] send SETTINGS frame <length=0, flags=0x01, stream_id=0>
|
||||||
|
; ACK
|
||||||
|
(niv=0)
|
||||||
|
[ 0.004] recv (stream_id=13) :status: 200
|
||||||
|
[ 0.004] recv (stream_id=13) content-length: 16
|
||||||
|
[ 0.004] recv (stream_id=13) content-type: text/plain
|
||||||
|
[ 0.004] recv (stream_id=13) date: Tue, 14 Jun 2016 09:15:48 GMT
|
||||||
|
[ 0.004] recv (stream_id=13) server: Cowboy
|
||||||
|
[ 0.004] recv HEADERS frame <length=45, flags=0x04, stream_id=13>
|
||||||
|
; END_HEADERS
|
||||||
|
(padlen=0)
|
||||||
|
; First response header
|
||||||
|
Hello, Alladin!
|
||||||
|
[ 0.004] recv DATA frame <length=16, flags=0x01, stream_id=13>
|
||||||
|
; END_STREAM
|
||||||
|
[ 0.004] send GOAWAY frame <length=8, flags=0x00, stream_id=0>
|
||||||
|
(last_stream_id=0, error_code=NO_ERROR(0x00), opaque_data(0)=[])
|
||||||
|
----
|
||||||
|
|
|
@ -16,9 +16,9 @@ start(_Type, _Args) ->
|
||||||
{"/", toppage_handler, []}
|
{"/", toppage_handler, []}
|
||||||
]}
|
]}
|
||||||
]),
|
]),
|
||||||
{ok, _} = cowboy:start_http(http, 100, [{port, 8080}], [
|
{ok, _} = cowboy:start_clear(http, 100, [{port, 8080}], #{
|
||||||
{env, [{dispatch, Dispatch}]}
|
env => #{dispatch => Dispatch}
|
||||||
]),
|
}),
|
||||||
rest_basic_auth_sup:start_link().
|
rest_basic_auth_sup:start_link().
|
||||||
|
|
||||||
stop(_State) ->
|
stop(_State) ->
|
||||||
|
|
|
@ -185,17 +185,25 @@ rest_hello_world(Config) ->
|
||||||
end.
|
end.
|
||||||
|
|
||||||
do_rest_hello_world(Transport, Protocol, Config) ->
|
do_rest_hello_world(Transport, Protocol, Config) ->
|
||||||
<< "<html>", _/bits >> = do_rest_get(Transport, Protocol, "/", undefined, Config),
|
<< "<html>", _/bits >> = do_rest_get(Transport, Protocol,
|
||||||
<< "REST Hello World as text!" >> = do_rest_get(Transport, Protocol, "/", <<"text/plain">>, Config),
|
"/", undefined, undefined, Config),
|
||||||
<< "{\"rest\": \"Hello World!\"}" >> = do_rest_get(Transport, Protocol, "/", <<"application/json">>, Config),
|
<< "REST Hello World as text!" >> = do_rest_get(Transport, Protocol,
|
||||||
not_acceptable = do_rest_get(Transport, Protocol, "/", <<"text/css">>, Config),
|
"/", <<"text/plain">>, undefined, Config),
|
||||||
|
<< "{\"rest\": \"Hello World!\"}" >> = do_rest_get(Transport, Protocol,
|
||||||
|
"/", <<"application/json">>, undefined, Config),
|
||||||
|
not_acceptable = do_rest_get(Transport, Protocol,
|
||||||
|
"/", <<"text/css">>, undefined, Config),
|
||||||
ok.
|
ok.
|
||||||
|
|
||||||
do_rest_get(Transport, Protocol, Path, Accept, Config) ->
|
do_rest_get(Transport, Protocol, Path, Accept, Auth, Config) ->
|
||||||
ReqHeaders = case Accept of
|
ReqHeaders0 = case Accept of
|
||||||
undefined -> [];
|
undefined -> [];
|
||||||
_ -> [{<<"accept">>, Accept}]
|
_ -> [{<<"accept">>, Accept}]
|
||||||
end,
|
end,
|
||||||
|
ReqHeaders = case Auth of
|
||||||
|
undefined -> ReqHeaders0;
|
||||||
|
_ -> [{<<"authorization">>, [<<"Basic ">>, base64:encode(Auth)]}|ReqHeaders0]
|
||||||
|
end,
|
||||||
case do_get(Transport, Protocol, Path, ReqHeaders, Config) of
|
case do_get(Transport, Protocol, Path, ReqHeaders, Config) of
|
||||||
{200, RespHeaders, Body} ->
|
{200, RespHeaders, Body} ->
|
||||||
Accept = case Accept of
|
Accept = case Accept of
|
||||||
|
@ -205,10 +213,29 @@ do_rest_get(Transport, Protocol, Path, Accept, Config) ->
|
||||||
ContentType
|
ContentType
|
||||||
end,
|
end,
|
||||||
Body;
|
Body;
|
||||||
|
{401, _, _} ->
|
||||||
|
unauthorized;
|
||||||
{406, _, _} ->
|
{406, _, _} ->
|
||||||
not_acceptable
|
not_acceptable
|
||||||
end.
|
end.
|
||||||
|
|
||||||
|
%% REST basic auth.
|
||||||
|
|
||||||
|
rest_basic_auth(Config) ->
|
||||||
|
doc("REST basic authorization example."),
|
||||||
|
try
|
||||||
|
do_compile_and_start(rest_basic_auth),
|
||||||
|
do_rest_basic_auth(tcp, http, Config),
|
||||||
|
do_rest_basic_auth(tcp, http2, Config)
|
||||||
|
after
|
||||||
|
do_stop(rest_basic_auth)
|
||||||
|
end.
|
||||||
|
|
||||||
|
do_rest_basic_auth(Transport, Protocol, Config) ->
|
||||||
|
unauthorized = do_rest_get(Transport, Protocol, "/", undefined, undefined, Config),
|
||||||
|
<<"Hello, Alladin!\n">> = do_rest_get(Transport, Protocol, "/", undefined, "Alladin:open sesame", Config),
|
||||||
|
ok.
|
||||||
|
|
||||||
%% File server.
|
%% File server.
|
||||||
|
|
||||||
file_server(Config) ->
|
file_server(Config) ->
|
||||||
|
@ -225,7 +252,7 @@ do_file_server(Transport, Protocol, Config) ->
|
||||||
%% Directory.
|
%% Directory.
|
||||||
{200, DirHeaders, <<"<!DOCTYPE html><html>", _/bits >>} = do_get(Transport, Protocol, "/", Config),
|
{200, DirHeaders, <<"<!DOCTYPE html><html>", _/bits >>} = do_get(Transport, Protocol, "/", Config),
|
||||||
{_, <<"text/html">>} = lists:keyfind(<<"content-type">>, 1, DirHeaders),
|
{_, <<"text/html">>} = lists:keyfind(<<"content-type">>, 1, DirHeaders),
|
||||||
_ = do_rest_get(Transport, Protocol, "/", <<"application/json">>, Config),
|
_ = do_rest_get(Transport, Protocol, "/", <<"application/json">>, undefined, Config),
|
||||||
%% Files.
|
%% Files.
|
||||||
{200, _, _} = do_get(Transport, Protocol, "/small.mp4", Config),
|
{200, _, _} = do_get(Transport, Protocol, "/small.mp4", Config),
|
||||||
{200, _, _} = do_get(Transport, Protocol, "/small.ogv", Config),
|
{200, _, _} = do_get(Transport, Protocol, "/small.ogv", Config),
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue