-
- Add
repo
as an override option to the plugs
- Add
- Enhancements
- Use
:extra_applications
opt
- Use
- Enhancements
- Add
non_id_actions
opt
- Add
- Bug fixes
- Do not clobber resources in the
Conn
on index action if they are of the same model
- Do not clobber resources in the
- Relax Ecto version requirements
- Bug fixes
- Use Macro.underscore/1 instead of Mix.Utils.underscore/1 to avoid :mix dependency on production
- Enhancements
- You can now tell Canary to search for a resource using a field other than the default
:id
by using the:id_field
option. Note that the specified field must be able to uniquely identify any resource in the specified table.
- You can now tell Canary to search for a resource using a field other than the default
- Dependency changes
- Elixir ~> 1.2 is now required
- Ecto ~> 1.1 is now required
- Enhancements
- If both an
:unauthorized_handler
and a:not_found_handler
are specified forload_and_authorize_resource
, and the request meets the criteria for both, the:unauthorized_handler
will be called first.
- If both an
- Bug Fixes
- If more than one handler are specified and the first handler halts the request, the second handler will be skipped.
- Enhancements
- Canary can now be configured to call a user-defined function when a resource is not found. The function is specified and used in a similar manner to
:unauthorized_handler
.
- Canary can now be configured to call a user-defined function when a resource is not found. The function is specified and used in a similar manner to
- Bug Fixes
- Disabled protocol consolidation in order for tests to work on Elixir 1.2
- Deprecations
- Canary now looks for the current action in
conn.assigns.canary_action
rather thanconn.assigns.action
in order to avoid conflicts. Theaction
key is deprecated.
- Canary now looks for the current action in
- Enhancements
- Canary can now be configured to call a user-defined function when authorization fails. Canary will pass the
Plug.Conn
for the request to the given function. The handler should accept aPlug.Conn
as its only argument, and should return aPlug.Conn
.- For example, to have Canary call
Helpers.handle_unauthorized/1
:
config :canary, unauthorized_handler: {Helpers, :handle_unauthorized}
- You can also specify the
:unauthorized_handler
on an individual basis by specifying the:unauthorized_handler
opt
in the plug call like so:
plug :load_and_authorize_resource Post, unauthorized_handler: {Helpers, :handle_unauthorized}
- For example, to have Canary call
- Canary can now be configured to call a user-defined function when authorization fails. Canary will pass the
- Enhancements
- Resources can now be loaded on
:new
and:create
actions, whenpersisted: true
is specified in the plug call. This allows parent resources to be loaded when a child is created. For example, if aPost
resource has multipleComment
children, you may want to load the parentPost
when creating a newComment
. You can load the parentPost
with a separate
This will cause Canary to try to load the correspondingplug :load_and_authorize_resource, model: Post, id_name: "post_id", persisted: true, only: [:create]
Post
from the database when creating aComment
at the URL/posts/:post_id/comments
- Resources can now be loaded on
-
Bug fix
- Correctly checks
conn.assigns
for pre-existing resource
- Correctly checks
-
Deprecations
- Canary now favours looking for the current action in
conn.assigns.canary_action
rather thanconn.assigns.action
in order to avoid conflicts. Theaction
key is deprecated
- Canary now favours looking for the current action in
-
Enhancements
- The name of the id in
conn.params
can now be specified with theid_name
opt
- The name of the id in