praxis 2.0.pre.16 → 2.0.pre.20

Sign up to get free protection for your applications and to get access to all the features.
Files changed (235) hide show
  1. checksums.yaml +4 -4
  2. data/.rubocop.yml +54 -0
  3. data/.simplecov +3 -1
  4. data/.travis.yml +2 -1
  5. data/CHANGELOG.md +22 -0
  6. data/CONTRIBUTING.md +2 -79
  7. data/Gemfile +5 -1
  8. data/Guardfile +6 -4
  9. data/LICENSE +0 -2
  10. data/MAINTAINERS.md +1 -0
  11. data/README.md +15 -22
  12. data/Rakefile +4 -2
  13. data/bin/praxis +55 -58
  14. data/lib/praxis/action_definition/headers_dsl_compiler.rb +5 -6
  15. data/lib/praxis/action_definition.rb +65 -95
  16. data/lib/praxis/api_definition.rb +21 -29
  17. data/lib/praxis/api_general_info.rb +55 -66
  18. data/lib/praxis/application.rb +15 -32
  19. data/lib/praxis/blueprint.rb +80 -73
  20. data/lib/praxis/bootloader.rb +24 -33
  21. data/lib/praxis/bootloader_stages/environment.rb +5 -10
  22. data/lib/praxis/bootloader_stages/file_loader.rb +3 -6
  23. data/lib/praxis/bootloader_stages/plugin_config_load.rb +4 -6
  24. data/lib/praxis/bootloader_stages/plugin_config_prepare.rb +2 -2
  25. data/lib/praxis/bootloader_stages/plugin_loader.rb +3 -7
  26. data/lib/praxis/bootloader_stages/plugin_setup.rb +3 -3
  27. data/lib/praxis/bootloader_stages/routing.rb +5 -8
  28. data/lib/praxis/bootloader_stages/subgroup_loader.rb +2 -10
  29. data/lib/praxis/bootloader_stages/warn_unloaded_files.rb +15 -19
  30. data/lib/praxis/callbacks.rb +12 -11
  31. data/lib/praxis/collection.rb +11 -14
  32. data/lib/praxis/config.rb +17 -28
  33. data/lib/praxis/config_hash.rb +2 -1
  34. data/lib/praxis/controller.rb +7 -6
  35. data/lib/praxis/dispatcher.rb +34 -42
  36. data/lib/praxis/docs/open_api/info_object.rb +11 -8
  37. data/lib/praxis/docs/open_api/media_type_object.rb +18 -17
  38. data/lib/praxis/docs/open_api/operation_object.rb +7 -4
  39. data/lib/praxis/docs/open_api/parameter_object.rb +17 -14
  40. data/lib/praxis/docs/open_api/paths_object.rb +11 -9
  41. data/lib/praxis/docs/open_api/request_body_object.rb +14 -13
  42. data/lib/praxis/docs/open_api/response_object.rb +24 -18
  43. data/lib/praxis/docs/open_api/responses_object.rb +3 -1
  44. data/lib/praxis/docs/open_api/schema_object.rb +61 -29
  45. data/lib/praxis/docs/open_api/server_object.rb +5 -2
  46. data/lib/praxis/docs/open_api/tag_object.rb +9 -6
  47. data/lib/praxis/docs/open_api_generator.rb +114 -150
  48. data/lib/praxis/endpoint_definition.rb +60 -77
  49. data/lib/praxis/error_handler.rb +2 -2
  50. data/lib/praxis/exception.rb +2 -0
  51. data/lib/praxis/exceptions/config.rb +3 -1
  52. data/lib/praxis/exceptions/config_load.rb +2 -0
  53. data/lib/praxis/exceptions/config_validation.rb +3 -1
  54. data/lib/praxis/exceptions/invalid_configuration.rb +3 -1
  55. data/lib/praxis/exceptions/invalid_response.rb +3 -1
  56. data/lib/praxis/exceptions/invalid_trait.rb +3 -1
  57. data/lib/praxis/exceptions/stage_not_found.rb +3 -1
  58. data/lib/praxis/exceptions/validation.rb +4 -3
  59. data/lib/praxis/extensions/attribute_filtering/active_record_filter_query_builder.rb +187 -131
  60. data/lib/praxis/extensions/attribute_filtering/active_record_patches/5x.rb +18 -13
  61. data/lib/praxis/extensions/attribute_filtering/active_record_patches/6_0.rb +13 -9
  62. data/lib/praxis/extensions/attribute_filtering/active_record_patches/6_1_plus.rb +14 -11
  63. data/lib/praxis/extensions/attribute_filtering/active_record_patches.rb +12 -9
  64. data/lib/praxis/extensions/attribute_filtering/filter_tree_node.rb +8 -5
  65. data/lib/praxis/extensions/attribute_filtering/filtering_params.rb +89 -65
  66. data/lib/praxis/extensions/attribute_filtering/filters_parser.rb +68 -62
  67. data/lib/praxis/extensions/attribute_filtering.rb +3 -1
  68. data/lib/praxis/extensions/field_expansion.rb +6 -4
  69. data/lib/praxis/extensions/field_selection/active_record_query_selector.rb +10 -8
  70. data/lib/praxis/extensions/field_selection/field_selector.rb +91 -92
  71. data/lib/praxis/extensions/field_selection/sequel_query_selector.rb +12 -12
  72. data/lib/praxis/extensions/field_selection.rb +3 -1
  73. data/lib/praxis/extensions/pagination/active_record_pagination_handler.rb +6 -4
  74. data/lib/praxis/extensions/pagination/header_generator.rb +16 -11
  75. data/lib/praxis/extensions/pagination/ordering_params.rb +29 -28
  76. data/lib/praxis/extensions/pagination/pagination_handler.rb +44 -42
  77. data/lib/praxis/extensions/pagination/pagination_params.rb +29 -48
  78. data/lib/praxis/extensions/pagination/sequel_pagination_handler.rb +8 -7
  79. data/lib/praxis/extensions/pagination.rb +10 -15
  80. data/lib/praxis/extensions/rails_compat/request_methods.rb +3 -4
  81. data/lib/praxis/extensions/rails_compat.rb +2 -0
  82. data/lib/praxis/extensions/rendering.rb +12 -12
  83. data/lib/praxis/field_expander.rb +8 -9
  84. data/lib/praxis/file_group.rb +8 -12
  85. data/lib/praxis/finalizable.rb +1 -0
  86. data/lib/praxis/handlers/json.rb +5 -2
  87. data/lib/praxis/handlers/plain.rb +2 -1
  88. data/lib/praxis/handlers/www_form.rb +6 -3
  89. data/lib/praxis/handlers/{xml-sample.rb → xml_sample.rb} +26 -22
  90. data/lib/praxis/mapper/active_model_compat.rb +13 -10
  91. data/lib/praxis/mapper/resource.rb +196 -181
  92. data/lib/praxis/mapper/selector_generator.rb +106 -112
  93. data/lib/praxis/mapper/sequel_compat.rb +70 -67
  94. data/lib/praxis/media_type.rb +2 -2
  95. data/lib/praxis/media_type_identifier.rb +26 -22
  96. data/lib/praxis/middleware_app.rb +18 -15
  97. data/lib/praxis/multipart/parser.rb +46 -51
  98. data/lib/praxis/multipart/part.rb +78 -110
  99. data/lib/praxis/notifications.rb +2 -4
  100. data/lib/praxis/plugin.rb +11 -18
  101. data/lib/praxis/plugin_concern.rb +12 -15
  102. data/lib/praxis/plugins/mapper_plugin.rb +15 -13
  103. data/lib/praxis/plugins/pagination_plugin.rb +8 -6
  104. data/lib/praxis/plugins/rails_plugin.rb +33 -28
  105. data/lib/praxis/renderer.rb +11 -15
  106. data/lib/praxis/request.rb +48 -44
  107. data/lib/praxis/request_stages/action.rb +4 -6
  108. data/lib/praxis/request_stages/load_request.rb +2 -4
  109. data/lib/praxis/request_stages/request_stage.rb +19 -23
  110. data/lib/praxis/request_stages/response.rb +4 -6
  111. data/lib/praxis/request_stages/validate.rb +3 -5
  112. data/lib/praxis/request_stages/validate_params_and_headers.rb +15 -22
  113. data/lib/praxis/request_stages/validate_payload.rb +25 -28
  114. data/lib/praxis/request_superclassing.rb +3 -3
  115. data/lib/praxis/resource_definition.rb +1 -0
  116. data/lib/praxis/response.rb +24 -26
  117. data/lib/praxis/response_definition.rb +77 -122
  118. data/lib/praxis/response_template.rb +11 -15
  119. data/lib/praxis/responses/http.rb +23 -44
  120. data/lib/praxis/responses/internal_server_error.rb +18 -21
  121. data/lib/praxis/responses/multipart_ok.rb +4 -9
  122. data/lib/praxis/responses/validation_error.rb +8 -15
  123. data/lib/praxis/route.rb +8 -10
  124. data/lib/praxis/router/rack.rb +13 -7
  125. data/lib/praxis/router/simple.rb +10 -5
  126. data/lib/praxis/router.rb +27 -34
  127. data/lib/praxis/routing_config.rb +52 -29
  128. data/lib/praxis/simple_media_type.rb +5 -8
  129. data/lib/praxis/stage.rb +17 -25
  130. data/lib/praxis/tasks/api_docs.rb +17 -16
  131. data/lib/praxis/tasks/console.rb +3 -1
  132. data/lib/praxis/tasks/environment.rb +2 -0
  133. data/lib/praxis/tasks/routes.rb +26 -24
  134. data/lib/praxis/tasks.rb +3 -1
  135. data/lib/praxis/trait.rb +37 -46
  136. data/lib/praxis/types/fuzzy_hash.rb +13 -14
  137. data/lib/praxis/types/media_type_common.rb +11 -10
  138. data/lib/praxis/types/multipart_array/part_definition.rb +14 -17
  139. data/lib/praxis/types/multipart_array.rb +100 -115
  140. data/lib/praxis/validation_handler.rb +5 -3
  141. data/lib/praxis/version.rb +3 -1
  142. data/lib/praxis.rb +4 -5
  143. data/praxis.gemspec +22 -21
  144. data/spec/functional_spec.rb +44 -56
  145. data/spec/praxis/action_definition_spec.rb +39 -48
  146. data/spec/praxis/api_definition_spec.rb +45 -47
  147. data/spec/praxis/api_general_info_spec.rb +28 -29
  148. data/spec/praxis/application_spec.rb +18 -14
  149. data/spec/praxis/blueprint_spec.rb +33 -34
  150. data/spec/praxis/bootloader_spec.rb +32 -30
  151. data/spec/praxis/callbacks_spec.rb +37 -37
  152. data/spec/praxis/collection_spec.rb +18 -25
  153. data/spec/praxis/config_hash_spec.rb +5 -4
  154. data/spec/praxis/config_spec.rb +27 -26
  155. data/spec/praxis/controller_spec.rb +8 -9
  156. data/spec/praxis/endpoint_definition_spec.rb +25 -32
  157. data/spec/praxis/extensions/attribute_filtering/active_record_filter_query_builder_spec.rb +221 -106
  158. data/spec/praxis/extensions/attribute_filtering/filter_tree_node_spec.rb +22 -21
  159. data/spec/praxis/extensions/attribute_filtering/filtering_params_spec.rb +112 -60
  160. data/spec/praxis/extensions/attribute_filtering/filters_parser_spec.rb +37 -38
  161. data/spec/praxis/extensions/field_expansion_spec.rb +8 -10
  162. data/spec/praxis/extensions/field_selection/active_record_query_selector_spec.rb +14 -13
  163. data/spec/praxis/extensions/field_selection/field_selector_spec.rb +9 -16
  164. data/spec/praxis/extensions/field_selection/sequel_query_selector_spec.rb +50 -49
  165. data/spec/praxis/extensions/pagination/active_record_pagination_handler_spec.rb +32 -31
  166. data/spec/praxis/extensions/rendering_spec.rb +9 -9
  167. data/spec/praxis/extensions/support/spec_resources_active_model.rb +32 -47
  168. data/spec/praxis/extensions/support/spec_resources_sequel.rb +48 -48
  169. data/spec/praxis/field_expander_spec.rb +6 -5
  170. data/spec/praxis/file_group_spec.rb +3 -1
  171. data/spec/praxis/handlers/json_spec.rb +6 -5
  172. data/spec/praxis/mapper/resource_spec.rb +39 -29
  173. data/spec/praxis/mapper/selector_generator_spec.rb +80 -46
  174. data/spec/praxis/media_type_identifier_spec.rb +13 -10
  175. data/spec/praxis/media_type_spec.rb +12 -12
  176. data/spec/praxis/middleware_app_spec.rb +23 -22
  177. data/spec/praxis/multipart/parser_spec.rb +7 -9
  178. data/spec/praxis/notifications_spec.rb +4 -4
  179. data/spec/praxis/plugin_concern_spec.rb +5 -6
  180. data/spec/praxis/renderer_spec.rb +10 -9
  181. data/spec/praxis/request_spec.rb +38 -41
  182. data/spec/praxis/request_stages/action_spec.rb +14 -15
  183. data/spec/praxis/request_stages/request_stage_spec.rb +30 -41
  184. data/spec/praxis/request_stages/validate_spec.rb +3 -1
  185. data/spec/praxis/response_definition_spec.rb +79 -92
  186. data/spec/praxis/response_spec.rb +35 -40
  187. data/spec/praxis/responses/internal_server_error_spec.rb +6 -9
  188. data/spec/praxis/responses/validation_error_spec.rb +17 -18
  189. data/spec/praxis/route_spec.rb +4 -7
  190. data/spec/praxis/router_spec.rb +69 -79
  191. data/spec/praxis/routing_config_spec.rb +15 -14
  192. data/spec/praxis/stage_spec.rb +56 -53
  193. data/spec/praxis/trait_spec.rb +17 -17
  194. data/spec/praxis/types/fuzzy_hash_spec.rb +11 -9
  195. data/spec/praxis/types/multipart_array/part_definition_spec.rb +3 -2
  196. data/spec/praxis/types/multipart_array_spec.rb +33 -48
  197. data/spec/spec_app/app/concerns/authenticated.rb +5 -5
  198. data/spec/spec_app/app/concerns/basic_api.rb +3 -1
  199. data/spec/spec_app/app/concerns/log_wrapper.rb +5 -3
  200. data/spec/spec_app/app/controllers/base_class.rb +6 -5
  201. data/spec/spec_app/app/controllers/instances.rb +31 -34
  202. data/spec/spec_app/app/controllers/volumes.rb +6 -6
  203. data/spec/spec_app/app/responses/multipart.rb +1 -2
  204. data/spec/spec_app/app/responses/other_response.rb +2 -2
  205. data/spec/spec_app/config/environment.rb +19 -6
  206. data/spec/spec_app/config.ru +4 -3
  207. data/spec/spec_app/design/api.rb +13 -15
  208. data/spec/spec_app/design/media_types/instance.rb +6 -6
  209. data/spec/spec_app/design/media_types/volume.rb +2 -1
  210. data/spec/spec_app/design/media_types/volume_snapshot.rb +2 -1
  211. data/spec/spec_app/design/resources/instances.rb +11 -17
  212. data/spec/spec_app/design/resources/volume_snapshots.rb +4 -5
  213. data/spec/spec_app/design/resources/volumes.rb +4 -5
  214. data/spec/spec_helper.rb +12 -13
  215. data/spec/support/be_deep_equal_matcher.rb +5 -0
  216. data/spec/support/spec_authorization_plugin.rb +7 -12
  217. data/spec/support/spec_blueprints.rb +5 -4
  218. data/spec/support/spec_complex_authentication_plugin.rb +17 -34
  219. data/spec/support/spec_endpoint_definitions.rb +2 -3
  220. data/spec/support/spec_media_types.rb +28 -35
  221. data/spec/support/spec_resources.rb +22 -16
  222. data/spec/support/spec_simple_authentication_plugin.rb +5 -9
  223. data/tasks/loader.thor +4 -2
  224. data/tasks/thor/app.rb +7 -5
  225. data/tasks/thor/example.rb +23 -22
  226. data/tasks/thor/model.rb +7 -7
  227. data/tasks/thor/scaffold.rb +23 -23
  228. data/tasks/thor/templates/generator/example_app/app/v1/resources/user.rb +0 -8
  229. data/tasks/thor/templates/generator/scaffold/implementation/resources/item.rb +1 -2
  230. metadata +72 -84
  231. data/MAINTAINERS +0 -2
  232. data/TODO.md +0 -25
  233. data/spec/praxis/api_resource_spec.rb +0 -0
  234. data/spec/praxis/dispatcher_spec.rb +0 -0
  235. data/spec/spec_app/app/responses/bulk_response.rb +0 -0
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  require 'active_support/concern'
2
4
  require 'active_support/inflector'
3
5
 
@@ -8,21 +10,21 @@ module Praxis
8
10
  DEFAULT_RESOURCE_HREF_ACTION = :show
9
11
 
10
12
  included do
11
- @version = 'n/a'.freeze
12
- @actions = Hash.new
13
- @responses = Hash.new
13
+ @version = 'n/a'
14
+ @actions = {}
15
+ @responses = {}
14
16
 
15
- @action_defaults = Trait.new &EndpointDefinition.generate_defaults_block
17
+ @action_defaults = Trait.new(&EndpointDefinition.generate_defaults_block)
16
18
 
17
19
  @version_options = {}
18
20
  @metadata = {}
19
21
  @traits = []
20
22
 
21
- if self.name
22
- @prefix = '/' + self.name.split("::").last.underscore
23
- else
24
- @prefix = '/'
25
- end
23
+ @prefix = if name
24
+ "/#{name.split('::').last.underscore}"
25
+ else
26
+ '/'
27
+ end
26
28
 
27
29
  @version_prefix = ''
28
30
 
@@ -31,21 +33,20 @@ module Praxis
31
33
 
32
34
  @routing_prefix = nil
33
35
 
34
- @on_finalize = Array.new
36
+ @on_finalize = []
35
37
 
36
38
  Application.instance.endpoint_definitions << self
37
39
  end
38
40
 
39
- def self.generate_defaults_block( version: nil )
40
-
41
+ def self.generate_defaults_block(version: nil)
41
42
  # Ensure we inherit any base params defined in the API definition for the passed in version
42
43
  base_attributes = if (base_params = ApiDefinition.instance.info(version).base_params)
43
- base_params.attributes
44
- else
45
- {}
46
- end
44
+ base_params.attributes
45
+ else
46
+ {}
47
+ end
47
48
 
48
- Proc.new do
49
+ proc do
49
50
  unless base_attributes.empty?
50
51
  params do
51
52
  base_attributes.each do |base_name, base_attribute|
@@ -64,15 +65,8 @@ module Praxis
64
65
  end
65
66
  end
66
67
 
67
-
68
-
69
68
  module ClassMethods
70
- attr_reader :actions
71
- attr_reader :responses
72
- attr_reader :version_options
73
- attr_reader :traits
74
- attr_reader :version_prefix
75
- attr_reader :parent_prefix
69
+ attr_reader :actions, :responses, :version_options, :traits, :version_prefix, :parent_prefix
76
70
 
77
71
  # opaque hash of user-defined medata, used to decorate the definition,
78
72
  # and also available in the generated JSON documents
@@ -80,38 +74,35 @@ module Praxis
80
74
 
81
75
  attr_accessor :controller
82
76
 
83
- def display_name( string=nil )
77
+ def display_name(string = nil)
84
78
  unless string
85
- return @display_name ||= self.name.split("::").last # Best guess at a display name?
79
+ return @display_name ||= name.split('::').last # Best guess at a display name?
86
80
  end
81
+
87
82
  @display_name = string
88
83
  end
89
84
 
90
85
  def on_finalize(&block)
91
- if block_given?
92
- @on_finalize << proc(&block)
93
- end
86
+ @on_finalize << proc(&block) if block_given?
94
87
 
95
88
  @on_finalize
96
89
  end
97
90
 
98
- def prefix(prefix=nil)
91
+ def prefix(prefix = nil)
99
92
  return @prefix if prefix.nil?
93
+
100
94
  @routing_prefix = nil # reset routing_prefix
101
95
  @prefix = prefix
102
96
  end
103
97
 
104
- def media_type(media_type=nil)
98
+ def media_type(media_type = nil)
105
99
  return @media_type if media_type.nil?
106
100
 
107
- if media_type.kind_of?(String)
108
- media_type = SimpleMediaType.new(media_type)
109
- end
101
+ media_type = SimpleMediaType.new(media_type) if media_type.is_a?(String)
110
102
  @media_type = media_type
111
103
  end
112
104
 
113
-
114
- def parent(parent=nil, **mapping)
105
+ def parent(parent = nil, **mapping)
115
106
  return @parent if parent.nil?
116
107
 
117
108
  @routing_prefix = nil # reset routing_prefix
@@ -139,24 +130,24 @@ module Praxis
139
130
  param = mapping[name]
140
131
  # FIXME: this won't handle URI Template type paths, ie '/{parent_id}'
141
132
  prefixed_path = parent_action.route.prefixed_path
142
- @parent_prefix = prefixed_path.gsub(/(:)(#{name})(\W+|$)/, "\\1#{param.to_s}\\3")
133
+ @parent_prefix = prefixed_path.gsub(/(:)(#{name})(\W+|$)/, "\\1#{param}\\3")
143
134
  else
144
135
  mapping[name] = name
145
136
  end
146
137
  end
147
138
 
148
- self.on_finalize do
149
- self.inherit_params_from_parent(parent_action, **mapping)
139
+ on_finalize do
140
+ inherit_params_from_parent(parent_action, **mapping)
150
141
  end
151
142
 
152
143
  @parent = parent
153
144
  end
154
145
 
155
146
  def inherit_params_from_parent(parent_action, **mapping)
156
- actions.each do |name, action|
147
+ actions.each do |_name, action|
157
148
  action.params do
158
149
  mapping.each do |parent_name, name|
159
- next if action.params && action.params.attributes.key?(name)
150
+ next if action.params&.attributes&.key?(name)
160
151
 
161
152
  parent_attribute = parent_action.params.attributes[parent_name]
162
153
 
@@ -164,7 +155,6 @@ module Praxis
164
155
  end
165
156
  end
166
157
  end
167
-
168
158
  end
169
159
 
170
160
  attr_writer :routing_prefix
@@ -175,18 +165,17 @@ module Praxis
175
165
  @routing_prefix = parent_prefix + prefix
176
166
  end
177
167
 
178
-
179
- def version(version=nil)
168
+ def version(version = nil)
180
169
  return @version unless version
181
170
 
182
171
  @version = version
183
- @action_defaults.instance_eval &EndpointDefinition.generate_defaults_block( version: version )
172
+ @action_defaults.instance_eval(&EndpointDefinition.generate_defaults_block(version: version))
184
173
  end
185
174
 
186
-
187
- def canonical_path(action_name=nil)
175
+ def canonical_path(action_name = nil)
188
176
  if action_name
189
- raise "Canonical path for #{self.name} is already defined as: '#{@canonical_action_name}'. 'canonical_path' can only be defined once." if @canonical_action_name
177
+ raise "Canonical path for #{name} is already defined as: '#{@canonical_action_name}'. 'canonical_path' can only be defined once." if @canonical_action_name
178
+
190
179
  @canonical_action_name = action_name
191
180
  else
192
181
  # Resolution of the actual action definition needs to be done lazily, since we can use the `canonical_path` stanza
@@ -194,80 +183,74 @@ module Praxis
194
183
  unless @canonical_action
195
184
  href_action = @canonical_action_name || DEFAULT_RESOURCE_HREF_ACTION
196
185
  @canonical_action = actions.fetch(href_action) do
197
- raise "Error: trying to set canonical_href of #{self.name}. Action '#{href_action}' does not exist"
186
+ raise "Error: trying to set canonical_href of #{name}. Action '#{href_action}' does not exist"
198
187
  end
199
188
  end
200
- return @canonical_action
189
+ @canonical_action
201
190
  end
202
191
  end
203
192
 
204
- def to_href( params )
193
+ def to_href(params)
205
194
  canonical_path.route.path.expand(params.transform_values(&:to_s))
206
195
  end
207
196
 
208
197
  def parse_href(path)
209
- if path.kind_of?(::URI::Generic)
210
- path = path.path
211
- end
198
+ path = path.path if path.is_a?(::URI::Generic)
212
199
  param_values = canonical_path.route.path.params(path)
213
200
  attrs = canonical_path.params.attributes
214
- param_values.each_with_object({}) do |(key,value),hash|
215
- hash[key.to_sym] = attrs[key.to_sym].load(value,[key])
201
+ param_values.each_with_object({}) do |(key, value), hash|
202
+ hash[key.to_sym] = attrs[key.to_sym].load(value, [key])
216
203
  end
217
- rescue => e
218
- raise Praxis::Exception.new("Error parsing or coercing parameters from href: #{path}\n"+e.message)
204
+ rescue StandardError => e
205
+ raise Praxis::Exception, "Error parsing or coercing parameters from href: #{path}\n" + e.message
219
206
  end
220
207
 
221
208
  def trait(trait_name)
222
- unless ApiDefinition.instance.traits.has_key? trait_name
223
- raise Exceptions::InvalidTrait.new("Trait #{trait_name} not found in the system")
224
- end
225
- trait = ApiDefinition.instance.traits.fetch(trait_name)
209
+ raise Exceptions::InvalidTrait, "Trait #{trait_name} not found in the system" unless ApiDefinition.instance.traits.key? trait_name
210
+
211
+ # TODO: We're only storing the names here, should we store the actual traits in a hash?
226
212
  @traits << trait_name
227
213
  end
228
- alias_method :use, :trait
214
+ alias use trait
229
215
 
230
216
  def action_defaults(&block)
231
- if block_given?
232
- @action_defaults.instance_eval(&block)
233
- end
217
+ @action_defaults.instance_eval(&block) if block_given?
234
218
 
235
219
  @action_defaults
236
220
  end
237
221
 
238
222
  def action(name, &block)
239
- raise ArgumentError, "can not create ActionDefinition without block" unless block_given?
223
+ raise ArgumentError, 'can not create ActionDefinition without block' unless block_given?
240
224
  raise ArgumentError, "Action names must be defined using symbols (Got: #{name} (of type #{name.class}))" unless name.is_a? Symbol
225
+
241
226
  @actions[name] = ActionDefinition.new(name, self, &block)
242
227
  end
243
228
 
244
- def description(text=nil)
229
+ def description(text = nil)
245
230
  @description = text if text
246
231
  @description
247
232
  end
248
233
 
249
234
  def id
250
- self.name.gsub('::'.freeze,'-'.freeze)
235
+ name.gsub('::', '-')
251
236
  end
252
237
 
253
238
  def describe(context: nil)
254
239
  {}.tap do |hash|
255
240
  hash[:description] = description
256
241
  hash[:media_type] = media_type.describe(true) if media_type
257
- hash[:actions] = actions.values.collect{|action| action.describe(context: context)}
258
- hash[:name] = self.name
259
- hash[:parent] = self.parent.id if self.parent
260
- hash[:display_name] = self.display_name
242
+ hash[:actions] = actions.values.collect { |action| action.describe(context: context) }
243
+ hash[:name] = name
244
+ hash[:parent] = parent.id if parent
245
+ hash[:display_name] = display_name
261
246
  hash[:metadata] = metadata
262
- hash[:traits] = self.traits
247
+ hash[:traits] = traits
263
248
  end
264
249
  end
265
250
 
266
251
  def nodoc!
267
252
  metadata[:doc_visibility] = :none
268
253
  end
269
-
270
254
  end
271
-
272
255
  end
273
256
  end
@@ -1,6 +1,7 @@
1
+ # frozen_string_literal: true
2
+
1
3
  module Praxis
2
4
  class ErrorHandler
3
-
4
5
  def handle!(request, error)
5
6
  Application.instance.logger.error error.inspect
6
7
  error.backtrace.each do |line|
@@ -11,6 +12,5 @@ module Praxis
11
12
  response.request = request
12
13
  response.finish
13
14
  end
14
-
15
15
  end
16
16
  end
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  module Praxis
2
4
  class Exception < StandardError
3
5
  end
@@ -1,6 +1,8 @@
1
+ # frozen_string_literal: true
2
+
1
3
  module Praxis
2
4
  module Exceptions
3
- class Config < Exception
5
+ class Config < RuntimeError
4
6
  end
5
7
  end
6
8
  end
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  module Praxis
2
4
  module Exceptions
3
5
  class ConfigLoad < Config
@@ -1,8 +1,10 @@
1
+ # frozen_string_literal: true
2
+
1
3
  module Praxis
2
4
  module Exceptions
3
5
  class ConfigValidation < Config
4
6
  def initialize(errors:)
5
- super('Validation error: ' << errors.join('; '))
7
+ super("Validation error: #{errors.join('; ')}")
6
8
  end
7
9
  end
8
10
  end
@@ -1,6 +1,8 @@
1
+ # frozen_string_literal: true
2
+
1
3
  module Praxis
2
4
  module Exceptions
3
- class InvalidConfiguration < Exception
5
+ class InvalidConfiguration < RuntimeError
4
6
  end
5
7
  end
6
8
  end
@@ -1,6 +1,8 @@
1
+ # frozen_string_literal: true
2
+
1
3
  module Praxis
2
4
  module Exceptions
3
- class InvalidResponse < Exception
5
+ class InvalidResponse < RuntimeError
4
6
  end
5
7
  end
6
8
  end
@@ -1,6 +1,8 @@
1
+ # frozen_string_literal: true
2
+
1
3
  module Praxis
2
4
  module Exceptions
3
- class InvalidTrait < Exception
5
+ class InvalidTrait < RuntimeError
4
6
  end
5
7
  end
6
8
  end
@@ -1,6 +1,8 @@
1
+ # frozen_string_literal: true
2
+
1
3
  module Praxis
2
4
  module Exceptions
3
- class StageNotFound < Exception
5
+ class StageNotFound < RuntimeError
4
6
  end
5
7
  end
6
8
  end
@@ -1,13 +1,14 @@
1
+ # frozen_string_literal: true
2
+
1
3
  module Praxis
2
4
  module Exceptions
3
- class Validation < Exception
4
-
5
+ class Validation < RuntimeError
5
6
  attr_accessor :errors
7
+
6
8
  def initialize(message, errors: nil)
7
9
  super(message)
8
10
  @errors = errors
9
11
  end
10
-
11
12
  end
12
13
  end
13
14
  end