shaf 1.6.1 → 2.0.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- checksums.yaml.gz.sig +0 -0
- data.tar.gz.sig +0 -0
- data/iana_link_relations.csv.gz +0 -0
- data/lib/shaf.rb +6 -0
- data/lib/shaf/alps/attribute_serializer.rb +41 -0
- data/lib/shaf/alps/json_serializer.rb +50 -0
- data/lib/shaf/alps/relation_serializer.rb +70 -0
- data/lib/shaf/api_doc/link_relations.rb +77 -0
- data/lib/shaf/authenticator.rb +56 -0
- data/lib/shaf/authenticator/base.rb +161 -0
- data/lib/shaf/authenticator/basic_auth.rb +25 -0
- data/lib/shaf/authenticator/challenge.rb +32 -0
- data/lib/shaf/authenticator/parameter.rb +31 -0
- data/lib/shaf/authenticator/request.rb +17 -0
- data/lib/shaf/command/console.rb +1 -1
- data/lib/shaf/command/generate.rb +5 -2
- data/lib/shaf/command/new.rb +20 -7
- data/lib/shaf/command/templates/Gemfile.erb +1 -0
- data/{templates/config/settings.yml → lib/shaf/command/templates/config/settings.yml.erb} +1 -5
- data/lib/shaf/errors.rb +11 -0
- data/lib/shaf/extensions.rb +3 -3
- data/lib/shaf/extensions/api_routes.rb +60 -0
- data/lib/shaf/extensions/authorize.rb +11 -9
- data/lib/shaf/extensions/log.rb +1 -1
- data/lib/shaf/extensions/resource_uris.rb +139 -63
- data/lib/shaf/extensions/symbolic_routes.rb +22 -19
- data/lib/shaf/formable.rb +1 -2
- data/lib/shaf/formable/form.rb +1 -1
- data/lib/shaf/generator.rb +2 -0
- data/lib/shaf/generator/base.rb +2 -3
- data/lib/shaf/generator/controller.rb +11 -7
- data/lib/shaf/generator/doc.rb +17 -0
- data/lib/shaf/generator/forms.rb +1 -0
- data/lib/shaf/generator/helper.rb +2 -1
- data/lib/shaf/generator/migration/base.rb +7 -3
- data/lib/shaf/generator/migration/type.rb +4 -26
- data/lib/shaf/generator/migration/types.rb +45 -16
- data/lib/shaf/generator/model.rb +1 -2
- data/lib/shaf/generator/profile.rb +52 -0
- data/lib/shaf/generator/serializer.rb +38 -73
- data/lib/shaf/generator/templates/api/policy.rb.erb +2 -2
- data/lib/shaf/generator/templates/api/profile.rb.erb +16 -0
- data/lib/shaf/generator/templates/api/serializer.rb.erb +2 -2
- data/lib/shaf/generator/templates/spec/integration_spec.rb.erb +1 -2
- data/lib/shaf/generator/templates/spec/serializer_spec.rb.erb +5 -5
- data/lib/shaf/helpers.rb +4 -0
- data/lib/shaf/helpers/authentication.rb +79 -0
- data/lib/shaf/helpers/payload.rb +14 -34
- data/lib/shaf/helpers/vary.rb +8 -0
- data/lib/shaf/logger.rb +12 -0
- data/lib/shaf/parser.rb +65 -0
- data/lib/shaf/parser/base.rb +44 -0
- data/lib/shaf/parser/form_data.rb +15 -0
- data/lib/shaf/parser/json.rb +26 -0
- data/lib/shaf/profile.rb +110 -0
- data/lib/shaf/profile/attribute.rb +29 -0
- data/lib/shaf/profile/evaluator.rb +46 -0
- data/lib/shaf/profile/relation.rb +29 -0
- data/lib/shaf/profile/unique_id.rb +58 -0
- data/lib/shaf/profiles.rb +42 -0
- data/lib/shaf/profiles/shaf_basic.rb +20 -0
- data/lib/shaf/profiles/shaf_error.rb +48 -0
- data/lib/shaf/profiles/shaf_form.rb +109 -0
- data/lib/shaf/responder.rb +41 -2
- data/lib/shaf/responder/alps_json.rb +25 -0
- data/lib/shaf/responder/base.rb +20 -17
- data/lib/shaf/responder/hal.rb +65 -4
- data/lib/shaf/responder/html.rb +43 -16
- data/lib/shaf/responder/problem_json.rb +1 -1
- data/lib/shaf/serializer.rb +31 -0
- data/lib/shaf/settings.rb +25 -12
- data/lib/shaf/spec.rb +1 -0
- data/lib/shaf/spec/authenticator.rb +13 -0
- data/lib/shaf/spec/base.rb +1 -1
- data/lib/shaf/spec/http_method_utils.rb +1 -1
- data/lib/shaf/spec/integration_spec.rb +25 -13
- data/lib/shaf/spec/payload_utils.rb +2 -2
- data/lib/shaf/supported_http_methods.rb +15 -0
- data/lib/shaf/tasks/api_doc_task.rb +24 -3
- data/lib/shaf/tasks/routes_task.rb +14 -17
- data/lib/shaf/upgrade/manifest.rb +11 -2
- data/lib/shaf/upgrade/package.rb +73 -43
- data/lib/shaf/upgrade/version.rb +11 -10
- data/lib/shaf/utils.rb +19 -5
- data/lib/shaf/version.rb +3 -1
- data/lib/shaf/yard.rb +34 -0
- data/lib/shaf/yard/attribute_method_handler.rb +19 -0
- data/lib/shaf/yard/attribute_object.rb +30 -0
- data/lib/shaf/yard/base_method_handler.rb +30 -0
- data/lib/shaf/yard/link_method_handler.rb +39 -0
- data/lib/shaf/yard/link_object.rb +60 -0
- data/lib/shaf/yard/nested_attributes.rb +37 -0
- data/lib/shaf/yard/parser.rb +64 -0
- data/lib/shaf/yard/profile_method_handler.rb +51 -0
- data/lib/shaf/yard/profile_object.rb +21 -0
- data/lib/shaf/yard/resource_object.rb +55 -0
- data/lib/shaf/yard/serializer_handler.rb +27 -0
- data/templates/api/controllers/base_controller.rb +0 -10
- data/templates/api/controllers/docs_controller.rb +5 -3
- data/templates/api/controllers/root_controller.rb +7 -1
- data/templates/api/policies/base_policy.rb +2 -0
- data/templates/api/serializers/base_serializer.rb +1 -3
- data/templates/api/serializers/error_serializer.rb +1 -5
- data/templates/api/serializers/form_serializer.rb +1 -5
- data/templates/api/serializers/validation_error_serializer.rb +1 -5
- data/templates/config/bootstrap.rb +1 -2
- data/templates/config/directories.rb +52 -44
- data/templates/config/helpers.rb +1 -1
- data/templates/config/initializers.rb +52 -8
- data/templates/config/initializers/authentication.rb +18 -0
- data/templates/config/initializers/db_migrations.rb +2 -2
- data/templates/config/initializers/logging.rb +2 -2
- data/templates/spec/spec_helper.rb +2 -0
- data/upgrades/0.5.0.tar.gz +0 -0
- data/upgrades/1.0.4.tar.gz +0 -0
- data/upgrades/1.1.0.tar.gz +0 -0
- data/upgrades/2.0.0.tar.gz +0 -0
- data/yard_templates/api_doc/doc_index/html/body.erb +3 -0
- data/yard_templates/api_doc/doc_index/setup.rb +8 -0
- data/yard_templates/api_doc/html/css/api-doc.css +222 -0
- data/yard_templates/api_doc/html/favicon.ico +0 -0
- data/yard_templates/api_doc/html/js/switch_tab.js +17 -0
- data/yard_templates/api_doc/html/setup.rb +59 -0
- data/yard_templates/api_doc/layout/html/footer.erb +3 -0
- data/yard_templates/api_doc/layout/html/header.erb +7 -0
- data/yard_templates/api_doc/layout/html/layout.erb +13 -0
- data/yard_templates/api_doc/layout/setup.rb +24 -0
- data/yard_templates/api_doc/profile/html/attributes.erb +10 -0
- data/yard_templates/api_doc/profile/html/profile.erb +6 -0
- data/yard_templates/api_doc/profile/html/relations.erb +10 -0
- data/yard_templates/api_doc/profile/setup.rb +38 -0
- data/yard_templates/api_doc/profile_attribute/html/attribute.erb +23 -0
- data/yard_templates/api_doc/profile_attribute/setup.rb +21 -0
- data/yard_templates/api_doc/profile_relation/html/relation.erb +37 -0
- data/yard_templates/api_doc/profile_relation/setup.rb +41 -0
- data/yard_templates/api_doc/resource/html/attributes.erb +10 -0
- data/yard_templates/api_doc/resource/html/profile.erb +14 -0
- data/yard_templates/api_doc/resource/html/relations.erb +10 -0
- data/yard_templates/api_doc/resource/html/resource.erb +5 -0
- data/yard_templates/api_doc/resource/setup.rb +56 -0
- data/yard_templates/api_doc/resource_attribute/html/attribute.erb +23 -0
- data/yard_templates/api_doc/resource_attribute/setup.rb +20 -0
- data/yard_templates/api_doc/resource_relation/html/relation.erb +47 -0
- data/yard_templates/api_doc/resource_relation/setup.rb +80 -0
- data/yard_templates/api_doc/setup.rb +31 -0
- data/yard_templates/api_doc/sidebar/html/profile_list.erb +8 -0
- data/yard_templates/api_doc/sidebar/html/search.erb +7 -0
- data/yard_templates/api_doc/sidebar/html/serializer_list.erb +8 -0
- data/yard_templates/api_doc/sidebar/html/sidebar.erb +13 -0
- data/yard_templates/api_doc/sidebar/setup.rb +56 -0
- metadata +137 -30
- metadata.gz.sig +1 -3
- data/lib/shaf/extensions/current_user.rb +0 -48
- data/lib/shaf/responder/hal_serializable.rb +0 -64
data/lib/shaf/upgrade/version.rb
CHANGED
@@ -8,7 +8,7 @@ module Shaf
|
|
8
8
|
alias eql? ==
|
9
9
|
|
10
10
|
class UpgradeVersionError < StandardError
|
11
|
-
def initialize(message =
|
11
|
+
def initialize(message = '')
|
12
12
|
super("Bad upgrade version: #{message}")
|
13
13
|
end
|
14
14
|
end
|
@@ -16,25 +16,26 @@ module Shaf
|
|
16
16
|
def initialize(version)
|
17
17
|
case version
|
18
18
|
when Version
|
19
|
-
@major, @minor, @patch =
|
19
|
+
@major, @minor, @patch = version.to_a
|
20
20
|
when /\d+\.\d+(\.\d+)?/
|
21
21
|
@major, @minor, @patch = split_version(version)
|
22
22
|
else
|
23
|
-
raise UpgradeVersionError
|
23
|
+
raise UpgradeVersionError, version
|
24
24
|
end
|
25
25
|
end
|
26
26
|
|
27
27
|
def <=>(other)
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
when Version
|
32
|
-
compare_version(other.major, other.minor, other.patch)
|
33
|
-
end
|
28
|
+
return unless other
|
29
|
+
other = self.class.new(other)
|
30
|
+
compare_version(other.major, other.minor, other.patch)
|
34
31
|
end
|
35
32
|
|
36
33
|
def to_s
|
37
|
-
|
34
|
+
to_a.join('.')
|
35
|
+
end
|
36
|
+
|
37
|
+
def to_a
|
38
|
+
[major, minor, patch]
|
38
39
|
end
|
39
40
|
|
40
41
|
private
|
data/lib/shaf/utils.rb
CHANGED
@@ -3,6 +3,8 @@
|
|
3
3
|
require 'erb'
|
4
4
|
require 'forwardable'
|
5
5
|
require 'yaml'
|
6
|
+
require 'csv'
|
7
|
+
require 'zlib'
|
6
8
|
require 'shaf/version'
|
7
9
|
|
8
10
|
module Shaf
|
@@ -35,12 +37,19 @@ module Shaf
|
|
35
37
|
noun[0..-2]
|
36
38
|
end
|
37
39
|
|
38
|
-
def
|
39
|
-
|
40
|
+
def symbol_string(str)
|
41
|
+
str.to_sym.inspect
|
40
42
|
end
|
41
43
|
|
42
|
-
def
|
43
|
-
|
44
|
+
def symbol_or_quoted_string(obj)
|
45
|
+
case obj
|
46
|
+
when Symbol
|
47
|
+
obj.inspect
|
48
|
+
when Numeric
|
49
|
+
obj
|
50
|
+
else
|
51
|
+
"'#{obj.to_s}'"
|
52
|
+
end
|
44
53
|
end
|
45
54
|
|
46
55
|
def environment
|
@@ -98,6 +107,11 @@ module Shaf
|
|
98
107
|
end
|
99
108
|
end
|
100
109
|
|
110
|
+
def iana_link_relations_csv
|
111
|
+
zip_file = File.join(gem_root, 'iana_link_relations.csv.gz')
|
112
|
+
Zlib::GzipReader.open(zip_file) { |content| CSV.new(content.read) }
|
113
|
+
end
|
114
|
+
|
101
115
|
private
|
102
116
|
|
103
117
|
def erb(content, binding: nil)
|
@@ -107,7 +121,7 @@ module Shaf
|
|
107
121
|
end
|
108
122
|
end
|
109
123
|
|
110
|
-
def_delegators Utils, :pluralize, :singularize, :
|
124
|
+
def_delegators Utils, :pluralize, :singularize, :symbol_string, :gem_root, :rackify_header
|
111
125
|
|
112
126
|
def project_root
|
113
127
|
return @project_root if defined? @project_root
|
data/lib/shaf/version.rb
CHANGED
data/lib/shaf/yard.rb
ADDED
@@ -0,0 +1,34 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'yard'
|
4
|
+
require 'shaf/yard/serializer_handler'
|
5
|
+
require 'shaf/yard/attribute_method_handler'
|
6
|
+
require 'shaf/yard/link_method_handler'
|
7
|
+
require 'shaf/yard/profile_method_handler'
|
8
|
+
require 'shaf/yard/resource_object'
|
9
|
+
require 'shaf/yard/profile_object'
|
10
|
+
require 'shaf/yard/attribute_object'
|
11
|
+
require 'shaf/yard/link_object'
|
12
|
+
require 'shaf/yard/nested_attributes'
|
13
|
+
require 'shaf/yard/parser'
|
14
|
+
|
15
|
+
module Shaf
|
16
|
+
module Yard
|
17
|
+
CUSTOM_TAGS = [
|
18
|
+
['Request Header', :request_header, :with_name],
|
19
|
+
['Reponse Header', :response_header, :with_name],
|
20
|
+
['Example Request', :example_request],
|
21
|
+
['Example Response', :example_response],
|
22
|
+
['Description', :description],
|
23
|
+
['HTTP method', :http_method],
|
24
|
+
['Attribute type', :type, :with_types]
|
25
|
+
].freeze
|
26
|
+
|
27
|
+
CUSTOM_TAGS.each do |tag|
|
28
|
+
YARD::Tags::Library.define_tag(*tag)
|
29
|
+
end
|
30
|
+
|
31
|
+
TEMPLATE_PATH = File.join(Utils.gem_root, 'yard_templates').freeze
|
32
|
+
YARD::Templates::Engine.register_template_path TEMPLATE_PATH
|
33
|
+
end
|
34
|
+
end
|
@@ -0,0 +1,19 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'shaf/yard/base_method_handler'
|
4
|
+
|
5
|
+
module Shaf
|
6
|
+
module Yard
|
7
|
+
# Handles call to Shaf::Serializer::attribute
|
8
|
+
class AttributeMethodHandler < BaseMethodHandler
|
9
|
+
handles method_call(:attribute)
|
10
|
+
|
11
|
+
def object
|
12
|
+
AttributeObject.new(serializer_namespace, name).tap do |attr|
|
13
|
+
attr.dynamic = true
|
14
|
+
attr.name = name
|
15
|
+
end
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|
@@ -0,0 +1,30 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module Shaf
|
4
|
+
module Yard
|
5
|
+
class AttributeObject < ::YARD::CodeObjects::Base
|
6
|
+
attr_accessor :name
|
7
|
+
|
8
|
+
def documentation
|
9
|
+
profile_doc || 'Not documented'
|
10
|
+
end
|
11
|
+
|
12
|
+
def profile
|
13
|
+
return unless namespace.respond_to? :profile
|
14
|
+
@profile ||= namespace.profile
|
15
|
+
end
|
16
|
+
|
17
|
+
def value_types
|
18
|
+
Array(descriptor&.type).compact.map(&:to_s)
|
19
|
+
end
|
20
|
+
|
21
|
+
def profile_doc
|
22
|
+
descriptor&.doc
|
23
|
+
end
|
24
|
+
|
25
|
+
def descriptor
|
26
|
+
profile&.find_attribute(name)
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
@@ -0,0 +1,30 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module Shaf
|
4
|
+
module Yard
|
5
|
+
class BaseMethodHandler < ::YARD::Handlers::Ruby::Base
|
6
|
+
namespace_only
|
7
|
+
|
8
|
+
def process
|
9
|
+
return unless serializer_namespace
|
10
|
+
|
11
|
+
register object
|
12
|
+
end
|
13
|
+
|
14
|
+
def name
|
15
|
+
call_params.first.yield_self do |name|
|
16
|
+
# remove single colon. Sometimes symbols get the :, (e.g. :self)
|
17
|
+
name.sub(/\A:(?!:)/, '')
|
18
|
+
end
|
19
|
+
end
|
20
|
+
|
21
|
+
def object
|
22
|
+
raise NotImplementedError, "#{self} must implement #object"
|
23
|
+
end
|
24
|
+
|
25
|
+
def serializer_namespace
|
26
|
+
@serializer_namespace ||= YARD::Registry.at ResourceObject.path(namespace)
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
@@ -0,0 +1,39 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'shaf/yard/base_method_handler'
|
4
|
+
|
5
|
+
module Shaf
|
6
|
+
module Yard
|
7
|
+
# Handles call to Shaf::Serializer::link
|
8
|
+
class LinkMethodHandler < BaseMethodHandler
|
9
|
+
handles method_call(:link)
|
10
|
+
|
11
|
+
def object
|
12
|
+
LinkObject.new(serializer_namespace, name).tap do |link|
|
13
|
+
link.dynamic = true
|
14
|
+
link.rel = name
|
15
|
+
link.curie = curie
|
16
|
+
end
|
17
|
+
end
|
18
|
+
|
19
|
+
def name
|
20
|
+
super.sub(/[^:]+:/, '')
|
21
|
+
end
|
22
|
+
|
23
|
+
def curie
|
24
|
+
m = name.match(/([^:]+):/)
|
25
|
+
return m[1] if m
|
26
|
+
|
27
|
+
statement.parameters(false).each do |param|
|
28
|
+
next unless param&.respond_to? :source
|
29
|
+
|
30
|
+
str = String(param.source)
|
31
|
+
m = str.match(/curie:\s:?(\w+)/)
|
32
|
+
return m[1] if m
|
33
|
+
end
|
34
|
+
|
35
|
+
nil
|
36
|
+
end
|
37
|
+
end
|
38
|
+
end
|
39
|
+
end
|
@@ -0,0 +1,60 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'shaf/api_doc/link_relations'
|
4
|
+
|
5
|
+
module Shaf
|
6
|
+
module Yard
|
7
|
+
class LinkObject < ::YARD::CodeObjects::Base
|
8
|
+
attr_accessor :rel, :curie
|
9
|
+
|
10
|
+
def curie?
|
11
|
+
!!curie
|
12
|
+
end
|
13
|
+
|
14
|
+
def documentation
|
15
|
+
profile_doc || iana_doc || 'Undocumented'
|
16
|
+
end
|
17
|
+
|
18
|
+
def profile_object
|
19
|
+
return unless profile
|
20
|
+
return unless namespace.respond_to? :profile_objects
|
21
|
+
|
22
|
+
namespace.profile_objects.find do |po|
|
23
|
+
po.profile == profile
|
24
|
+
end
|
25
|
+
end
|
26
|
+
|
27
|
+
def profile
|
28
|
+
return @profile if defined? @profile
|
29
|
+
return unless namespace.respond_to? :profile
|
30
|
+
profile = namespace.profile
|
31
|
+
@profile = profile&.find_relation(name) && profile
|
32
|
+
end
|
33
|
+
|
34
|
+
def descriptor
|
35
|
+
profile&.find_relation(rel)
|
36
|
+
end
|
37
|
+
|
38
|
+
def profile_doc
|
39
|
+
descriptor&.doc
|
40
|
+
end
|
41
|
+
|
42
|
+
def http_methods
|
43
|
+
Array(descriptor&.http_methods)
|
44
|
+
end
|
45
|
+
|
46
|
+
def href
|
47
|
+
descriptor&.href
|
48
|
+
end
|
49
|
+
|
50
|
+
def content_type
|
51
|
+
descriptor&.content_type
|
52
|
+
end
|
53
|
+
|
54
|
+
def iana_doc
|
55
|
+
ApiDoc::LinkRelations.load_iana
|
56
|
+
ApiDoc::LinkRelations[name.to_sym]&.description
|
57
|
+
end
|
58
|
+
end
|
59
|
+
end
|
60
|
+
end
|
@@ -0,0 +1,37 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module Shaf
|
4
|
+
module Yard
|
5
|
+
module NestedAttributes
|
6
|
+
def nested_attributes_for(descriptor)
|
7
|
+
return {} unless descriptor
|
8
|
+
|
9
|
+
base_key = nested_key(descriptor)
|
10
|
+
nested_attributes(descriptor)
|
11
|
+
.yield_self { |nested| flatten(nested, base_key) }
|
12
|
+
end
|
13
|
+
|
14
|
+
def nested_attributes(descriptor)
|
15
|
+
attrs = Array(descriptor&.attributes)
|
16
|
+
attrs.each_with_object({}) do |attr, nested|
|
17
|
+
nested[attr] = nested_attributes(attr)
|
18
|
+
end.transform_values { |v| v.empty? ? nil : v }
|
19
|
+
end
|
20
|
+
|
21
|
+
def flatten(nested, base_key)
|
22
|
+
return {} if !nested || nested.empty?
|
23
|
+
|
24
|
+
nested.each_with_object({}) do |(desc, nested), all|
|
25
|
+
key = nested_key(base_key, desc)
|
26
|
+
all[key] = desc
|
27
|
+
next unless nested
|
28
|
+
all.merge!(flatten(nested, key))
|
29
|
+
end
|
30
|
+
end
|
31
|
+
|
32
|
+
def nested_key(base_key = nil, desc)
|
33
|
+
[base_key, desc.name].compact.join('.')
|
34
|
+
end
|
35
|
+
end
|
36
|
+
end
|
37
|
+
end
|
@@ -0,0 +1,64 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module Shaf
|
4
|
+
module Yard
|
5
|
+
class Parser
|
6
|
+
def self.call(name: '')
|
7
|
+
new(name).parse!
|
8
|
+
end
|
9
|
+
|
10
|
+
def initialize(name)
|
11
|
+
@name = name.downcase
|
12
|
+
end
|
13
|
+
|
14
|
+
def parse!
|
15
|
+
verify_exists! unless name.empty?
|
16
|
+
::YARD.parse pattern
|
17
|
+
end
|
18
|
+
|
19
|
+
private
|
20
|
+
|
21
|
+
attr_reader :name
|
22
|
+
|
23
|
+
def pattern
|
24
|
+
return file_path if file_path
|
25
|
+
|
26
|
+
base = ['*', suffix].join
|
27
|
+
File.join(base_dir, '**', base)
|
28
|
+
end
|
29
|
+
|
30
|
+
def suffix
|
31
|
+
'_serializer.rb'
|
32
|
+
end
|
33
|
+
|
34
|
+
def verify_exists!
|
35
|
+
file_path or raise <<~ERR
|
36
|
+
Could not find a matching serializer for #{name}.
|
37
|
+
Looked in: #{base_dir}
|
38
|
+
Using suffix: #{suffix}
|
39
|
+
ERR
|
40
|
+
end
|
41
|
+
|
42
|
+
def file_path
|
43
|
+
@file_path ||= lookup_path
|
44
|
+
end
|
45
|
+
|
46
|
+
def base_dir
|
47
|
+
File.join(Shaf::Settings.app_dir || 'api', 'serializers')
|
48
|
+
end
|
49
|
+
|
50
|
+
def lookup_path
|
51
|
+
return if name.empty?
|
52
|
+
|
53
|
+
path = File.join(base_dir, name)
|
54
|
+
return path if File.exist? path
|
55
|
+
|
56
|
+
with_suffix = [path, suffix].join
|
57
|
+
return with_suffix if File.exist? with_suffix
|
58
|
+
|
59
|
+
with_extension = [path, '.rb'].join
|
60
|
+
with_extension if File.exist? with_extension
|
61
|
+
end
|
62
|
+
end
|
63
|
+
end
|
64
|
+
end
|
@@ -0,0 +1,51 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'shaf/yard/base_method_handler'
|
4
|
+
require 'shaf/profiles'
|
5
|
+
require 'shaf/utils'
|
6
|
+
|
7
|
+
module Shaf
|
8
|
+
module Yard
|
9
|
+
# Handles call to Shaf::Serializer::profile
|
10
|
+
class ProfileMethodHandler < BaseMethodHandler
|
11
|
+
include Shaf::Utils
|
12
|
+
|
13
|
+
handles method_call(:profile)
|
14
|
+
|
15
|
+
def process
|
16
|
+
serializer = serializer_namespace
|
17
|
+
profile = shaf_profile
|
18
|
+
return unless serializer
|
19
|
+
|
20
|
+
serializer.profile = profile
|
21
|
+
|
22
|
+
register object
|
23
|
+
serializer_namespace.profile_objects << object
|
24
|
+
end
|
25
|
+
|
26
|
+
def shaf_profile
|
27
|
+
return @shaf_profile if defined? @shaf_profile
|
28
|
+
|
29
|
+
bootstrap(env: ENV['RACK_ENV'])
|
30
|
+
|
31
|
+
@shaf_profile = Shaf::Profiles.find name
|
32
|
+
end
|
33
|
+
|
34
|
+
def object
|
35
|
+
# Put the Profile object on the the same namespace level as
|
36
|
+
# the serializer. Typically this it the root namespace
|
37
|
+
ns = namespace.namespace
|
38
|
+
|
39
|
+
name = shaf_profile&.to_s || self.name
|
40
|
+
name.gsub!(/(Shaf|Profiles)?::/, "")
|
41
|
+
|
42
|
+
name << "Profile" unless name.end_with? "Profile"
|
43
|
+
|
44
|
+
ProfileObject.new(ns, name).tap do |obj|
|
45
|
+
obj.dynamic = true
|
46
|
+
obj.profile = shaf_profile
|
47
|
+
end
|
48
|
+
end
|
49
|
+
end
|
50
|
+
end
|
51
|
+
end
|