Class: GrapeSwagger::DocMethods::Extensions
- Inherits:
-
Object
- Object
- GrapeSwagger::DocMethods::Extensions
- Defined in:
- lib/grape-swagger/doc_methods/extensions.rb
Class Method Summary collapse
- .add(path, definitions, route) ⇒ Object
- .add_extension_to(part, extensions) ⇒ Object
- .add_extensions_to_definition(settings, path, definitions) ⇒ Object
- .add_extensions_to_info(settings, info) ⇒ Object
- .add_extensions_to_operation(settings, path, route) ⇒ Object
- .add_extensions_to_path(settings, path) ⇒ Object
- .add_extensions_to_root(settings, object) ⇒ Object
- .concatenate(extensions) ⇒ Object
- .extended?(part, identifier = :x) ⇒ Boolean
- .extension(part, identifier = :x) ⇒ Object
- .find_definition(status, path) ⇒ Object
- .method(*args) ⇒ Object
- .setup_definition(def_extension, path, definitions) ⇒ Object
Class Method Details
.add(path, definitions, route) ⇒ Object
7 8 9 10 11 12 13 14 15 16 17 |
# File 'lib/grape-swagger/doc_methods/extensions.rb', line 7 def add(path, definitions, route) @route = route description = route.settings[:description] add_extension_to(path[method], extension(description)) if description && extended?(description, :x) settings = route.settings add_extensions_to_operation(settings, path, route) if settings && extended?(settings, :x_operation) add_extensions_to_path(settings, path) if settings && extended?(settings, :x_path) add_extensions_to_definition(settings, path, definitions) if settings && extended?(settings, :x_def) end |
.add_extension_to(part, extensions) ⇒ Object
63 64 65 66 67 68 69 |
# File 'lib/grape-swagger/doc_methods/extensions.rb', line 63 def add_extension_to(part, extensions) return if part.nil? concatenate(extensions).each do |key, value| part[key] = value unless key.start_with?('x-for') end end |
.add_extensions_to_definition(settings, path, definitions) ⇒ Object
35 36 37 38 39 40 41 42 43 |
# File 'lib/grape-swagger/doc_methods/extensions.rb', line 35 def add_extensions_to_definition(settings, path, definitions) def_extension = extension(settings, :x_def) if def_extension[:x_def].is_a?(Array) def_extension[:x_def].each { |extension| setup_definition(extension, path, definitions) } else setup_definition(def_extension[:x_def], path, definitions) end end |
.add_extensions_to_info(settings, info) ⇒ Object
23 24 25 |
# File 'lib/grape-swagger/doc_methods/extensions.rb', line 23 def add_extensions_to_info(settings, info) add_extension_to(info, extension(settings)) if extended?(settings, :x) end |
.add_extensions_to_operation(settings, path, route) ⇒ Object
27 28 29 |
# File 'lib/grape-swagger/doc_methods/extensions.rb', line 27 def add_extensions_to_operation(settings, path, route) add_extension_to(path[route.request_method.downcase.to_sym], extension(settings, :x_operation)) end |
.add_extensions_to_path(settings, path) ⇒ Object
31 32 33 |
# File 'lib/grape-swagger/doc_methods/extensions.rb', line 31 def add_extensions_to_path(settings, path) add_extension_to(path, extension(settings, :x_path)) end |
.add_extensions_to_root(settings, object) ⇒ Object
19 20 21 |
# File 'lib/grape-swagger/doc_methods/extensions.rb', line 19 def add_extensions_to_root(settings, object) add_extension_to(object, extension(settings)) if extended?(settings, :x) end |
.concatenate(extensions) ⇒ Object
71 72 73 74 75 76 77 78 79 80 81 |
# File 'lib/grape-swagger/doc_methods/extensions.rb', line 71 def concatenate(extensions) result = {} extensions.each_value do |extension| extension.each do |key, value| result["x-#{key}"] = value end end result end |
.extended?(part, identifier = :x) ⇒ Boolean
83 84 85 |
# File 'lib/grape-swagger/doc_methods/extensions.rb', line 83 def extended?(part, identifier = :x) !extension(part, identifier).empty? end |
.extension(part, identifier = :x) ⇒ Object
87 88 89 |
# File 'lib/grape-swagger/doc_methods/extensions.rb', line 87 def extension(part, identifier = :x) part.select { |x| x == identifier } end |
.find_definition(status, path) ⇒ Object
54 55 56 57 58 59 60 61 |
# File 'lib/grape-swagger/doc_methods/extensions.rb', line 54 def find_definition(status, path) response = path[method][:responses][status] return if response.nil? return response[:schema]['$ref'].split('/').last if response[:schema].key?('$ref') response[:schema]['items']['$ref'].split('/').last if response[:schema].key?('items') end |
.method(*args) ⇒ Object
91 92 93 94 95 96 97 98 |
# File 'lib/grape-swagger/doc_methods/extensions.rb', line 91 def method(*args) # We're shadowing Object.method(:symbol) here so we provide # a compatibility layer for code that introspects the methods # of this class return super if args.size.positive? @route.request_method.downcase.to_sym end |
.setup_definition(def_extension, path, definitions) ⇒ Object
45 46 47 48 49 50 51 52 |
# File 'lib/grape-swagger/doc_methods/extensions.rb', line 45 def setup_definition(def_extension, path, definitions) return unless def_extension.key?(:for) status = def_extension[:for] definition = find_definition(status, path) add_extension_to(definitions[definition], x_def: def_extension) end |