From c1f1da937854c962cf7125b2c47db4589abb92ac Mon Sep 17 00:00:00 2001 From: Turtle Date: Mon, 26 Jul 2021 14:48:24 +0800 Subject: [PATCH 1/4] trails_handler supports parameter --- src/trails_handler.erl | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/trails_handler.erl b/src/trails_handler.erl index a8b08c7..31b3457 100644 --- a/src/trails_handler.erl +++ b/src/trails_handler.erl @@ -9,5 +9,6 @@ %% @doc Returns the cowboy routes defined in the called module. -callback trails() -> trails:trails(). --spec trails(module()) -> trails:trails(). +-spec trails(module() | {module(), map()}) -> trails:trails(). +trails({Module, Opts}) -> Module:trails(Opts); trails(Module) -> Module:trails(). From f114d1ccdbf43f2d791ca05acc400bc6f23ee2d0 Mon Sep 17 00:00:00 2001 From: Turtle Date: Mon, 26 Jul 2021 15:24:49 +0800 Subject: [PATCH 2/4] add trails/1 callback --- src/trails_handler.erl | 1 + 1 file changed, 1 insertion(+) diff --git a/src/trails_handler.erl b/src/trails_handler.erl index 31b3457..7156821 100644 --- a/src/trails_handler.erl +++ b/src/trails_handler.erl @@ -8,6 +8,7 @@ %% @doc Returns the cowboy routes defined in the called module. -callback trails() -> trails:trails(). +-callback trails(Opts :: map()) -> trails:trails(). -spec trails(module() | {module(), map()}) -> trails:trails(). trails({Module, Opts}) -> Module:trails(Opts); From 778c0ea5ecebdd820dbf503b96f62f73d4f62fac Mon Sep 17 00:00:00 2001 From: Turtle Date: Mon, 26 Jul 2021 18:48:43 +0800 Subject: [PATCH 3/4] Update README && add more test cases --- README.md | 5 +++-- src/trails_handler.erl | 1 + test/trails_SUITE.erl | 8 ++++++++ test/trails_test3_handler.erl | 12 ++++++++++++ 4 files changed, 24 insertions(+), 2 deletions(-) create mode 100644 test/trails_test3_handler.erl diff --git a/README.md b/README.md index 9f4b07b..86a577c 100644 --- a/README.md +++ b/README.md @@ -101,11 +101,11 @@ Dispatch = cowboy_router:compile(Routes), ``` But now with `trails` you're able to define the routes on each resource handler. -The handler must implement the callback `trails/0` and return the specific +The handler must implement the callback `trails/0` or `trails/1` and return the specific routes for that handler. For a better understanding, you can check out the examples in the `test` folder ([trails_test_handler](./test/trails_test_handler.erl)). -Once you have implemented the `trails/0` callback on your handlers, you can do +Once you have implemented the `trails/0` or `trails/1` callback on your handlers, you can do something like this: ```erlang @@ -116,6 +116,7 @@ Handlers = , spts_serpents_handler , spts_single_serpent_handler , spts_news_handler + , {support_params_handler, #{key => value}} ], Trails = [ {"/", cowboy_static, {file, "www/index.html"}} diff --git a/src/trails_handler.erl b/src/trails_handler.erl index 7156821..c462a65 100644 --- a/src/trails_handler.erl +++ b/src/trails_handler.erl @@ -9,6 +9,7 @@ %% @doc Returns the cowboy routes defined in the called module. -callback trails() -> trails:trails(). -callback trails(Opts :: map()) -> trails:trails(). +-optional_callbacks([trails/0, trails/1]). -spec trails(module() | {module(), map()}) -> trails:trails(). trails({Module, Opts}) -> Module:trails(Opts); diff --git a/test/trails_SUITE.erl b/test/trails_SUITE.erl index ad0989c..b6791b5 100644 --- a/test/trails_SUITE.erl +++ b/test/trails_SUITE.erl @@ -312,14 +312,22 @@ basic_trails_routes(_Config) -> , {"/api/resource1/[:id]", trails_test_handler, []} , {"/api/:id/resource2", trails_test_handler, [arg0]} ], + ExpectedResponse4 = + [ {"/api/resource5/[:id]", trails_test3_handler, []} + , {"/api/:id/resource6", trails_test3_handler, [#{test_key => test_value}]} + ] ++ ExpectedResponse3, Handlers1 = [trails_test_handler, trails_test2_handler], Handlers2 = [trails_test2_handler, trails_test_handler], + Handlers3 = [{trails_test3_handler, #{test_key => test_value}}], Trails1 = StaticRoutes ++ trails:trails(Handlers1), ExpectedResponse1 = Trails1, Trails2 = StaticRoutes ++ trails:trails(trails_test_handler), ExpectedResponse2 = Trails2, Trails3 = StaticRoutes ++ trails:trails(Handlers2), ExpectedResponse3 = Trails3, + Trails4 = trails:trails(Handlers3) ++ Trails3, + ExpectedResponse4 = Trails4, + {comment, ""}. -spec trails_store(config()) -> {atom(), string()}. diff --git a/test/trails_test3_handler.erl b/test/trails_test3_handler.erl new file mode 100644 index 0000000..588200c --- /dev/null +++ b/test/trails_test3_handler.erl @@ -0,0 +1,12 @@ +-module(trails_test3_handler). + +-behaviour(trails_handler). + +%% API +-export([trails/1]). + +trails(Opts) -> + [ + {"/api/resource5/[:id]", trails_test3_handler, []}, + {"/api/:id/resource6", trails_test3_handler, [Opts]} + ]. From d48209ba81a8dbe968297a22ed27caddf71553cf Mon Sep 17 00:00:00 2001 From: Turtle Date: Tue, 27 Jul 2021 09:39:25 +0800 Subject: [PATCH 4/4] Update README && add more test cases --- test/trails_SUITE.erl | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/test/trails_SUITE.erl b/test/trails_SUITE.erl index b6791b5..f53fd9b 100644 --- a/test/trails_SUITE.erl +++ b/test/trails_SUITE.erl @@ -325,9 +325,8 @@ basic_trails_routes(_Config) -> ExpectedResponse2 = Trails2, Trails3 = StaticRoutes ++ trails:trails(Handlers2), ExpectedResponse3 = Trails3, - Trails4 = trails:trails(Handlers3) ++ Trails3, + Trails4 = trails:trails(Handlers3) ++ Trails3, ExpectedResponse4 = Trails4, - {comment, ""}. -spec trails_store(config()) -> {atom(), string()}.