Class: Generator::API
Constant Summary
Constants included
from Formatter
Formatter::MAX_LINE_LENGTH
Instance Attribute Summary collapse
Class Method Summary
collapse
Instance Method Summary
collapse
Methods included from Formatter
#convert_doc_links_to_full_url, #convert_html_links_to_yard, #format_method_definition, #split_long_comment_line
Methods included from FileWriter
#format_files, #write_file
Constructor Details
#initialize(file) ⇒ API
Returns a new instance of API.
53
54
55
56
|
# File 'lib/generator/api.rb', line 53
def initialize(file)
@file = file
@written_files = []
end
|
Instance Attribute Details
#file ⇒ Object
Returns the value of attribute file.
24
25
26
|
# File 'lib/generator/api.rb', line 24
def file
@file
end
|
Class Method Details
.cleanup! ⇒ Object
41
42
43
44
45
46
47
48
49
50
|
# File 'lib/generator/api.rb', line 41
def cleanup!
["lib", "sig"].each do |base|
apis_path = File.join(Config::BASE_PATH, base, "peddler/apis")
FileUtils.mkdir_p(apis_path)
Dir.glob(File.join(apis_path, "*")).select { |p| File.directory?(p) }.each do |dir|
FileUtils.rm_rf(dir)
end
end
end
|
.generate ⇒ Object
27
28
29
30
31
32
|
# File 'lib/generator/api.rb', line 27
def generate
cleanup!
Parallel.each(apis, &:generate)
end
|
Instance Method Details
#class_name ⇒ Object
143
144
145
|
# File 'lib/generator/api.rb', line 143
def class_name
name_with_version.camelize
end
|
#convenience_method_name ⇒ Object
165
166
167
|
# File 'lib/generator/api.rb', line 165
def convenience_method_name
name
end
|
#description ⇒ Object
119
120
121
122
123
124
125
|
# File 'lib/generator/api.rb', line 119
def description
description = model["info"]["description"]
description = convert_html_links_to_yard(description)
description = convert_doc_links_to_full_url(description)
(description, base_indent: 4)
end
|
#file_path ⇒ Object
187
188
189
|
# File 'lib/generator/api.rb', line 187
def file_path
File.join(Config::BASE_PATH, "lib/#{library_name}.rb")
end
|
#generate ⇒ Object
58
59
60
61
62
63
64
65
66
67
68
|
# File 'lib/generator/api.rb', line 58
def generate
generate_api_class!
generate_types!
IntrospectionLoader.reload
generate_rbs!
format_files(@written_files)
Generator.logger.info("Generated #{name_with_version}")
end
|
#generate_api_class! ⇒ Object
70
71
72
|
# File 'lib/generator/api.rb', line 70
def generate_api_class!
@written_files << write_file(file_path, render)
end
|
#generate_rbs! ⇒ Object
95
96
97
98
|
# File 'lib/generator/api.rb', line 95
def generate_rbs!
@written_files << RBS::Unified.new(self, name_with_version, @api_types || []).generate
end
|
#generate_types! ⇒ Object
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
|
# File 'lib/generator/api.rb', line 74
def generate_types!
api_types = types
return [] if api_types.empty?
detector = CircularDependencyDetector.new(api_types)
detector.detect
api_types.each do |type|
type.circular_dependencies = detector.circular_deps
type.cycle_edges = detector.cycle_edges
end
api_types.each do |type|
@written_files << type.generate
end
@api_types = api_types
end
|
#github_model_filename ⇒ Object
195
196
197
198
|
# File 'lib/generator/api.rb', line 195
def github_model_filename
parts = file.split("/")
"#{parts[-2]}/#{parts[-1]}"
end
|
#has_helper? ⇒ Boolean
131
132
133
|
# File 'lib/generator/api.rb', line 131
def has_helper?
File.exist?("lib/" + helper_library_name + ".rb")
end
|
#helper_class_name ⇒ Object
135
136
137
|
# File 'lib/generator/api.rb', line 135
def helper_class_name
"Peddler::Helpers::#{name_with_version.camelize}"
end
|
#helper_library_name ⇒ Object
139
140
141
|
# File 'lib/generator/api.rb', line 139
def helper_library_name
"peddler/helpers/#{name_with_version}"
end
|
#latest_version? ⇒ Boolean
159
160
161
162
163
|
# File 'lib/generator/api.rb', line 159
def latest_version?
all_apis = self.class.apis.select { |api| api.name == name }
latest_version = VersionSelector.find_latest_version(all_apis.map(&:version))
version == latest_version
end
|
#library_name ⇒ Object
127
128
129
|
# File 'lib/generator/api.rb', line 127
def library_name
"peddler/apis/#{name_with_version}"
end
|
#name_with_version ⇒ Object
155
156
157
|
# File 'lib/generator/api.rb', line 155
def name_with_version
[name, version].join("_")
end
|
#openapi_spec ⇒ Object
191
192
193
|
# File 'lib/generator/api.rb', line 191
def openapi_spec
model
end
|
#operations ⇒ Object
169
170
171
172
173
174
|
# File 'lib/generator/api.rb', line 169
def operations
@operations ||= begin
ops = paths.flat_map { |path| path.operations(name_with_version) }.compact
deduplicate_operations(ops)
end
end
|
#paths ⇒ Object
183
184
185
|
# File 'lib/generator/api.rb', line 183
def paths
model["paths"].map { |path, methods| Path.new(path, methods) }
end
|
#title ⇒ Object
115
116
117
|
# File 'lib/generator/api.rb', line 115
def title
(model["info"]["title"], base_indent: 4)
end
|
#type_names ⇒ Object
176
177
178
179
180
181
|
# File 'lib/generator/api.rb', line 176
def type_names
openapi_spec["definitions"]
.select { |name, def_| def_["type"] == "object" && !TypeResolver::MONEY_TYPES.include?(name) && !def_["additionalProperties"] }
.keys
.sort
end
|
#types ⇒ Object
100
101
102
103
104
105
106
107
108
109
110
111
112
113
|
# File 'lib/generator/api.rb', line 100
def types
arr = []
openapi_spec["definitions"].each do |name, definition|
next unless definition["type"] == "object" || definition["allOf"] || definition["type"] == "array"
next if TypeResolver.money?(name)
next if definition["additionalProperties"] && !definition["properties"] && !definition["allOf"]
arr << Type.new(name, definition, name_with_version, openapi_spec)
end
arr
end
|
#version ⇒ Object
151
152
153
|
# File 'lib/generator/api.rb', line 151
def version
model["info"]["version"].tr("-", "_")
end
|