aboutsummaryrefslogtreecommitdiffstats
path: root/examples/static_world
diff options
context:
space:
mode:
authorLoïc Hoguin <[email protected]>2013-01-30 22:13:31 +0100
committerLoïc Hoguin <[email protected]>2013-01-30 22:13:31 +0100
commitf96e20aef7cce6d47535ab63c36452f6c9e1c444 (patch)
treeb6ae3cd187ebe6d6c2eb48819f4cd4be0253757f /examples/static_world
parenteaaa81cce693e6dbbe2a48a594cd4bcd424c0495 (diff)
downloadcowboy-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.md49
-rw-r--r--examples/static_world/priv/small.mp4bin0 -> 383631 bytes
-rw-r--r--examples/static_world/priv/small.ogvbin0 -> 872453 bytes
-rw-r--r--examples/static_world/priv/test.txt1
-rw-r--r--examples/static_world/priv/video.html11
-rw-r--r--examples/static_world/rebar.config6
-rw-r--r--examples/static_world/src/static_world.app.src15
-rw-r--r--examples/static_world/src/static_world.erl14
-rw-r--r--examples/static_world/src/static_world_app.erl28
-rw-r--r--examples/static_world/src/static_world_sup.erl23
-rwxr-xr-xexamples/static_world/start.sh4
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
new file mode 100644
index 0000000..1fc4788
--- /dev/null
+++ b/examples/static_world/priv/small.mp4
Binary files differ
diff --git a/examples/static_world/priv/small.ogv b/examples/static_world/priv/small.ogv
new file mode 100644
index 0000000..6409d6e
--- /dev/null
+++ b/examples/static_world/priv/small.ogv
Binary files differ
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\")."