Skip to content

Latest commit

 

History

History
64 lines (41 loc) · 1.6 KB

File metadata and controls

64 lines (41 loc) · 1.6 KB

ActiveModelSerializers::Cancancan

Provides a simple integration between CanCanCan and Active Model Serializers.

Installation

Add this line to your application's Gemfile:

gem 'active_model_serializers_cancancan'

And then execute:

$ bundle

Or install it yourself as:

$ gem install active_model_serializers_cancancan

Usage

Helpers

Serializers now also have access to the same helpers as controllers, namely current_ability, can?, and cannot?.

Ability Serialization

Use the abilities helper method to add an abilities key to the serialized data. For example:

class PostSerializer < ActiveModel::Serializer
  attributes :id
  abilities :show, :update
end

@post.as_json # { id: 1, abilities: { show: true, update: false } }

RESTful Alias

If :restful is passed as an ability it will expand to the 7 default RESTful actions: :index, :show, :new, :create, :edit, :update, :destroy

Overriding an Ability

Abilities are checked by calling the can_#{action}? method. By overriding this method the result for the ability can be customized. For example:

class PostSerializer < ActiveModel::Serializer
  attributes :id
  abilities :show

  def can_show?
    session[:wizard_started] && can?(:show, object)
  end
end

Contributing

  1. Fork it
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create new Pull Request