diff options
author | Loïc Hoguin <[email protected]> | 2013-01-30 22:13:31 +0100 |
---|---|---|
committer | Loïc Hoguin <[email protected]> | 2013-01-30 22:13:31 +0100 |
commit | f96e20aef7cce6d47535ab63c36452f6c9e1c444 (patch) | |
tree | b6ae3cd187ebe6d6c2eb48819f4cd4be0253757f /examples/static_world | |
parent | eaaa81cce693e6dbbe2a48a594cd4bcd424c0495 (diff) | |
download | cowboy-f96e20aef7cce6d47535ab63c36452f6c9e1c444.tar.gz cowboy-f96e20aef7cce6d47535ab63c36452f6c9e1c444.tar.bz2 cowboy-f96e20aef7cce6d47535ab63c36452f6c9e1c444.zip |
Rename example 'static' to 'static_world' to avoid confusion
Diffstat (limited to 'examples/static_world')
-rw-r--r-- | examples/static_world/README.md | 49 | ||||
-rw-r--r-- | examples/static_world/priv/small.mp4 | bin | 0 -> 383631 bytes | |||
-rw-r--r-- | examples/static_world/priv/small.ogv | bin | 0 -> 872453 bytes | |||
-rw-r--r-- | examples/static_world/priv/test.txt | 1 | ||||
-rw-r--r-- | examples/static_world/priv/video.html | 11 | ||||
-rw-r--r-- | examples/static_world/rebar.config | 6 | ||||
-rw-r--r-- | examples/static_world/src/static_world.app.src | 15 | ||||
-rw-r--r-- | examples/static_world/src/static_world.erl | 14 | ||||
-rw-r--r-- | examples/static_world/src/static_world_app.erl | 28 | ||||
-rw-r--r-- | examples/static_world/src/static_world_sup.erl | 23 | ||||
-rwxr-xr-x | examples/static_world/start.sh | 4 |
11 files changed, 151 insertions, 0 deletions
diff --git a/examples/static_world/README.md b/examples/static_world/README.md new file mode 100644 index 0000000..e947ebb --- /dev/null +++ b/examples/static_world/README.md @@ -0,0 +1,49 @@ +Cowboy Static File Handler +========================== + +To compile this example you need rebar in your PATH. + +Type the following command: +``` +$ rebar get-deps compile +``` + +You can then start the Erlang node with the following command: +``` +./start.sh +``` + +Cowboy will serve all the files you put in the priv/ directory. +You can replace the filename given in the example URL with the +one of a file you added to this directory to receive that file. + +Example +------- + +Show that the file is returned as an octet-stream + +``` bash +$ curl -i http://localhost:8080/test.txt +HTTP/1.1 200 OK +connection: keep-alive +server: Cowboy +date: Fri, 28 Sep 2012 04:19:40 GMT +content-length: 52 +Content-Type: application/octet-stream +Last-Modified: Fri, 28 Sep 2012 04:01:20 GMT + +If you read this then the static file server works! +``` + +Finally download and cat the file to verify + +``` bash +$ curl -sLO http://localhost:8080/test.txt +$ cat test.txt +If you read this then the static file server works! +``` + +HTML5 Video Example +------------------- + +Open http://localhost:8080/video.html in your favorite browser. diff --git a/examples/static_world/priv/small.mp4 b/examples/static_world/priv/small.mp4 Binary files differnew file mode 100644 index 0000000..1fc4788 --- /dev/null +++ b/examples/static_world/priv/small.mp4 diff --git a/examples/static_world/priv/small.ogv b/examples/static_world/priv/small.ogv Binary files differnew file mode 100644 index 0000000..6409d6e --- /dev/null +++ b/examples/static_world/priv/small.ogv diff --git a/examples/static_world/priv/test.txt b/examples/static_world/priv/test.txt new file mode 100644 index 0000000..760cddb --- /dev/null +++ b/examples/static_world/priv/test.txt @@ -0,0 +1 @@ +If you read this then the static file server works! diff --git a/examples/static_world/priv/video.html b/examples/static_world/priv/video.html new file mode 100644 index 0000000..eca63ee --- /dev/null +++ b/examples/static_world/priv/video.html @@ -0,0 +1,11 @@ +<!DOCTYPE html> +<html> +<body> + <h1>HTML5 Video Example</h1> + <video controls> + <source src="small.ogv" type="video/ogg"/> + <source src="small.mp4" type="video/mp4"/> + </video> + <p>Videos taken from <a href="http://techslides.com/sample-webm-ogg-and-mp4-video-files-for-html5/">TechSlides</a></p> +</body> +</html> diff --git a/examples/static_world/rebar.config b/examples/static_world/rebar.config new file mode 100644 index 0000000..eb6f194 --- /dev/null +++ b/examples/static_world/rebar.config @@ -0,0 +1,6 @@ +{deps, [ + {cowboy, ".*", + {git, "git://github.com/extend/cowboy.git", "master"}}, + {mimetypes, ".*", + {git, "git://github.com/spawngrid/mimetypes.git", "master"}} +]}. diff --git a/examples/static_world/src/static_world.app.src b/examples/static_world/src/static_world.app.src new file mode 100644 index 0000000..b65995d --- /dev/null +++ b/examples/static_world/src/static_world.app.src @@ -0,0 +1,15 @@ +%% Feel free to use, reuse and abuse the code in this file. + +{application, static_world, [ + {description, "Cowboy static file handler example."}, + {vsn, "1"}, + {modules, []}, + {registered, []}, + {applications, [ + kernel, + stdlib, + cowboy + ]}, + {mod, {static_world_app, []}}, + {env, []} +]}. diff --git a/examples/static_world/src/static_world.erl b/examples/static_world/src/static_world.erl new file mode 100644 index 0000000..6425a99 --- /dev/null +++ b/examples/static_world/src/static_world.erl @@ -0,0 +1,14 @@ +%% Feel free to use, reuse and abuse the code in this file. + +-module(static_world). + +%% API. +-export([start/0]). + +%% API. + +start() -> + ok = application:start(crypto), + ok = application:start(ranch), + ok = application:start(cowboy), + ok = application:start(static_world). diff --git a/examples/static_world/src/static_world_app.erl b/examples/static_world/src/static_world_app.erl new file mode 100644 index 0000000..6470f12 --- /dev/null +++ b/examples/static_world/src/static_world_app.erl @@ -0,0 +1,28 @@ +%% Feel free to use, reuse and abuse the code in this file. + +%% @private +-module(static_world_app). +-behaviour(application). + +%% API. +-export([start/2]). +-export([stop/1]). + +%% API. + +start(_Type, _Args) -> + Dispatch = cowboy_router:compile([ + {'_', [ + {"/[...]", cowboy_static, [ + {directory, {priv_dir, static_world, []}}, + {mimetypes, {fun mimetypes:path_to_mimes/2, default}} + ]} + ]} + ]), + {ok, _} = cowboy:start_http(http, 100, [{port, 8080}], [ + {env, [{dispatch, Dispatch}]} + ]), + static_world_sup:start_link(). + +stop(_State) -> + ok. diff --git a/examples/static_world/src/static_world_sup.erl b/examples/static_world/src/static_world_sup.erl new file mode 100644 index 0000000..a57d07a --- /dev/null +++ b/examples/static_world/src/static_world_sup.erl @@ -0,0 +1,23 @@ +%% Feel free to use, reuse and abuse the code in this file. + +%% @private +-module(static_world_sup). +-behaviour(supervisor). + +%% API. +-export([start_link/0]). + +%% supervisor. +-export([init/1]). + +%% API. + +-spec start_link() -> {ok, pid()}. +start_link() -> + supervisor:start_link({local, ?MODULE}, ?MODULE, []). + +%% supervisor. + +init([]) -> + Procs = [], + {ok, {{one_for_one, 10, 10}, Procs}}. diff --git a/examples/static_world/start.sh b/examples/static_world/start.sh new file mode 100755 index 0000000..995f913 --- /dev/null +++ b/examples/static_world/start.sh @@ -0,0 +1,4 @@ +#!/bin/sh +erl -pa ebin deps/*/ebin -s static_world \ + -eval "io:format(\"Point your browser at http://localhost:8080/test.txt~n\")." \ + -eval "io:format(\"Point your browser at http://localhost:8080/video.html~n\")." |