charcoal 2.1.2 → 2.3.0

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.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
- SHA1:
3
- metadata.gz: a62743439d4ec19dae5b53e08511138105e83b64
4
- data.tar.gz: 22f4273d278cae65b23fdacacd877e4507456eb7
2
+ SHA256:
3
+ metadata.gz: f1c9e686108450bbf02c66b8baab2a1f1d99c08584ce2859da903cd6bb374da2
4
+ data.tar.gz: f43f57c491c9e29bf94cd94e309bba934f004b1f94afab5fc01b63dcf673a26d
5
5
  SHA512:
6
- metadata.gz: 325b79b0c83831771e6eab58563802e8ae9a29290b25941437289ade1cc096b9529eda550f54a22f001c45cbaac0b0475dc062e5c9d82eb99adb18b1749638dc
7
- data.tar.gz: 7ec48e229f4684498d0f2cc66bc52c2d39569b530a98ec79f7aa5f23baad958a6e5f7332bc4ae778895ef0543f77e64feed0a6b36df614790a6145d0b9e1598a
6
+ metadata.gz: 86d9cd403d5d0ad9870cfe01eae8c9e7d3cef14fdbc70a0a06e9d66d9bebbb0d4a96e1dae06a0acd6c937f15aaf48eb345b0e1df315351ef37045543330bdbec
7
+ data.tar.gz: db9bab1419a9d7c01a04e7af3a8df342b14a614fd336b3f7803147148cd67f4c209cf7d49f8806559e043e8b9acb9232cd59f74ea84f8ad5cbab6a3c375aaae1
@@ -42,7 +42,7 @@ module Charcoal
42
42
 
43
43
  def set_cors_headers
44
44
  headers["Access-Control-Allow-Origin"] = allowed_origin
45
- headers["Access-Control-Allow-Credentials"] = Charcoal.configuration["credentials"].to_s
45
+ headers["Access-Control-Allow-Credentials"] = "true" if credentials_allowed?
46
46
  headers["Access-Control-Expose-Headers"] = Charcoal.configuration["expose-headers"].join(",")
47
47
  end
48
48
 
@@ -50,5 +50,10 @@ module Charcoal
50
50
  value = Charcoal.configuration["allow-origin"]
51
51
  value.respond_to?(:call) ? value.call(self) : value.to_s
52
52
  end
53
+
54
+ def credentials_allowed?
55
+ value = Charcoal.configuration["credentials"]
56
+ value.respond_to?(:call) ? value.call(self) : value
57
+ end
53
58
  end
54
59
  end
@@ -1,13 +1,16 @@
1
1
  # This controller handles CORS preflight requests
2
2
  # See https://developer.mozilla.org/En/HTTP_access_control for documentation
3
3
 
4
- require 'action_controller'
4
+ require 'action_controller/metal'
5
5
  require 'active_support/version'
6
+ require 'charcoal/utilities'
6
7
 
7
- class Charcoal::CrossOriginController < ActionController::Base
8
+ class Charcoal::CrossOriginController < ActionController::Metal
9
+ include AbstractController::Callbacks
10
+ include ActionController::Head
11
+ include ActionController::Instrumentation
8
12
  include Charcoal::CrossOrigin
9
-
10
- Routing = defined?(ActionDispatch) ? ActionDispatch::Routing : ActionController::Routing
13
+ include Charcoal::Utilities
11
14
 
12
15
  allow_cors :all
13
16
  if respond_to?(:skip_around_action)
@@ -31,44 +34,6 @@ class Charcoal::CrossOriginController < ActionController::Base
31
34
  private
32
35
 
33
36
  def allowed_methods
34
- @allowed_methods ||= Routing::HTTP_METHODS.select do |verb|
35
- next if verb == :options
36
-
37
- route = find_route(request.path, request.env.merge(:method => verb))
38
-
39
- if route
40
- controller = route[:controller].camelize
41
- controller = "#{controller}Controller".constantize
42
-
43
- action = route[:action] || params[:path].last.split(".").first
44
-
45
- instance = controller.new
46
- instance.request = request
47
- instance.response = response
48
-
49
- controller.respond_to?(:cors_allowed) && controller.cors_allowed?(instance, action)
50
- else
51
- false
52
- end
53
- end
54
- end
55
-
56
- def find_route(path, env)
57
- routes = [Rails.application.routes]
58
-
59
- railties = Rails.application.railties
60
- railties = railties.respond_to?(:all) ? railties.all : railties._all
61
- routes += railties.select {|tie| tie.is_a?(Rails::Engine)}.map(&:routes)
62
-
63
- routes.each do |route_set|
64
- begin
65
- return route_set.recognize_path(path, env)
66
- rescue ActionController::RoutingError
67
- end
68
- end
69
-
70
- nil
71
- rescue ActionController::RoutingError
72
- nil
37
+ allowed_methods_for?(:cors)
73
38
  end
74
39
  end
@@ -0,0 +1,56 @@
1
+ require 'action_controller'
2
+
3
+ module Charcoal::Utilities
4
+ Routing = defined?(ActionDispatch) ? ActionDispatch::Routing : ActionController::Routing
5
+
6
+ def allowed_methods_for?(protocol)
7
+ @allowed_methods ||= {}
8
+ return @allowed_methods[protocol] if @allowed_methods[protocol]
9
+ @allowed_methods[protocol] = methods_allowed_for?(protocol)
10
+ end
11
+
12
+ private
13
+
14
+ def methods_allowed_for?(protocol)
15
+ Routing::HTTP_METHODS.select do |verb|
16
+ next if verb == :options
17
+
18
+ route = find_route(request.path, request.env.merge(:method => verb))
19
+
20
+ if route
21
+ controller = route[:controller].camelize
22
+ controller = "#{controller}Controller".constantize
23
+
24
+ action = route[:action] || params[:path].last.split(".").first
25
+
26
+ instance = controller.new
27
+ instance.request = request
28
+ instance.response = response
29
+
30
+ method_name = "#{protocol}_allowed"
31
+ controller.respond_to?(method_name.to_sym) && controller.send(method_name + '?', instance, action)
32
+ else
33
+ false
34
+ end
35
+ end
36
+ end
37
+
38
+ def find_route(path, env)
39
+ routes = [Rails.application.routes]
40
+
41
+ railties = Rails.application.railties
42
+ railties = railties.respond_to?(:all) ? railties.all : railties._all
43
+ routes += railties.select {|tie| tie.is_a?(Rails::Engine)}.map(&:routes)
44
+
45
+ routes.each do |route_set|
46
+ begin
47
+ return route_set.recognize_path(path, env)
48
+ rescue ActionController::RoutingError
49
+ end
50
+ end
51
+
52
+ nil
53
+ rescue ActionController::RoutingError
54
+ nil
55
+ end
56
+ end
@@ -1,3 +1,3 @@
1
1
  module Charcoal
2
- VERSION = "2.1.2"
2
+ VERSION = "2.3.0"
3
3
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: charcoal
3
3
  version: !ruby/object:Gem::Version
4
- version: 2.1.2
4
+ version: 2.3.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Steven Davidovitz
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2017-04-28 00:00:00.000000000 Z
11
+ date: 2020-11-09 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: activesupport
@@ -19,7 +19,7 @@ dependencies:
19
19
  version: 3.2.21
20
20
  - - "<"
21
21
  - !ruby/object:Gem::Version
22
- version: '5.2'
22
+ version: '6.1'
23
23
  type: :runtime
24
24
  prerelease: false
25
25
  version_requirements: !ruby/object:Gem::Requirement
@@ -29,7 +29,7 @@ dependencies:
29
29
  version: 3.2.21
30
30
  - - "<"
31
31
  - !ruby/object:Gem::Version
32
- version: '5.2'
32
+ version: '6.1'
33
33
  - !ruby/object:Gem::Dependency
34
34
  name: actionpack
35
35
  requirement: !ruby/object:Gem::Requirement
@@ -39,7 +39,7 @@ dependencies:
39
39
  version: 3.2.21
40
40
  - - "<"
41
41
  - !ruby/object:Gem::Version
42
- version: '5.2'
42
+ version: '6.1'
43
43
  type: :runtime
44
44
  prerelease: false
45
45
  version_requirements: !ruby/object:Gem::Requirement
@@ -49,7 +49,7 @@ dependencies:
49
49
  version: 3.2.21
50
50
  - - "<"
51
51
  - !ruby/object:Gem::Version
52
- version: '5.2'
52
+ version: '6.1'
53
53
  - !ruby/object:Gem::Dependency
54
54
  name: rake
55
55
  requirement: !ruby/object:Gem::Requirement
@@ -96,16 +96,16 @@ dependencies:
96
96
  name: yard
97
97
  requirement: !ruby/object:Gem::Requirement
98
98
  requirements:
99
- - - "~>"
99
+ - - ">="
100
100
  - !ruby/object:Gem::Version
101
- version: '0.7'
101
+ version: 0.9.11
102
102
  type: :development
103
103
  prerelease: false
104
104
  version_requirements: !ruby/object:Gem::Requirement
105
105
  requirements:
106
- - - "~>"
106
+ - - ">="
107
107
  - !ruby/object:Gem::Version
108
- version: '0.7'
108
+ version: 0.9.11
109
109
  - !ruby/object:Gem::Dependency
110
110
  name: shoulda
111
111
  requirement: !ruby/object:Gem::Requirement
@@ -120,34 +120,6 @@ dependencies:
120
120
  - - "~>"
121
121
  - !ruby/object:Gem::Version
122
122
  version: '3.0'
123
- - !ruby/object:Gem::Dependency
124
- name: shoulda-context
125
- requirement: !ruby/object:Gem::Requirement
126
- requirements:
127
- - - ">="
128
- - !ruby/object:Gem::Version
129
- version: '0'
130
- type: :development
131
- prerelease: false
132
- version_requirements: !ruby/object:Gem::Requirement
133
- requirements:
134
- - - ">="
135
- - !ruby/object:Gem::Version
136
- version: '0'
137
- - !ruby/object:Gem::Dependency
138
- name: mocha
139
- requirement: !ruby/object:Gem::Requirement
140
- requirements:
141
- - - ">="
142
- - !ruby/object:Gem::Version
143
- version: '0'
144
- type: :development
145
- prerelease: false
146
- version_requirements: !ruby/object:Gem::Requirement
147
- requirements:
148
- - - ">="
149
- - !ruby/object:Gem::Version
150
- version: '0'
151
123
  description: Helps you support JSONP and CORS in your Rails app
152
124
  email: sdavidovitz@zendesk.com
153
125
  executables: []
@@ -159,6 +131,7 @@ files:
159
131
  - lib/charcoal/cross_origin.rb
160
132
  - lib/charcoal/cross_origin_controller.rb
161
133
  - lib/charcoal/jsonp.rb
134
+ - lib/charcoal/utilities.rb
162
135
  - lib/charcoal/version.rb
163
136
  homepage: https://github.com/zendesk/charcoal
164
137
  licenses:
@@ -172,15 +145,14 @@ required_ruby_version: !ruby/object:Gem::Requirement
172
145
  requirements:
173
146
  - - ">="
174
147
  - !ruby/object:Gem::Version
175
- version: '0'
148
+ version: 2.4.0
176
149
  required_rubygems_version: !ruby/object:Gem::Requirement
177
150
  requirements:
178
151
  - - ">="
179
152
  - !ruby/object:Gem::Version
180
153
  version: '0'
181
154
  requirements: []
182
- rubyforge_project:
183
- rubygems_version: 2.6.11
155
+ rubygems_version: 3.1.4
184
156
  signing_key:
185
157
  specification_version: 4
186
158
  summary: Cross-Origin helper for Rails