zobi 4.0.0.rc2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: 69518a2db256e0b503887391e17de15b8007cb16
4
+ data.tar.gz: b13497e78105e33a61f8d083736ac2e023633a91
5
+ SHA512:
6
+ metadata.gz: f99d0a53a9257f453ef2cfc1c3ee6a3f0b288710ffdae88f53352392b1ad532b9108dce9e929d2183f4277fbeb889165bdaf73931a6b2797e95d7dbf1d730d7c
7
+ data.tar.gz: 9fab74b46acb53cad0cb57d861b9e50cd327435e8036c42342d17530ffed9ff3630b246341d2c083183deef9504fcbc85f8c507aab81a26aaf530a96fdad0519
@@ -0,0 +1,170 @@
1
+ Zobi
2
+ ====
3
+
4
+ Zobi helps you to orchestrate your controller behaviors using the following gems :
5
+
6
+ - [**devise**](https://github.com/plataformatec/devise)
7
+ - [**inherited_resources**](https://github.com/josevalim/inherited_resources)
8
+ - [**has_scope**](https://github.com/plataformatec/has_scope)
9
+ - [**kaminari**](https://github.com/amatsuda/kaminari)
10
+ - [**pundit**](https://github.com/elabs/pundit)
11
+ - [**draper**](https://github.com/drapergem/draper)
12
+
13
+ How to use it?
14
+ --------------
15
+
16
+ Add it in your `Gemfile` and run `bundle install`:
17
+
18
+ ```ruby
19
+ gem 'zobi', '~> 4.0.0.rc2'
20
+ ```
21
+
22
+ Next, include Zobi module in your controller and set modules you want to
23
+ include :
24
+
25
+ ```ruby
26
+ extend Zobi
27
+ behaviors :inherited, :scoped, :included, :paginated, :controlled_access, :decorated
28
+ ```
29
+
30
+ Available modules
31
+ -----------------
32
+
33
+ ### Inherited
34
+
35
+ This module uses
36
+ [inherited_resources](https://github.com/josevalim/inherited_resources) gem.
37
+
38
+ This module deals with String Parameters using Parameters classes.
39
+
40
+ A Parameters inherits from Zobi::ParametersSanitizer, and should define the list
41
+ of parameters and nested parameters to accept.
42
+
43
+ If your controller is namespaced, you should define the `resource_type` method to
44
+ override its generic behavior.
45
+
46
+ If your model is namespaced, you should define the defaults resource_class for
47
+ Inherited Resource, ie : `defaults resource_class: ::User::Address`
48
+
49
+ Here is an example :
50
+
51
+ ``` ruby
52
+ module User
53
+ class AddressParameters < Zobi::ParametersSanitizer
54
+
55
+ # Optional, usefull for a namespaced controller, User::AddressesController
56
+ # here.
57
+ def resource_type
58
+ :user_address
59
+ end
60
+
61
+ protected
62
+
63
+ def fields
64
+ [
65
+ :id,
66
+ :street,
67
+ :zip_code,
68
+ nested_attributes: [:id, :foo, :bar]
69
+ ]
70
+ end
71
+ end
72
+ end
73
+ ```
74
+
75
+ By default, Parameters class are discovered using the controller namespace.
76
+ Given a `User::AddressesController`, Zobi will search for
77
+ `User::AddressParameters` class.
78
+
79
+ If you don't want to use Parameters class, you can define the `permitted_params`
80
+ in your controller and perform custom filtering.
81
+
82
+ ### Scoped
83
+
84
+ This module uses [has_scope](https://github.com/plataformatec/has_scope) gem.
85
+
86
+
87
+ ### Included
88
+
89
+ This module only works with ActiveRecord because it uses the
90
+ [Eager Loading Associations of Active Record](http://guides.rubyonrails.org/active_record_querying.html#eager-loading-associations).
91
+
92
+
93
+ ### Paginated
94
+
95
+ This module uses [kaminari](https://github.com/amatsuda/kaminari) gem.
96
+
97
+
98
+ ### Controlled Access
99
+
100
+ This module uses [pundit](https://github.com/elabs/pundit) and
101
+ [devise](https://github.com/plataformatec/devise) gems.
102
+
103
+
104
+ ### Decorated
105
+
106
+ This module uses [draper](https://github.com/drapergem/draper) gem and has a
107
+ dependency on Inherited modules for now.
108
+
109
+ By default, Zobi will try to discover the decorator class to use using the
110
+ current namespece.
111
+
112
+ For example, given a controller named Admin::User::AddressesController, Zobi
113
+ will try to find the appropriate decorator class in this order :
114
+
115
+ Collection :
116
+
117
+ ``` ruby
118
+ Admin::User::AddressesDecorator
119
+ Admin::AddressesDecorator
120
+ AdressesDecorator
121
+ Admin::User::CollectionDecorator
122
+ Admin::CollectionDecorator
123
+ CollectionDecorator
124
+ ```
125
+
126
+ Resource :
127
+
128
+ ``` ruby
129
+ Admin::User::AddressDecorator
130
+ Admin::AddressDecorator
131
+ AdressDecorator
132
+ Admin::User::ResourceDecorator
133
+ Admin::ResourceDecorator
134
+ ResourceDecorator
135
+ ```
136
+
137
+ If this is not the way you organize your decorators, you can override this
138
+ behavior by defining a method called `collection_decorator_class` or
139
+ `decorator_class` which returns the decorator class to use.
140
+
141
+
142
+ # Developing
143
+
144
+ Launch test suite :
145
+
146
+ ``` console
147
+ cd spec/dummy
148
+ bundle exec rake db:test:prepare
149
+ cd ../..
150
+ bundle exec rspec
151
+ ```
152
+
153
+ Launch the dummy app :
154
+
155
+ ``` console
156
+ cd spec/dummy
157
+ bundle exec rake db:migrate
158
+ bundle exec rails s
159
+ ```
160
+
161
+ # Versioning
162
+
163
+ We decided to follow rails versions to simplify update of Zobi when you want to
164
+ upgrade rails.
165
+
166
+ # Credits
167
+
168
+ Copyright (c) 2013 af83
169
+
170
+ Released under the MIT license
@@ -0,0 +1,7 @@
1
+ # encoding: utf-8
2
+
3
+ module Zobi
4
+ class CollectionDecorator < Draper::CollectionDecorator
5
+ include Draper::AutomaticDelegation
6
+ end
7
+ end
@@ -0,0 +1,7 @@
1
+ # encoding: utf-8
2
+
3
+ module Zobi
4
+ class ResourceDecorator < Draper::Decorator
5
+ delegate_all
6
+ end
7
+ end
@@ -0,0 +1,45 @@
1
+ # encoding: utf-8
2
+
3
+ Dir["#{File.dirname(__FILE__)}/zobi/**/*.rb"].each { |f| require f }
4
+
5
+ module Zobi
6
+ BEHAVIORS = [:inherited, :scoped, :included, :paginated, :controlled_access, :decorated].freeze
7
+
8
+ def self.extended base
9
+ base.helper_method :collection, :resource
10
+ end
11
+
12
+ def behaviors *behaviors
13
+ (BEHAVIORS & behaviors).each do |behavior|
14
+ send(:include, behavior_module(behavior))
15
+ end
16
+ send(:include, ::Zobi::InstanceMethods)
17
+ end
18
+
19
+ def behavior_module name
20
+ "Zobi::#{name.to_s.camelize}".constantize
21
+ end
22
+
23
+ def behavior_included? name
24
+ ancestors.include?(behavior_module(name))
25
+ end
26
+
27
+ module InstanceMethods
28
+
29
+ def zobi_resource_class
30
+ return resource_class if self.class.behavior_included?(:inherited)
31
+ self.class.name.demodulize.gsub('Controller', '').singularize.constantize
32
+ end
33
+
34
+ def collection
35
+ return @collection if @collection
36
+ c = zobi_resource_class
37
+ BEHAVIORS.each do |behavior|
38
+ next unless self.class.behavior_included?(behavior)
39
+ c = send :"#{behavior}_collection", c
40
+ end
41
+ @collection = (c.is_a?(Class) ? c.all : c)
42
+ end
43
+
44
+ end
45
+ end
@@ -0,0 +1,77 @@
1
+ # encoding: utf-8
2
+
3
+ module Zobi
4
+ # This module help to manage control access on your collection using pundit.
5
+ #
6
+ module ControlledAccess
7
+
8
+ def self.included base
9
+ base.send :include, Pundit
10
+ base.class_eval do
11
+ before_filter :authorize_resource
12
+
13
+ def policy_scope scope
14
+ Pundit.policy_scope!(controlled_access_user, scope)
15
+ end
16
+
17
+ def policy record
18
+ Pundit.policy!(controlled_access_user, record)
19
+ end
20
+ end
21
+ end
22
+
23
+ protected
24
+
25
+ # Authorize resource, see Policies.
26
+ def authorize_resource
27
+ case action_name
28
+ when build_resources_authorized
29
+ authorize controlled_access_build_resource
30
+ when resources_authorized
31
+ authorize controlled_access_resource
32
+ else
33
+ authorize zobi_resource_class
34
+ end
35
+ end
36
+
37
+ def controlled_access_user
38
+ if self.class.to_s.split('::').first == 'Admin'
39
+ begin
40
+ current_administrator
41
+ rescue NameError
42
+ raise "You need to define the current_administrator method.".inspect
43
+ end
44
+ else
45
+ begin
46
+ current_user
47
+ rescue NameError
48
+ raise "You need to define the current_user method.".inspect
49
+ end
50
+ end
51
+ end
52
+
53
+ private
54
+
55
+ def controlled_access_collection c
56
+ policy_scope c
57
+ end
58
+
59
+ def build_resources_authorized
60
+ /new|create/
61
+ end
62
+
63
+ def resources_authorized
64
+ /edit|update|show|destroy/
65
+ end
66
+
67
+ def controlled_access_build_resource
68
+ return build_resource if respond_to?(:build_resource)
69
+ zobi_resource_class.new params[zobi_resource_class.to_s.to_sym]
70
+ end
71
+
72
+ def controlled_access_resource
73
+ return resource if respond_to?(:resource)
74
+ zobi_resource_class.find(params[:id])
75
+ end
76
+ end
77
+ end
@@ -0,0 +1,32 @@
1
+ # encoding: utf-8
2
+
3
+ module Zobi
4
+ # This module decorate your collection and resource
5
+ # NB: dependencie on Inherited module
6
+ #
7
+ module Decorated
8
+
9
+ def resource
10
+ @resource ||= decorator_class.decorate super
11
+ end
12
+
13
+ protected
14
+
15
+ def collection_decorator_class
16
+ Zobi::Discover.new(self.class, :decorated, :collection).resolve
17
+ end
18
+
19
+ def decorator_class
20
+ Zobi::Discover.new(self.class, :decorated, :resource).resolve
21
+ end
22
+
23
+ private
24
+
25
+ def decorated_collection c
26
+ collection_decorator_class.decorate(
27
+ (c.is_a?(Class) ? c.all : c),
28
+ with: decorator_class
29
+ )
30
+ end
31
+ end
32
+ end
@@ -0,0 +1,70 @@
1
+ # encoding: utf-8
2
+
3
+ module Zobi
4
+ Discover = Struct.new(:klass, :behavior, :type) do
5
+ CONFIG = {
6
+ decorated: {
7
+ suffix: 'Decorator',
8
+ resource: 'ResourceDecorator',
9
+ collection: 'CollectionDecorator'
10
+ }
11
+ }.freeze
12
+
13
+ def resolve
14
+ discovery.each do |klass|
15
+ begin
16
+ return klass.constantize
17
+ rescue NameError
18
+ next
19
+ end
20
+ end
21
+ "Zobi::#{fallback}".constantize
22
+ end
23
+
24
+ private
25
+
26
+ def namespaces
27
+ last = ""
28
+ ns = klass.to_s.split('::')
29
+ ns.pop
30
+ ns.map{|i| last += "::#{i}"}.reverse.push '::'
31
+ end
32
+
33
+ def resource_class
34
+ collection_class.singularize
35
+ end
36
+
37
+ def collection_class
38
+ klass.to_s.demodulize.gsub('Controller', '')
39
+ end
40
+
41
+ def base_class
42
+ type == :resource ? resource_class : collection_class
43
+ end
44
+
45
+ def discovery
46
+ discovery = []
47
+ discovery << self.class.classes_for_namespaces(
48
+ namespaces, "#{base_class}#{suffix}"
49
+ )
50
+ discovery << self.class.classes_for_namespaces(namespaces, fallback)
51
+ discovery.flatten
52
+ end
53
+
54
+ def fallback
55
+ CONFIG[behavior][type]
56
+ end
57
+
58
+ def suffix
59
+ CONFIG[behavior][:suffix]
60
+ end
61
+
62
+ class << self
63
+ def classes_for_namespaces namespaces, base_name
64
+ namespaces.map{|ns|
65
+ "#{ns == '::' ? ns : "#{ns}::"}#{base_name}"
66
+ }
67
+ end
68
+ end
69
+ end
70
+ end
@@ -0,0 +1,6 @@
1
+ # encoding: utf-8
2
+
3
+ module Zobi
4
+ class Engine < Rails::Engine
5
+ end
6
+ end
@@ -0,0 +1,20 @@
1
+ # encoding: utf-8
2
+
3
+ module Zobi
4
+ module Included
5
+
6
+ protected
7
+
8
+ def includes
9
+ nil
10
+ end
11
+
12
+ private
13
+
14
+ def included_collection c
15
+ c = c.includes(*includes) if includes.present?
16
+ c
17
+ end
18
+
19
+ end
20
+ end
@@ -0,0 +1,42 @@
1
+ # encoding: utf-8
2
+
3
+ module Zobi
4
+ # This module add some helpers to controllers.
5
+ #
6
+ # * inherit_resources
7
+ # * params filtering
8
+ #
9
+ module Inherited
10
+ def self.included(klass)
11
+ klass.inherit_resources
12
+ klass.send('include', Inherited::Hidden)
13
+ end
14
+
15
+ private
16
+
17
+ def inherited_collection c
18
+ end_of_association_chain
19
+ end
20
+
21
+ module Hidden
22
+ protected
23
+
24
+ # This method can be overwritted in controllers
25
+ def permitted_params
26
+ @permitted_params ||= parameters_class.new(self, params).params
27
+ end
28
+
29
+ private
30
+
31
+ def parameters_class
32
+ klass = "#{self.class.to_s.sub('Controller', '').singularize}Parameters"
33
+ klass.constantize
34
+ rescue NameError
35
+ raise <<EOT
36
+ You need to define the class #{klass} or overwrite the permitted_params method in your controller.
37
+ EOT
38
+ end
39
+ end
40
+
41
+ end
42
+ end
@@ -0,0 +1,24 @@
1
+ # encoding: utf-8
2
+
3
+ module Zobi
4
+ # This module helps you to paginate your collection using kaminari
5
+ #
6
+ module Paginated
7
+
8
+ def self.included base
9
+ base.send :responders, 'zobi/responders/pagination'
10
+ end
11
+
12
+ protected
13
+
14
+ def paginate_per
15
+ params[:per]
16
+ end
17
+
18
+ private
19
+
20
+ def paginated_collection c
21
+ c.page(params[:page]).per(paginate_per)
22
+ end
23
+ end
24
+ end
@@ -0,0 +1,71 @@
1
+ # encoding: utf-8
2
+ module Zobi
3
+ # This class responsability is to filter parameters before sending it to the
4
+ # model.
5
+ #
6
+ # This class is meant to be inherited.
7
+ #
8
+ # Most of the time, two methods will be overriden: `fields` and
9
+ # `translated_fields`.
10
+ #
11
+ # If you need complex logic based on context of execution (user rights and so
12
+ # on...), you have access to the controller through the `context` attr.
13
+ # Meaning, `context.current_user` is possible. And then, you can implement
14
+ # all the `if` possible in the world.
15
+ #
16
+ class ParametersSanitizer
17
+ attr_reader :context, :canonical_params
18
+ private :context, :canonical_params
19
+
20
+ # @param [ApplicationController] context
21
+ # @param [ActionController::Parameters] canonical_params
22
+ #
23
+ # @return [Sanitizer]
24
+ #
25
+ def initialize(context, canonical_params)
26
+ @context, @canonical_params = context, canonical_params
27
+ end
28
+
29
+ # The only public method. Return sanitized parameters.
30
+ #
31
+ # @return [ActionController::Parameters]
32
+ #
33
+ def params
34
+ canonical_params.permit resource_type => permitted_fields
35
+ end
36
+
37
+ protected
38
+
39
+ # @return [Array] array of fields
40
+ #
41
+ def fields
42
+ []
43
+ end
44
+
45
+ # @return [Array] array of translated fields
46
+ #
47
+ def translated_fields
48
+ []
49
+ end
50
+
51
+ # @return [Array] array of locales
52
+ #
53
+ def locales
54
+ I18n.available_locales
55
+ end
56
+
57
+ # Computes all the fields
58
+ #
59
+ # @return [Array] Complete list of fields
60
+ #
61
+ def permitted_fields
62
+ fields + locales.map {|l| translated_fields.map {|f| "#{f}_#{l}" }}
63
+ end
64
+
65
+ # @return [Symbol] The resource name to be required
66
+ #
67
+ def resource_type
68
+ self.class.to_s.demodulize.gsub('Parameters', '').underscore.to_sym
69
+ end
70
+ end
71
+ end
@@ -0,0 +1,25 @@
1
+ # encoding: utf-8
2
+
3
+ module Zobi
4
+ module Responders
5
+ module PaginationResponder
6
+
7
+ def respond(*)
8
+ if paginated?
9
+ controller.headers['X-Total-Pages'] = resource.total_pages.to_s
10
+ controller.headers['X-Current-Page'] = resource.current_page.to_s
11
+ controller.headers['X-Limit-Value'] = resource.limit_value.to_s
12
+ end
13
+ super
14
+ end
15
+
16
+ private
17
+
18
+ def paginated?
19
+ resource.respond_to?(:total_pages) &&
20
+ resource.respond_to?(:current_page) &&
21
+ resource.respond_to?(:limit_value)
22
+ end
23
+ end
24
+ end
25
+ end
@@ -0,0 +1,32 @@
1
+ # encoding: utf-8
2
+
3
+ module Zobi
4
+ # This module helps you to filter your collection using has_scope
5
+ #
6
+ module Scoped
7
+ def self.included(klass)
8
+ klass.helper_method :filters_list
9
+ klass.before_filter :default_order
10
+ end
11
+
12
+ protected
13
+
14
+ def filters_list
15
+ scopes_configuration.keys
16
+ end
17
+
18
+ private
19
+
20
+ def scoped_collection c
21
+ apply_scopes c
22
+ end
23
+
24
+ def default_order
25
+ return unless params[:by_order]
26
+ {order: 'created_at', direction: 'desc'}.each do |k, v|
27
+ next if params[:by_order][k].present?
28
+ params[:by_order][k] = v
29
+ end
30
+ end
31
+ end
32
+ end
@@ -0,0 +1,4 @@
1
+ # encoding: utf-8
2
+ module Zobi
3
+ VERSION = "4.0.0.rc2"
4
+ end
metadata ADDED
@@ -0,0 +1,283 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: zobi
3
+ version: !ruby/object:Gem::Version
4
+ version: 4.0.0.rc2
5
+ platform: ruby
6
+ authors:
7
+ - klacointe
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2013-11-22 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: rails
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - "~>"
18
+ - !ruby/object:Gem::Version
19
+ version: 4.0.0
20
+ type: :runtime
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - "~>"
25
+ - !ruby/object:Gem::Version
26
+ version: 4.0.0
27
+ - !ruby/object:Gem::Dependency
28
+ name: rspec-rails
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - ">="
32
+ - !ruby/object:Gem::Version
33
+ version: '0'
34
+ type: :development
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - ">="
39
+ - !ruby/object:Gem::Version
40
+ version: '0'
41
+ - !ruby/object:Gem::Dependency
42
+ name: sqlite3
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - ">="
46
+ - !ruby/object:Gem::Version
47
+ version: '0'
48
+ type: :development
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - ">="
53
+ - !ruby/object:Gem::Version
54
+ version: '0'
55
+ - !ruby/object:Gem::Dependency
56
+ name: rake
57
+ requirement: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - ">="
60
+ - !ruby/object:Gem::Version
61
+ version: '0'
62
+ type: :development
63
+ prerelease: false
64
+ version_requirements: !ruby/object:Gem::Requirement
65
+ requirements:
66
+ - - ">="
67
+ - !ruby/object:Gem::Version
68
+ version: '0'
69
+ - !ruby/object:Gem::Dependency
70
+ name: responders
71
+ requirement: !ruby/object:Gem::Requirement
72
+ requirements:
73
+ - - "~>"
74
+ - !ruby/object:Gem::Version
75
+ version: '1.0'
76
+ type: :development
77
+ prerelease: false
78
+ version_requirements: !ruby/object:Gem::Requirement
79
+ requirements:
80
+ - - "~>"
81
+ - !ruby/object:Gem::Version
82
+ version: '1.0'
83
+ - !ruby/object:Gem::Dependency
84
+ name: inherited_resources
85
+ requirement: !ruby/object:Gem::Requirement
86
+ requirements:
87
+ - - "~>"
88
+ - !ruby/object:Gem::Version
89
+ version: '1.4'
90
+ type: :development
91
+ prerelease: false
92
+ version_requirements: !ruby/object:Gem::Requirement
93
+ requirements:
94
+ - - "~>"
95
+ - !ruby/object:Gem::Version
96
+ version: '1.4'
97
+ - !ruby/object:Gem::Dependency
98
+ name: has_scope
99
+ requirement: !ruby/object:Gem::Requirement
100
+ requirements:
101
+ - - "~>"
102
+ - !ruby/object:Gem::Version
103
+ version: 0.6.0.rc
104
+ type: :development
105
+ prerelease: false
106
+ version_requirements: !ruby/object:Gem::Requirement
107
+ requirements:
108
+ - - "~>"
109
+ - !ruby/object:Gem::Version
110
+ version: 0.6.0.rc
111
+ - !ruby/object:Gem::Dependency
112
+ name: kaminari
113
+ requirement: !ruby/object:Gem::Requirement
114
+ requirements:
115
+ - - "~>"
116
+ - !ruby/object:Gem::Version
117
+ version: '0.14'
118
+ type: :development
119
+ prerelease: false
120
+ version_requirements: !ruby/object:Gem::Requirement
121
+ requirements:
122
+ - - "~>"
123
+ - !ruby/object:Gem::Version
124
+ version: '0.14'
125
+ - !ruby/object:Gem::Dependency
126
+ name: pundit
127
+ requirement: !ruby/object:Gem::Requirement
128
+ requirements:
129
+ - - "~>"
130
+ - !ruby/object:Gem::Version
131
+ version: '0.2'
132
+ type: :development
133
+ prerelease: false
134
+ version_requirements: !ruby/object:Gem::Requirement
135
+ requirements:
136
+ - - "~>"
137
+ - !ruby/object:Gem::Version
138
+ version: '0.2'
139
+ - !ruby/object:Gem::Dependency
140
+ name: draper
141
+ requirement: !ruby/object:Gem::Requirement
142
+ requirements:
143
+ - - "~>"
144
+ - !ruby/object:Gem::Version
145
+ version: '1.3'
146
+ type: :development
147
+ prerelease: false
148
+ version_requirements: !ruby/object:Gem::Requirement
149
+ requirements:
150
+ - - "~>"
151
+ - !ruby/object:Gem::Version
152
+ version: '1.3'
153
+ - !ruby/object:Gem::Dependency
154
+ name: devise
155
+ requirement: !ruby/object:Gem::Requirement
156
+ requirements:
157
+ - - "~>"
158
+ - !ruby/object:Gem::Version
159
+ version: '3.2'
160
+ type: :development
161
+ prerelease: false
162
+ version_requirements: !ruby/object:Gem::Requirement
163
+ requirements:
164
+ - - "~>"
165
+ - !ruby/object:Gem::Version
166
+ version: '3.2'
167
+ - !ruby/object:Gem::Dependency
168
+ name: jquery-rails
169
+ requirement: !ruby/object:Gem::Requirement
170
+ requirements:
171
+ - - ">="
172
+ - !ruby/object:Gem::Version
173
+ version: '0'
174
+ type: :development
175
+ prerelease: false
176
+ version_requirements: !ruby/object:Gem::Requirement
177
+ requirements:
178
+ - - ">="
179
+ - !ruby/object:Gem::Version
180
+ version: '0'
181
+ - !ruby/object:Gem::Dependency
182
+ name: faker
183
+ requirement: !ruby/object:Gem::Requirement
184
+ requirements:
185
+ - - ">="
186
+ - !ruby/object:Gem::Version
187
+ version: '0'
188
+ type: :development
189
+ prerelease: false
190
+ version_requirements: !ruby/object:Gem::Requirement
191
+ requirements:
192
+ - - ">="
193
+ - !ruby/object:Gem::Version
194
+ version: '0'
195
+ - !ruby/object:Gem::Dependency
196
+ name: pry-rails
197
+ requirement: !ruby/object:Gem::Requirement
198
+ requirements:
199
+ - - ">="
200
+ - !ruby/object:Gem::Version
201
+ version: '0'
202
+ type: :development
203
+ prerelease: false
204
+ version_requirements: !ruby/object:Gem::Requirement
205
+ requirements:
206
+ - - ">="
207
+ - !ruby/object:Gem::Version
208
+ version: '0'
209
+ - !ruby/object:Gem::Dependency
210
+ name: database_cleaner
211
+ requirement: !ruby/object:Gem::Requirement
212
+ requirements:
213
+ - - ">="
214
+ - !ruby/object:Gem::Version
215
+ version: '0'
216
+ type: :development
217
+ prerelease: false
218
+ version_requirements: !ruby/object:Gem::Requirement
219
+ requirements:
220
+ - - ">="
221
+ - !ruby/object:Gem::Version
222
+ version: '0'
223
+ - !ruby/object:Gem::Dependency
224
+ name: rspec-rails
225
+ requirement: !ruby/object:Gem::Requirement
226
+ requirements:
227
+ - - ">="
228
+ - !ruby/object:Gem::Version
229
+ version: '0'
230
+ type: :development
231
+ prerelease: false
232
+ version_requirements: !ruby/object:Gem::Requirement
233
+ requirements:
234
+ - - ">="
235
+ - !ruby/object:Gem::Version
236
+ version: '0'
237
+ description: Keep your rails controllers DRY while using devise, inherited_resources,
238
+ has_scope, kaminari, pundit and draper
239
+ email: kevinlacointe@gmail.com
240
+ executables: []
241
+ extensions: []
242
+ extra_rdoc_files: []
243
+ files:
244
+ - README.md
245
+ - app/decorators/zobi/collection_decorator.rb
246
+ - app/decorators/zobi/resource_decorator.rb
247
+ - lib/zobi.rb
248
+ - lib/zobi/controlled_access.rb
249
+ - lib/zobi/decorated.rb
250
+ - lib/zobi/discover.rb
251
+ - lib/zobi/engine.rb
252
+ - lib/zobi/included.rb
253
+ - lib/zobi/inherited.rb
254
+ - lib/zobi/paginated.rb
255
+ - lib/zobi/parameters_sanitizer.rb
256
+ - lib/zobi/responders/pagination_responder.rb
257
+ - lib/zobi/scoped.rb
258
+ - lib/zobi/version.rb
259
+ homepage: https://github.com/af83/zobi
260
+ licenses:
261
+ - MIT
262
+ metadata: {}
263
+ post_install_message:
264
+ rdoc_options: []
265
+ require_paths:
266
+ - lib
267
+ required_ruby_version: !ruby/object:Gem::Requirement
268
+ requirements:
269
+ - - ">="
270
+ - !ruby/object:Gem::Version
271
+ version: '0'
272
+ required_rubygems_version: !ruby/object:Gem::Requirement
273
+ requirements:
274
+ - - ">"
275
+ - !ruby/object:Gem::Version
276
+ version: 1.3.1
277
+ requirements: []
278
+ rubyforge_project:
279
+ rubygems_version: 2.1.11
280
+ signing_key:
281
+ specification_version: 4
282
+ summary: Keep your rails controllers DRY.
283
+ test_files: []