Cleaner request parameters in Elixir web applications 🙌
BetterParams
is a simple Elixir Plug that allows passed
request parameters to be called as atoms
instead of Strings. The
sole purpose of this Plug is to pattern match on maps with atom keys
instead of string keys in routers/controllers to calm my OCD down.
Once installed, it lets you pattern match request parameters like
%{id: id}
instead of %{"id" => id}
in Phoenix applications:
# web/controllers/some_controller.ex
def show(conn, %{id: id}) do
# do something
end
def create(conn, %{id: id, post: %{title: title, body: body}}) do
# do something
end
String.to_existing_atom
to prevent
against DoS attacks, so it only converts those params
to atoms that you use in your application.String
and Atom
keys (that have already been defined in the
application).Plug.Router
based applications, you can also access request
params similarly by calling them like conn.params[:id]
or
conn.params.post.title
.Add better_params
to your project dependencies in mix.exs
:
def deps do
[{:better_params, "~> 0.5.0"}]
end
For Phoenix applications, call the plug at the end of the controller
method in web/web.ex
(inside the quote
block):
# web/web.ex
def controller do
quote do
use Phoenix.Controller
# Other stuff...
plug BetterParams
end
end
Alternatively, you can also call it your Router Pipelines or in individual controllers directly.
For other applications using Plug.Router
, call the Plug anytime after
calling the :match
and :dispatch
plugs:
defmodule MyApp.Router do
use Plug.Router
plug :match
plug :dispatch
plug BetterParams
# Rest of the router...
end
If your use case calls for a params object with only Atom
keys, you
may pass the option drop_string_keys
to the plug. Much as it says on
the can, this will replace the String
-type keys altogether, rather
than preserving them alongside the Atom
keys.
plug BetterParams, drop_string_keys: true
params
mappath_params
body_params
query_params
This package is available as open source under the terms of the MIT License.