Class: Docit::Configuration

Inherits:
Object
  • Object
show all
Defined in:
lib/docit/configuration.rb

Overview

Holds global API documentation settings: metadata, authentication, tags, and servers.

Constant Summary collapse

SUPPORTED_UIS =
%i[scalar swagger].freeze

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initializeConfiguration

Returns a new instance of Configuration.



11
12
13
14
15
16
17
18
19
20
# File 'lib/docit/configuration.rb', line 11

def initialize
  @title = "API Documentation"
  @version = "1.0.0"
  @description = "Welcome to the API documentation. Browse the endpoints below to get started."
  @base_url = "/"
  @default_ui = :scalar
  @security_schemes = {}
  @tags = []
  @servers = []
end

Instance Attribute Details

#base_urlObject

Returns the value of attribute base_url.



8
9
10
# File 'lib/docit/configuration.rb', line 8

def base_url
  @base_url
end

#default_uiObject

Returns the value of attribute default_ui.



9
10
11
# File 'lib/docit/configuration.rb', line 9

def default_ui
  @default_ui
end

#descriptionObject

Returns the value of attribute description.



8
9
10
# File 'lib/docit/configuration.rb', line 8

def description
  @description
end

#titleObject

Returns the value of attribute title.



8
9
10
# File 'lib/docit/configuration.rb', line 8

def title
  @title
end

#versionObject

Returns the value of attribute version.



8
9
10
# File 'lib/docit/configuration.rb', line 8

def version
  @version
end

Instance Method Details

#auth(type, **options) ⇒ Object



31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
# File 'lib/docit/configuration.rb', line 31

def auth(type, **options)
  case type.to_s.downcase
  when "basic"
    @security_schemes[:basic_auth] = {
      type: "http",
      scheme: "basic"
    }
  when "bearer"
    @security_schemes[:bearer_auth] = {
      type: "http",
      scheme: "bearer",
      bearerFormat: options[:bearer_format] || "JWT"
    }
  when "api_key"
    @security_schemes[:api_key] = {
      type: "apiKey",
      name: options[:name] || "X-API-Key",
      in: options[:location] || "header"
    }
  else
    raise ArgumentError, "Unsupported auth type: #{type}"
  end
end

#security_schemesObject



55
56
57
# File 'lib/docit/configuration.rb', line 55

def security_schemes
  @security_schemes.dup
end

#server(url, description: nil) ⇒ Object



69
70
71
72
73
# File 'lib/docit/configuration.rb', line 69

def server(url, description: nil)
  entry = { url: url.to_s }
  entry[:description] = description if description
  @servers << entry
end

#serversObject



75
76
77
# File 'lib/docit/configuration.rb', line 75

def servers
  @servers.dup
end

#tag(name, description: nil) ⇒ Object



59
60
61
62
63
# File 'lib/docit/configuration.rb', line 59

def tag(name, description: nil)
  entry = { name: name.to_s }
  entry[:description] = description if description
  @tags << entry
end

#tagsObject



65
66
67
# File 'lib/docit/configuration.rb', line 65

def tags
  @tags.dup
end