-
Notifications
You must be signed in to change notification settings - Fork 5
Using Cowmachine
Marc Worrell edited this page May 31, 2022
·
7 revisions
Cowmachine is at Hex, in your rebar.config
file use:
{deps, [
cowmachine
]}.
You can also use the direct Git url and use the development version:
{deps, [
{cowmachine, {git, "https://github.com/zotonic/cowmachine.git", {branch, "master"}}}
]}.
Cowmachine can be called from your Cowboy middleware:
-spec execute(Req, Env) -> {ok, Req, Env} | {stop, Req}
when Req::cowboy_req:req(), Env::cowboy_middleware:env().
execute(Req, Env) ->
% Replace below with your own controller module
Controller = mycontroller,
Env1 = Env#{
cowmachine_controller => Controller,
cowmachine_controller_options => []
},
Context = #{
controller => Controller,
cowreq => Req,
cowenv => Env1
},
% Set options for the cowmachine and handle the request
Options = #{
on_welformed =>
fun(Ctx) ->
% Perform anything after well-formedness check of your request
% Examples are parsing the query args, or authentication
Ctx
end
},
cowmachine:request(Context, Options).
Or just use the default Cowmachine middleware:
#{
middlewares => [
% ... add your dispatcher middlware
cowmachine
],
request_timeout => 60000,
env => #{
% If no dispatcher, default to `mycontroller` as the cowmachine
% controller.
cowmachine_controller => mycontroller
}
}.
You can use the Zotonic Dispatch Compiler to match your controller paths against the request.
The controller provides the callback functions to handle the request.
The controller is an Erlang module implementing these callback functions, only functions that return some non-default value need to be implemented.