snorlax 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: b53bab2423a46c274206d57459abb78a811d3dd5
4
+ data.tar.gz: 9dbc6d8173b431936797bbdbe9979148fe02d125
5
+ SHA512:
6
+ metadata.gz: eb4a29d12a68529cf4335bd74026f10ed818db84f644447741770fb52016eac3c68dff54339d0533b5a4b2c94e888dbc40d605368ed46696bc370487c8257d4d
7
+ data.tar.gz: 569aebf4ea57664c9fa7e958eaeb0663e9ddf211d77eaa363648d975d080eab097af7e034aa99c022a5aef132d755afe6b24cf2fedbee9aa8c1a815b76ea2589
data/.gitignore ADDED
@@ -0,0 +1,10 @@
1
+ /.bundle/
2
+ /.yardoc
3
+ /Gemfile.lock
4
+ /_yardoc/
5
+ /coverage/
6
+ /doc/
7
+ /pkg/
8
+ /spec/reports/
9
+ /tmp/
10
+ *.gem
data/.travis.yml ADDED
@@ -0,0 +1,4 @@
1
+ language: ruby
2
+ rvm:
3
+ - 2.2.2
4
+ before_install: gem install bundler -v 1.10.5
@@ -0,0 +1,13 @@
1
+ # Contributor Code of Conduct
2
+
3
+ As contributors and maintainers of this project, we pledge to respect all people who contribute through reporting issues, posting feature requests, updating documentation, submitting pull requests or patches, and other activities.
4
+
5
+ We are committed to making participation in this project a harassment-free experience for everyone, regardless of level of experience, gender, gender identity and expression, sexual orientation, disability, personal appearance, body size, race, ethnicity, age, or religion.
6
+
7
+ Examples of unacceptable behavior by participants include the use of sexual language or imagery, derogatory comments or personal attacks, trolling, public or private harassment, insults, or other unprofessional conduct.
8
+
9
+ Project maintainers have the right and responsibility to remove, edit, or reject comments, commits, code, wiki edits, issues, and other contributions that are not aligned to this Code of Conduct. Project maintainers who do not follow the Code of Conduct may be removed from the project team.
10
+
11
+ Instances of abusive, harassing, or otherwise unacceptable behavior may be reported by opening an issue or contacting one or more of the project maintainers.
12
+
13
+ This Code of Conduct is adapted from the [Contributor Covenant](http://contributor-covenant.org), version 1.0.0, available at [http://contributor-covenant.org/version/1/0/0/](http://contributor-covenant.org/version/1/0/0/)
data/Gemfile ADDED
@@ -0,0 +1,18 @@
1
+ source 'https://rubygems.org'
2
+
3
+ # Specify your gem's dependencies in restful_controller.gemspec
4
+ gemspec
5
+
6
+ gem 'rails', '~> 4.1.0'
7
+ gem 'cancancan', '~> 1.12.0'
8
+
9
+ group :development, :test do
10
+ gem 'byebug', require: nil
11
+ gem 'temping'
12
+ gem 'mocha'
13
+ gem 'sqlite3'
14
+ end
15
+
16
+ group :test do
17
+ gem 'codeclimate-test-reporter', require: nil
18
+ end
data/LICENSE.txt ADDED
@@ -0,0 +1,21 @@
1
+ The MIT License (MIT)
2
+
3
+ Copyright (c) 2015 James Kiesel
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in
13
+ all copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
21
+ THE SOFTWARE.
data/README.md ADDED
@@ -0,0 +1,40 @@
1
+ # Snorlax
2
+
3
+ Welcome to your new gem! In this directory, you'll find the files you need to be able to package up your Ruby library into a gem. Put your Ruby code in the file `lib/restful_controller`. To experiment with that code, run `bin/console` for an interactive prompt.
4
+
5
+ TODO: Delete this and the text above, and describe your gem
6
+
7
+ ## Installation
8
+
9
+ Add this line to your application's Gemfile:
10
+
11
+ ```ruby
12
+ gem 'restful_controller'
13
+ ```
14
+
15
+ And then execute:
16
+
17
+ $ bundle
18
+
19
+ Or install it yourself as:
20
+
21
+ $ gem install restful_controller
22
+
23
+ ## Usage
24
+
25
+ TODO: Write usage instructions here
26
+
27
+ ## Development
28
+
29
+ After checking out the repo, run `bin/setup` to install dependencies. Then, run `rake test` to run the tests. You can also run `bin/console` for an interactive prompt that will allow you to experiment.
30
+
31
+ To install this gem onto your local machine, run `bundle exec rake install`. To release a new version, update the version number in `version.rb`, and then run `bundle exec rake release`, which will create a git tag for the version, push git commits and tags, and push the `.gem` file to [rubygems.org](https://rubygems.org).
32
+
33
+ ## Contributing
34
+
35
+ Bug reports and pull requests are welcome on GitHub at https://github.com/[USERNAME]/restful_controller. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the [Contributor Covenant](contributor-covenant.org) code of conduct.
36
+
37
+
38
+ ## License
39
+
40
+ The gem is available as open source under the terms of the [MIT License](http://opensource.org/licenses/MIT).
data/Rakefile ADDED
@@ -0,0 +1,12 @@
1
+ require 'bundler/gem_tasks'
2
+ require 'rake/testtask'
3
+
4
+ task default: :test
5
+
6
+ Rake::TestTask.new :test do |t|
7
+ t.libs << 'lib'
8
+ t.libs << 'test'
9
+ t.pattern = 'test/**/*_test.rb'
10
+ t.verbose = true
11
+ t.warning = false
12
+ end
@@ -0,0 +1,172 @@
1
+ module Snorlax
2
+ class Base < ::ApplicationController
3
+
4
+ def self.snorlax_used_rest!(controller)
5
+ controller.class_eval do
6
+ rescue_from(CanCan::AccessDenied) { |e| respond_with_standard_error e, 403 }
7
+ rescue_from(ActionController::UnpermittedParameters) { |e| respond_with_standard_error e, 400 }
8
+
9
+ def show
10
+ respond_with_resource
11
+ end
12
+
13
+ def index
14
+ instantiate_collection
15
+ respond_with_collection
16
+ end
17
+
18
+ def create
19
+ instantiate_resouce
20
+ create_action
21
+ respond_with_resource
22
+ end
23
+
24
+ def create_action
25
+ resource.save
26
+ end
27
+
28
+ def update
29
+ load_resource
30
+ update_action
31
+ respond_with_resource
32
+ end
33
+
34
+ def update_action
35
+ resource.update(resource_params)
36
+ end
37
+
38
+ def destroy
39
+ load_resource
40
+ destroy_action
41
+ render json: {success: 'success'}
42
+ end
43
+
44
+ def destroy_action
45
+ resource.destroy
46
+ end
47
+
48
+ private
49
+
50
+ def collection
51
+ instance_variable_get :"@#{resource_plural}"
52
+ end
53
+
54
+ def resource
55
+ instance_variable_get :"@#{resource_name}"
56
+ end
57
+
58
+ def resource=(value)
59
+ instance_variable_set :"@#{resource_name}", value
60
+ end
61
+
62
+ def collection=(value)
63
+ instance_variable_set :"@#{resource_name.pluralize}", value
64
+ end
65
+
66
+ def instantiate_resouce
67
+ self.resource = resource_class.new(resource_params)
68
+ end
69
+
70
+ def instantiate_collection(timeframe_collection: true, page_collection: true)
71
+ collection = accessible_records
72
+ collection = yield collection if block_given?
73
+ collection = timeframe_collection collection if timeframe_collection
74
+ collection = page_collection collection if page_collection
75
+ self.collection = collection.to_a
76
+ end
77
+
78
+ def timeframe_collection(collection)
79
+ if resource_class.try(:has_timeframe?) && (params[:since] || params[:until])
80
+ parse_date_parameters # I feel like Rails should do this for me..
81
+ collection.within(params[:since], params[:until], params[:timeframe_for])
82
+ else
83
+ collection
84
+ end
85
+ end
86
+
87
+ def parse_date_parameters
88
+ %w(since until).each { |field| params[field] = DateTime.parse(params[field].to_s) if params[field] }
89
+ end
90
+
91
+ def page_collection(collection)
92
+ collection.offset(params[:from]).limit(params[:per] || default_page_size)
93
+ end
94
+
95
+ def accessible_records
96
+ if current_user
97
+ visible_records
98
+ else
99
+ public_records
100
+ end
101
+ end
102
+
103
+ def visible_records
104
+ raise NotImplementedError.new
105
+ end
106
+
107
+ def public_records
108
+ raise NotImplementedError.new
109
+ end
110
+
111
+ def default_page_size
112
+ 50
113
+ end
114
+
115
+ def load_resource
116
+ self.resource = resource_class.find(params[:id])
117
+ end
118
+
119
+ def resource_params
120
+ permitted_params.send resource_name
121
+ end
122
+
123
+ def resource_symbol
124
+ resource_name.to_sym
125
+ end
126
+
127
+ def resource_name
128
+ controller_name.singularize
129
+ end
130
+
131
+ def resource_class
132
+ resource_name.camelize.constantize
133
+ end
134
+
135
+ def resource_plural
136
+ controller_name
137
+ end
138
+
139
+ def resource_serializer
140
+ "#{resource_name}_serializer".camelize.constantize
141
+ end
142
+
143
+ def respond_with_resource(scope: {}, serializer: resource_serializer, root: serializer_root)
144
+ if resource.errors.empty?
145
+ respond_with_collection(resources: [resource], scope: scope, serializer: serializer, root: root)
146
+ else
147
+ respond_with_errors
148
+ end
149
+ end
150
+
151
+ def respond_with_collection(resources: collection, scope: {}, serializer: resource_serializer, root: serializer_root)
152
+ render json: resources, scope: scope, each_serializer: serializer, root: root
153
+ end
154
+
155
+ def respond_with_standard_error(error, status)
156
+ render json: {exception: error.class.to_s}, root: false, status: status
157
+ end
158
+
159
+ def respond_with_errors
160
+ render json: {errors: resource.errors.as_json()}, root: false, status: 422
161
+ end
162
+
163
+ def serializer_root
164
+ controller_name
165
+ end
166
+ end
167
+ end
168
+
169
+ snorlax_used_rest!(self)
170
+
171
+ end
172
+ end
data/bin/console ADDED
@@ -0,0 +1,14 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ require "bundler/setup"
4
+ require "restful_controller"
5
+
6
+ # You can add fixtures and/or initialization code here to make experimenting
7
+ # with your gem easier. You can also use a different console, if you like.
8
+
9
+ # (If you use this, don't forget to add pry to your Gemfile!)
10
+ # require "pry"
11
+ # Pry.start
12
+
13
+ require "irb"
14
+ IRB.start
data/bin/setup ADDED
@@ -0,0 +1,7 @@
1
+ #!/bin/bash
2
+ set -euo pipefail
3
+ IFS=$'\n\t'
4
+
5
+ bundle install
6
+
7
+ # Do any other automated setup that you need to do here
@@ -0,0 +1,4 @@
1
+ module Snorlax
2
+ class Engine < Rails::Engine
3
+ end
4
+ end
@@ -0,0 +1,3 @@
1
+ module Snorlax
2
+ VERSION = "0.1.0"
3
+ end
data/lib/snorlax.rb ADDED
@@ -0,0 +1,13 @@
1
+ require 'snorlax/version'
2
+ require 'snorlax/engine'
3
+
4
+ module Snorlax
5
+ end
6
+
7
+ class ActionController::Base
8
+ # Method to allow controllers to apply Snorlax to themselves
9
+ # (g@nked from Inherited resources: https://github.com/josevalim/inherited_resources/blob/master/lib/inherited_resources.rb)
10
+ def self.snorlax_used_rest!
11
+ RestfulController::Base.snorlax_used_rest!(self)
12
+ end
13
+ end
data/snorlax.gemspec ADDED
@@ -0,0 +1,27 @@
1
+ # coding: utf-8
2
+ lib = File.expand_path('../lib', __FILE__)
3
+ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
4
+ require 'snorlax/version'
5
+
6
+ Gem::Specification.new do |spec|
7
+ spec.name = "snorlax"
8
+ spec.version = Snorlax::VERSION
9
+ spec.authors = ["James Kiesel (gdpelican)"]
10
+ spec.email = ["james@loomio.org"]
11
+
12
+ spec.summary = "Snorlax is an opinionated, but flexible and well-RESTed controller for Rails APIs"
13
+ spec.homepage = "http://www.github.com/gdpelican/snorlax"
14
+ spec.license = "MIT"
15
+
16
+ spec.files = `git ls-files -z`.split("\x0").reject { |f| f.match(%r{^(test|spec|features)/}) }
17
+ spec.bindir = "exe"
18
+ spec.executables = spec.files.grep(%r{^exe/}) { |f| File.basename(f) }
19
+ spec.require_paths = ["lib"]
20
+
21
+ spec.add_runtime_dependency "rails", "~> 4.1"
22
+ spec.add_runtime_dependency "cancancan", "~> 1.10.1"
23
+
24
+ spec.add_development_dependency "bundler", "~> 1.10"
25
+ spec.add_development_dependency "rake", "~> 10.0"
26
+ spec.add_development_dependency "minitest", "~> 5.7"
27
+ end
metadata ADDED
@@ -0,0 +1,129 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: snorlax
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.0
5
+ platform: ruby
6
+ authors:
7
+ - James Kiesel (gdpelican)
8
+ autorequire:
9
+ bindir: exe
10
+ cert_chain: []
11
+ date: 2015-08-07 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.1'
20
+ type: :runtime
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - "~>"
25
+ - !ruby/object:Gem::Version
26
+ version: '4.1'
27
+ - !ruby/object:Gem::Dependency
28
+ name: cancancan
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - "~>"
32
+ - !ruby/object:Gem::Version
33
+ version: 1.10.1
34
+ type: :runtime
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - "~>"
39
+ - !ruby/object:Gem::Version
40
+ version: 1.10.1
41
+ - !ruby/object:Gem::Dependency
42
+ name: bundler
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - "~>"
46
+ - !ruby/object:Gem::Version
47
+ version: '1.10'
48
+ type: :development
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - "~>"
53
+ - !ruby/object:Gem::Version
54
+ version: '1.10'
55
+ - !ruby/object:Gem::Dependency
56
+ name: rake
57
+ requirement: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - "~>"
60
+ - !ruby/object:Gem::Version
61
+ version: '10.0'
62
+ type: :development
63
+ prerelease: false
64
+ version_requirements: !ruby/object:Gem::Requirement
65
+ requirements:
66
+ - - "~>"
67
+ - !ruby/object:Gem::Version
68
+ version: '10.0'
69
+ - !ruby/object:Gem::Dependency
70
+ name: minitest
71
+ requirement: !ruby/object:Gem::Requirement
72
+ requirements:
73
+ - - "~>"
74
+ - !ruby/object:Gem::Version
75
+ version: '5.7'
76
+ type: :development
77
+ prerelease: false
78
+ version_requirements: !ruby/object:Gem::Requirement
79
+ requirements:
80
+ - - "~>"
81
+ - !ruby/object:Gem::Version
82
+ version: '5.7'
83
+ description:
84
+ email:
85
+ - james@loomio.org
86
+ executables: []
87
+ extensions: []
88
+ extra_rdoc_files: []
89
+ files:
90
+ - ".gitignore"
91
+ - ".travis.yml"
92
+ - CODE_OF_CONDUCT.md
93
+ - Gemfile
94
+ - LICENSE.txt
95
+ - README.md
96
+ - Rakefile
97
+ - app/controllers/snorlax/base.rb
98
+ - bin/console
99
+ - bin/setup
100
+ - lib/snorlax.rb
101
+ - lib/snorlax/engine.rb
102
+ - lib/snorlax/version.rb
103
+ - snorlax.gemspec
104
+ homepage: http://www.github.com/gdpelican/snorlax
105
+ licenses:
106
+ - MIT
107
+ metadata: {}
108
+ post_install_message:
109
+ rdoc_options: []
110
+ require_paths:
111
+ - lib
112
+ required_ruby_version: !ruby/object:Gem::Requirement
113
+ requirements:
114
+ - - ">="
115
+ - !ruby/object:Gem::Version
116
+ version: '0'
117
+ required_rubygems_version: !ruby/object:Gem::Requirement
118
+ requirements:
119
+ - - ">="
120
+ - !ruby/object:Gem::Version
121
+ version: '0'
122
+ requirements: []
123
+ rubyforge_project:
124
+ rubygems_version: 2.4.8
125
+ signing_key:
126
+ specification_version: 4
127
+ summary: Snorlax is an opinionated, but flexible and well-RESTed controller for Rails
128
+ APIs
129
+ test_files: []