aws-sdk-core 2.0.48 → 2.1.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/apis/autoscaling/2011-01-01/api-2.json +636 -33
- data/apis/cloudhsm/2014-05-30/api-2.json +3 -6
- data/apis/ec2/2014-10-01/api-2.json +10267 -0
- data/apis/ec2/2014-10-01/paginators-1.json +125 -0
- data/apis/ec2/2014-10-01/resources-1.json +2289 -0
- data/apis/ec2/2014-10-01/waiters-2.json +453 -0
- data/apis/ec2/2015-03-01/api-2.json +11245 -0
- data/apis/ec2/2015-03-01/paginators-1.json +125 -0
- data/apis/ec2/2015-03-01/resources-1.json +2479 -0
- data/apis/ec2/2015-03-01/waiters-2.json +458 -0
- data/apis/ec2/2015-04-15/api-2.json +182 -2
- data/apis/ecs/2014-11-13/api-2.json +316 -7
- data/apis/ecs/2014-11-13/paginators-1.json +40 -0
- data/apis/ecs/2014-11-13/waiters-2.json +93 -0
- data/apis/redshift/2012-12-01/waiters-2.json +19 -0
- data/apis/s3/2006-03-01/api-2.json +1 -2
- data/apis/sqs/2012-11-05/api-2.json +5 -6
- data/ca-bundle.crt +3554 -0
- data/lib/aws-sdk-core.rb +127 -44
- data/lib/aws-sdk-core/api/builder.rb +95 -0
- data/lib/aws-sdk-core/api/customizations.rb +152 -0
- data/lib/aws-sdk-core/api/docs/builder.rb +220 -0
- data/lib/aws-sdk-core/api/docs/client_type_documenter.rb +109 -0
- data/lib/aws-sdk-core/api/docs/docstring_provider.rb +66 -0
- data/lib/aws-sdk-core/api/docs/operation_documenter.rb +107 -0
- data/lib/aws-sdk-core/api/docs/param_formatter.rb +163 -0
- data/lib/aws-sdk-core/api/docs/request_syntax_example.rb +22 -0
- data/lib/aws-sdk-core/api/docs/response_structure_example.rb +91 -0
- data/lib/aws-sdk-core/api/docs/utils.rb +133 -0
- data/lib/aws-sdk-core/api/shape_map.rb +140 -0
- data/lib/aws-sdk-core/assume_role_credentials.rb +9 -6
- data/lib/aws-sdk-core/client.rb +9 -6
- data/lib/aws-sdk-core/client_stubs.rb +127 -133
- data/lib/aws-sdk-core/client_waiters.rb +1 -1
- data/lib/aws-sdk-core/credential_provider.rb +44 -0
- data/lib/aws-sdk-core/credential_provider_chain.rb +3 -2
- data/lib/aws-sdk-core/credentials.rb +5 -0
- data/lib/aws-sdk-core/deprecations.rb +69 -0
- data/lib/aws-sdk-core/dynamodb.rb +12 -0
- data/lib/aws-sdk-core/eager_loader.rb +31 -0
- data/lib/aws-sdk-core/ecs.rb +2 -0
- data/lib/aws-sdk-core/empty_structure.rb +1 -82
- data/lib/aws-sdk-core/endpoint_provider.rb +1 -1
- data/lib/aws-sdk-core/instance_profile_credentials.rb +9 -10
- data/lib/aws-sdk-core/json.rb +56 -0
- data/lib/aws-sdk-core/json/builder.rb +33 -34
- data/lib/aws-sdk-core/json/error_handler.rb +2 -2
- data/lib/aws-sdk-core/json/handler.rb +67 -0
- data/lib/aws-sdk-core/json/json_engine.rb +15 -0
- data/lib/aws-sdk-core/json/oj_engine.rb +15 -0
- data/lib/aws-sdk-core/json/parser.rb +30 -38
- data/lib/aws-sdk-core/pageable_response.rb +9 -12
- data/lib/aws-sdk-core/pager.rb +69 -0
- data/lib/aws-sdk-core/param_converter.rb +203 -0
- data/lib/aws-sdk-core/param_validator.rb +148 -0
- data/lib/aws-sdk-core/plugins/dynamodb_simple_attributes.rb +21 -18
- data/lib/aws-sdk-core/plugins/glacier_account_id.rb +9 -1
- data/lib/aws-sdk-core/plugins/glacier_checksums.rb +2 -3
- data/lib/aws-sdk-core/plugins/param_converter.rb +27 -0
- data/lib/aws-sdk-core/plugins/param_validator.rb +28 -0
- data/lib/aws-sdk-core/plugins/protocols/json_rpc.rb +3 -7
- data/lib/aws-sdk-core/plugins/protocols/rest_json.rb +1 -2
- data/lib/aws-sdk-core/plugins/protocols/rest_xml.rb +1 -1
- data/lib/aws-sdk-core/plugins/regional_endpoint.rb +1 -1
- data/lib/aws-sdk-core/plugins/request_signer.rb +5 -5
- data/lib/aws-sdk-core/plugins/response_paging.rb +20 -11
- data/lib/aws-sdk-core/plugins/s3_get_bucket_location_fix.rb +1 -1
- data/lib/aws-sdk-core/plugins/s3_request_signer.rb +1 -2
- data/lib/aws-sdk-core/plugins/stub_responses.rb +25 -27
- data/lib/aws-sdk-core/query/ec2_param_builder.rb +29 -34
- data/lib/aws-sdk-core/query/handler.rb +32 -18
- data/lib/aws-sdk-core/query/param_builder.rb +45 -53
- data/lib/aws-sdk-core/refreshing_credentials.rb +3 -15
- data/lib/aws-sdk-core/rest/handler.rb +22 -0
- data/lib/aws-sdk-core/rest/request/body.rb +58 -0
- data/lib/aws-sdk-core/rest/request/builder.rb +50 -0
- data/lib/aws-sdk-core/rest/request/endpoint.rb +70 -0
- data/lib/aws-sdk-core/rest/request/headers.rb +48 -0
- data/lib/aws-sdk-core/rest/response/body.rb +43 -0
- data/lib/aws-sdk-core/rest/response/headers.rb +60 -0
- data/lib/aws-sdk-core/rest/response/parser.rb +47 -0
- data/lib/aws-sdk-core/rest/response/status_code.rb +24 -0
- data/lib/aws-sdk-core/shared_credentials.rb +11 -6
- data/lib/aws-sdk-core/signers/base.rb +1 -1
- data/lib/aws-sdk-core/signers/s3.rb +2 -3
- data/lib/aws-sdk-core/signers/v2.rb +7 -4
- data/lib/aws-sdk-core/signers/v4.rb +11 -22
- data/lib/aws-sdk-core/structure.rb +26 -145
- data/lib/aws-sdk-core/stubbing/data_applicator.rb +46 -0
- data/lib/aws-sdk-core/stubbing/empty_stub.rb +53 -0
- data/lib/aws-sdk-core/stubbing/protocols/ec2.rb +49 -0
- data/lib/aws-sdk-core/stubbing/protocols/json.rb +40 -0
- data/lib/aws-sdk-core/stubbing/protocols/query.rb +40 -0
- data/lib/aws-sdk-core/stubbing/protocols/rest.rb +67 -0
- data/lib/aws-sdk-core/stubbing/protocols/rest_json.rb +25 -0
- data/lib/aws-sdk-core/stubbing/protocols/rest_xml.rb +38 -0
- data/lib/aws-sdk-core/stubbing/stub_data.rb +34 -0
- data/lib/aws-sdk-core/version.rb +1 -1
- data/lib/aws-sdk-core/xml/builder.rb +58 -52
- data/lib/aws-sdk-core/xml/default_map.rb +10 -0
- data/lib/aws-sdk-core/xml/doc_builder.rb +86 -0
- data/lib/aws-sdk-core/xml/error_handler.rb +7 -2
- data/lib/aws-sdk-core/xml/parser.rb +4 -4
- data/lib/aws-sdk-core/xml/parser/frame.rb +75 -70
- data/lib/aws-sdk-core/xml/parser/stack.rb +4 -4
- data/lib/seahorse.rb +0 -11
- data/lib/seahorse/client/base.rb +3 -12
- data/lib/seahorse/client/http/request.rb +9 -5
- data/lib/seahorse/client/plugins/endpoint.rb +5 -56
- data/lib/seahorse/client/plugins/restful_bindings.rb +38 -31
- data/lib/seahorse/client/request_context.rb +2 -2
- data/lib/seahorse/client/response.rb +6 -5
- data/lib/seahorse/model/api.rb +18 -61
- data/lib/seahorse/model/operation.rb +24 -54
- data/lib/seahorse/model/shapes.rb +120 -364
- data/lib/seahorse/util.rb +2 -6
- metadata +56 -109
- data/apis/autoscaling/2011-01-01/docs-2.json +0 -1246
- data/apis/cloudformation/2010-05-15/docs-2.json +0 -725
- data/apis/cloudfront/2014-11-06/docs-2.json +0 -1125
- data/apis/cloudhsm/2014-05-30/docs-2.json +0 -472
- data/apis/cloudsearch/2013-01-01/docs-2.json +0 -865
- data/apis/cloudsearchdomain/2013-01-01/docs-2.json +0 -311
- data/apis/cloudtrail/2013-11-01/docs-2.json +0 -328
- data/apis/codedeploy/2014-10-06/docs-2.json +0 -1261
- data/apis/cognito-identity/2014-06-30/docs-2.json +0 -506
- data/apis/cognito-sync/2014-06-30/docs-2.json +0 -582
- data/apis/config/2014-10-17/docs-2.json +0 -513
- data/apis/config/2014-11-12/docs-2.json +0 -514
- data/apis/datapipeline/2012-10-29/docs-2.json +0 -607
- data/apis/directconnect/2012-10-25/docs-2.json +0 -494
- data/apis/ds/2015-04-16/docs-2.json +0 -753
- data/apis/dynamodb/2011-12-05/api-2.json +0 -949
- data/apis/dynamodb/2011-12-05/docs-2.json +0 -606
- data/apis/dynamodb/2011-12-05/paginators-1.json +0 -26
- data/apis/dynamodb/2011-12-05/waiters-2.json +0 -35
- data/apis/dynamodb/2012-08-10/docs-2.json +0 -977
- data/apis/ec2/2015-04-15/docs-2.json +0 -5368
- data/apis/ecs/2014-11-13/docs-2.json +0 -791
- data/apis/elasticache/2015-02-02/docs-2.json +0 -1390
- data/apis/elasticbeanstalk/2010-12-01/docs-2.json +0 -1114
- data/apis/elasticfilesystem/2015-02-01/docs-2.json +0 -414
- data/apis/elasticloadbalancing/2012-06-01/docs-2.json +0 -1078
- data/apis/elasticmapreduce/2009-03-31/docs-2.json +0 -969
- data/apis/elastictranscoder/2012-09-25/docs-2.json +0 -1152
- data/apis/email/2010-12-01/docs-2.json +0 -441
- data/apis/glacier/2012-06-01/docs-2.json +0 -575
- data/apis/iam/2010-05-08/docs-2.json +0 -2138
- data/apis/importexport/2010-06-01/docs-2.json +0 -432
- data/apis/kinesis/2013-12-02/docs-2.json +0 -424
- data/apis/kms/2014-11-01/docs-2.json +0 -628
- data/apis/lambda/2014-11-11/docs-2.json +0 -303
- data/apis/lambda/2015-03-31/docs-2.json +0 -490
- data/apis/logs/2014-03-28/docs-2.json +0 -599
- data/apis/machinelearning/2014-12-12/docs-2.json +0 -1034
- data/apis/monitoring/2010-08-01/docs-2.json +0 -514
- data/apis/opsworks/2013-02-18/docs-2.json +0 -1592
- data/apis/rds/2014-10-31/docs-2.json +0 -2074
- data/apis/redshift/2012-12-01/docs-2.json +0 -1890
- data/apis/route53/2013-04-01/docs-2.json +0 -1159
- data/apis/route53domains/2014-05-15/docs-2.json +0 -620
- data/apis/s3/2006-03-01/docs-2.json +0 -2213
- data/apis/sdb/2009-04-15/docs-2.json +0 -339
- data/apis/sns/2010-03-31/docs-2.json +0 -564
- data/apis/sqs/2012-11-05/docs-2.json +0 -503
- data/apis/ssm/2014-11-06/docs-2.json +0 -440
- data/apis/storagegateway/2013-06-30/docs-2.json +0 -1331
- data/apis/sts/2011-06-15/docs-2.json +0 -351
- data/apis/support/2013-04-15/docs-2.json +0 -680
- data/apis/swf/2012-01-25/docs-2.json +0 -1569
- data/apis/workspaces/2015-04-08/docs-2.json +0 -457
- data/lib/aws-sdk-core/api/customizer.rb +0 -75
- data/lib/aws-sdk-core/api/docstrings.rb +0 -38
- data/lib/aws-sdk-core/api/documenter.rb +0 -241
- data/lib/aws-sdk-core/api/operation_documenter.rb +0 -173
- data/lib/aws-sdk-core/api/operation_example.rb +0 -133
- data/lib/aws-sdk-core/api/service_customizations.rb +0 -140
- data/lib/aws-sdk-core/client_paging.rb +0 -31
- data/lib/aws-sdk-core/json/rest_handler.rb +0 -20
- data/lib/aws-sdk-core/json/rpc_body_handler.rb +0 -38
- data/lib/aws-sdk-core/json/rpc_headers_handler.rb +0 -34
- data/lib/aws-sdk-core/json/simple_body_handler.rb +0 -34
- data/lib/aws-sdk-core/paging/null_pager.rb +0 -20
- data/lib/aws-sdk-core/paging/null_provider.rb +0 -13
- data/lib/aws-sdk-core/paging/pager.rb +0 -70
- data/lib/aws-sdk-core/paging/provider.rb +0 -22
- data/lib/aws-sdk-core/rest_body_handler.rb +0 -111
- data/lib/aws-sdk-core/signers/handler.rb +0 -18
- data/lib/aws-sdk-core/xml/rest_handler.rb +0 -20
- data/lib/seahorse/client/param_converter.rb +0 -207
- data/lib/seahorse/client/param_validator.rb +0 -139
- data/lib/seahorse/client/plugins/json_simple.rb +0 -33
- data/lib/seahorse/client/plugins/param_conversion.rb +0 -29
- data/lib/seahorse/client/plugins/param_validation.rb +0 -30
- data/lib/seahorse/client/xml/builder.rb +0 -91
- data/lib/seahorse/model/shape_map.rb +0 -47
@@ -0,0 +1,220 @@
|
|
1
|
+
require 'erb'
|
2
|
+
|
3
|
+
module Aws
|
4
|
+
module Api
|
5
|
+
module Docs
|
6
|
+
class Builder
|
7
|
+
|
8
|
+
def self.document(svc_module)
|
9
|
+
new(svc_module).document
|
10
|
+
end
|
11
|
+
|
12
|
+
def initialize(svc_module)
|
13
|
+
@svc_module = svc_module
|
14
|
+
@svc_name = svc_module.name.split('::').last
|
15
|
+
@client_class = svc_module.const_get(:Client)
|
16
|
+
@api = @client_class.api
|
17
|
+
@full_name = @api.metadata['serviceFullName']
|
18
|
+
@error_names = @api.operations.map {|_,o| o.errors.map(&:shape).map(&:name) }
|
19
|
+
@error_names = @error_names.flatten.uniq.sort
|
20
|
+
@namespace = YARD::Registry['Aws']
|
21
|
+
end
|
22
|
+
|
23
|
+
def document
|
24
|
+
document_service
|
25
|
+
document_types
|
26
|
+
document_client
|
27
|
+
document_errors
|
28
|
+
end
|
29
|
+
|
30
|
+
private
|
31
|
+
|
32
|
+
def document_service
|
33
|
+
yard_mod = YARD::CodeObjects::ModuleObject.new(@namespace, @svc_name)
|
34
|
+
yard_mod.docstring = service_docstring
|
35
|
+
yard_mod.docstring.add_tag(YARD::Tags::Tag.new(:service, @svc_name))
|
36
|
+
@namespace = yard_mod
|
37
|
+
end
|
38
|
+
|
39
|
+
def service_docstring
|
40
|
+
path = "doc-src/services/#{@svc_name}/service.md"
|
41
|
+
path = 'doc-src/services/default/service.md' unless File.exists?(path)
|
42
|
+
template = read(path)
|
43
|
+
svc_name = @svc_name
|
44
|
+
api = @api
|
45
|
+
full_name = @full_name
|
46
|
+
ERB.new(template).result(binding)
|
47
|
+
end
|
48
|
+
|
49
|
+
def document_errors
|
50
|
+
yard_mod = YARD::CodeObjects::ModuleObject.new(@namespace, 'Errors')
|
51
|
+
yard_mod.docstring = errors_docstring
|
52
|
+
|
53
|
+
base_error = YARD::CodeObjects::ClassObject.new(yard_mod, 'ServiceError')
|
54
|
+
base_error.docstring = "Base class for all Aws::#{@svc_name} errors."
|
55
|
+
base_error.superclass = YARD::Registry['Aws::Errors::ServiceError']
|
56
|
+
|
57
|
+
@error_names.each do |error_name|
|
58
|
+
error_klass = YARD::CodeObjects::ClassObject.new(yard_mod, error_name)
|
59
|
+
error_klass.superclass = base_error
|
60
|
+
end
|
61
|
+
end
|
62
|
+
|
63
|
+
def errors_docstring
|
64
|
+
path = "doc-src/services/#{@svc_name}/errors.md"
|
65
|
+
path = 'doc-src/services/default/errors.md' unless File.exists?(path)
|
66
|
+
template = read(path)
|
67
|
+
svc_name = @svc_name
|
68
|
+
api = @api
|
69
|
+
full_name = @full_name
|
70
|
+
known_errors = @error_names
|
71
|
+
ERB.new(template).result(binding)
|
72
|
+
end
|
73
|
+
|
74
|
+
def document_client
|
75
|
+
yard_class = YARD::CodeObjects::ClassObject.new(@namespace, 'Client')
|
76
|
+
yard_class.superclass = YARD::Registry['Seahorse::Client::Base']
|
77
|
+
yard_class.docstring = client_docstring
|
78
|
+
document_client_constructor(yard_class)
|
79
|
+
document_client_operations(yard_class)
|
80
|
+
document_client_waiters(yard_class)
|
81
|
+
end
|
82
|
+
|
83
|
+
def document_types
|
84
|
+
namespace = YARD::CodeObjects::ModuleObject.new(@namespace, 'Types')
|
85
|
+
documenter = ClientTypeDocumenter.new(namespace)
|
86
|
+
@api.metadata['shapes'].each_structure do |shape|
|
87
|
+
documenter.document(@api, shape)
|
88
|
+
end
|
89
|
+
end
|
90
|
+
|
91
|
+
def client_docstring
|
92
|
+
path = "doc-src/services/#{@svc_name}/client.md"
|
93
|
+
path = 'doc-src/services/default/client.md' unless File.exists?(path)
|
94
|
+
render(path)
|
95
|
+
end
|
96
|
+
|
97
|
+
def render(path)
|
98
|
+
svc_name = @svc_name
|
99
|
+
api = @api
|
100
|
+
full_name = @full_name
|
101
|
+
ERB.new(File.read(path)).result(binding)
|
102
|
+
end
|
103
|
+
|
104
|
+
def document_client_constructor(namespace)
|
105
|
+
constructor = YARD::CodeObjects::MethodObject.new(namespace, :initialize)
|
106
|
+
constructor.group = 'Constructor'
|
107
|
+
constructor.scope = :instance
|
108
|
+
constructor.parameters << ['options', '{}']
|
109
|
+
constructor.docstring = client_constructor_docstring
|
110
|
+
end
|
111
|
+
|
112
|
+
def client_constructor_docstring
|
113
|
+
<<-DOCS.strip
|
114
|
+
Constructs an API client.
|
115
|
+
#{client_constructor_options}
|
116
|
+
@return [#{@client_class.name}] Returns an API client.
|
117
|
+
DOCS
|
118
|
+
end
|
119
|
+
|
120
|
+
def client_constructor_options
|
121
|
+
options = {}
|
122
|
+
@client_class.plugins.each do |plugin|
|
123
|
+
if p = YARD::Registry[plugin.name]
|
124
|
+
p.tags.each do |tag|
|
125
|
+
if tag.tag_name == 'seahorse_client_option'
|
126
|
+
option_name = tag.text.match(/.+(:\w+)/)[1]
|
127
|
+
option_text = "@option options " + tag.text.split("\n").join("\n ")
|
128
|
+
options[option_name] = option_text +
|
129
|
+
" See {#{plugin.name}} for more details."
|
130
|
+
end
|
131
|
+
end
|
132
|
+
end
|
133
|
+
end
|
134
|
+
options.sort_by { |k,v| k }.map(&:last).join("\n")
|
135
|
+
end
|
136
|
+
|
137
|
+
def document_client_operations(namespace)
|
138
|
+
@api.operations.each do |method_name, operation|
|
139
|
+
document_client_operation(namespace, method_name, operation)
|
140
|
+
end
|
141
|
+
end
|
142
|
+
|
143
|
+
def document_client_operation(namespace, method_name, operation)
|
144
|
+
documenter = OperationDocumenter.new(@svc_name, namespace)
|
145
|
+
documenter.document(method_name, operation)
|
146
|
+
end
|
147
|
+
|
148
|
+
def document_client_waiters(yard_class)
|
149
|
+
m = YARD::CodeObjects::MethodObject.new(yard_class, :wait_until)
|
150
|
+
m.scope = :instance
|
151
|
+
m.parameters << ['waiter_name', nil]
|
152
|
+
m.parameters << ['params', '{}']
|
153
|
+
m.docstring = YARD::Registry['Aws::ClientWaiters#wait_until'].docstring
|
154
|
+
|
155
|
+
waiters = @client_class.waiters.waiter_names.sort.inject('') do |w,name|
|
156
|
+
waiter = @client_class.waiters.waiter(name)
|
157
|
+
operation = waiter.poller.operation_name
|
158
|
+
w << "<tr><td><tt>:#{name}</tt></td><td>{##{operation}}</td><td>#{waiter.delay}</td><td>#{waiter.max_attempts}</td></tr>"
|
159
|
+
end
|
160
|
+
docstring = <<-DOCSTRING
|
161
|
+
Returns the list of supported waiters. The following table lists the supported
|
162
|
+
waiters and the client method they call:
|
163
|
+
<table>
|
164
|
+
<thead>
|
165
|
+
<tr><th>Waiter Name</th><th>Client Method</th><th>Delay</th><th>Max Attempts</th></tr>
|
166
|
+
</thead>
|
167
|
+
<tbody>
|
168
|
+
#{waiters}
|
169
|
+
</tbody>
|
170
|
+
</table>
|
171
|
+
@return [Array<Symbol>] the list of supported waiters.
|
172
|
+
DOCSTRING
|
173
|
+
m = YARD::CodeObjects::MethodObject.new(yard_class, :waiter_names)
|
174
|
+
m.scope = :instance
|
175
|
+
m.docstring = docstring
|
176
|
+
end
|
177
|
+
|
178
|
+
class Tabulator
|
179
|
+
|
180
|
+
def initialize
|
181
|
+
@tabs = []
|
182
|
+
@tab_contents = []
|
183
|
+
end
|
184
|
+
|
185
|
+
def tab(method_name, tab_name, &block)
|
186
|
+
tab_class = tab_name.downcase.gsub(/[^a-z]+/i, '-')
|
187
|
+
tab_id = "#{method_name.to_s.gsub(/_/, '-')}-#{tab_class}"
|
188
|
+
class_names = ['tab-contents', tab_class]
|
189
|
+
@tabs << [tab_id, tab_name]
|
190
|
+
@tab_contents << "<div class=\"#{class_names.join(' ')}\" id=\"#{tab_id}\">"
|
191
|
+
@tab_contents << yield
|
192
|
+
@tab_contents << '</div>'
|
193
|
+
end
|
194
|
+
|
195
|
+
def to_html
|
196
|
+
lines = []
|
197
|
+
lines << '<div class="tab-box">'
|
198
|
+
lines << '<ul class="tabs">'
|
199
|
+
@tabs.each do |tab_id, tab_name|
|
200
|
+
lines << "<li data-tab-id=\"#{tab_id}\">#{tab_name}</li>"
|
201
|
+
end
|
202
|
+
lines << '</ul>'
|
203
|
+
lines.concat(@tab_contents)
|
204
|
+
lines << '</div>'
|
205
|
+
lines.join
|
206
|
+
end
|
207
|
+
alias inspect to_html
|
208
|
+
alias to_str to_html
|
209
|
+
alias to_s to_html
|
210
|
+
|
211
|
+
end
|
212
|
+
|
213
|
+
def read(path)
|
214
|
+
File.open(path, 'r', encoding: 'UTF-8') { |f| f.read }
|
215
|
+
end
|
216
|
+
|
217
|
+
end
|
218
|
+
end
|
219
|
+
end
|
220
|
+
end
|
@@ -0,0 +1,109 @@
|
|
1
|
+
module Aws
|
2
|
+
module Api
|
3
|
+
module Docs
|
4
|
+
class ClientTypeDocumenter
|
5
|
+
|
6
|
+
include Utils
|
7
|
+
include Seahorse::Model
|
8
|
+
include Seahorse::Model::Shapes
|
9
|
+
|
10
|
+
# @param [Yard::CodeObjects::Base] namespace
|
11
|
+
def initialize(namespace)
|
12
|
+
@namespace = namespace
|
13
|
+
end
|
14
|
+
|
15
|
+
# @param [Seahorse::Model::Api] api
|
16
|
+
# @param [Seahorse::Model::Shapes::StructureShape] shape
|
17
|
+
def document(api, shape)
|
18
|
+
yard_class = YARD::CodeObjects::ClassObject.new(@namespace, shape.name)
|
19
|
+
yard_class.superclass = 'Struct'
|
20
|
+
yard_class.docstring = docstring(api, shape)
|
21
|
+
tags(api, shape).each do |tag|
|
22
|
+
yard_class.add_tag(tag)
|
23
|
+
end
|
24
|
+
shape.members.each do |member_name, ref|
|
25
|
+
document_struct_member(yard_class, member_name, ref)
|
26
|
+
end
|
27
|
+
end
|
28
|
+
|
29
|
+
private
|
30
|
+
|
31
|
+
def docstring(api, shape)
|
32
|
+
docs = shape.documentation || ''
|
33
|
+
methods = returned_by(api, shape)
|
34
|
+
unless methods.empty?
|
35
|
+
docs += "<p>Returned by:</p>"
|
36
|
+
docs += "<ul>"
|
37
|
+
docs += methods.map{|m| "<li>{#{m}}</li>" }.join
|
38
|
+
docs += "</ul>"
|
39
|
+
end
|
40
|
+
docs
|
41
|
+
end
|
42
|
+
|
43
|
+
def tags(api, shape)
|
44
|
+
tags = []
|
45
|
+
tags << input_example_tag(api, shape) if input_shape?(api, shape)
|
46
|
+
tags
|
47
|
+
end
|
48
|
+
|
49
|
+
# Returns `true` if the given shape is ever used as input in the api.
|
50
|
+
def input_shape?(haystack, needle, stack = [])
|
51
|
+
if stack.include?(haystack)
|
52
|
+
return false
|
53
|
+
else
|
54
|
+
stack += [haystack]
|
55
|
+
end
|
56
|
+
case haystack
|
57
|
+
when needle
|
58
|
+
return true
|
59
|
+
when Seahorse::Model::Api
|
60
|
+
haystack.operations.each do |_, operation|
|
61
|
+
if operation.input && input_shape?(operation.input.shape, needle, stack)
|
62
|
+
return true
|
63
|
+
end
|
64
|
+
end
|
65
|
+
when StructureShape
|
66
|
+
haystack.members.each do |_, member_ref|
|
67
|
+
if input_shape?(member_ref.shape, needle, stack)
|
68
|
+
return true
|
69
|
+
end
|
70
|
+
end
|
71
|
+
when ListShape
|
72
|
+
return input_shape?(haystack.member.shape, needle, stack)
|
73
|
+
when MapShape
|
74
|
+
return input_shape?(haystack.value.shape, needle, stack)
|
75
|
+
end
|
76
|
+
false
|
77
|
+
end
|
78
|
+
|
79
|
+
def input_example_tag(api, shape)
|
80
|
+
params = ParamFormatter.new(ShapeRef.new(shape: shape))
|
81
|
+
note = "@note When passing #{shape.name} as input to an #{Client} "
|
82
|
+
note << "method, you can use a\n vanilla Hash:\n\n "
|
83
|
+
note << params.format.lines.join(" ")
|
84
|
+
tag(note)
|
85
|
+
end
|
86
|
+
|
87
|
+
def returned_by(api, shape)
|
88
|
+
methods = []
|
89
|
+
|
90
|
+
api.metadata['shapes'].each_structure do |struct|
|
91
|
+
struct.members.each do |member_name, member_ref|
|
92
|
+
if member_ref.shape == shape
|
93
|
+
methods << "Types::#{struct.name}##{member_name}"
|
94
|
+
end
|
95
|
+
end
|
96
|
+
end
|
97
|
+
|
98
|
+
api.operations.each do |operation_name, operation|
|
99
|
+
if operation.output && operation.output.shape == shape
|
100
|
+
methods << "Client##{operation_name}"
|
101
|
+
end
|
102
|
+
end
|
103
|
+
methods
|
104
|
+
end
|
105
|
+
|
106
|
+
end
|
107
|
+
end
|
108
|
+
end
|
109
|
+
end
|
@@ -0,0 +1,66 @@
|
|
1
|
+
module Aws
|
2
|
+
module Api
|
3
|
+
module Docs
|
4
|
+
class DocstringProvider
|
5
|
+
|
6
|
+
def initialize(docstrings)
|
7
|
+
@docstrings = docstrings
|
8
|
+
end
|
9
|
+
|
10
|
+
# @param [String] operation_name
|
11
|
+
# @return [String,nil]
|
12
|
+
def operation_docs(operation_name)
|
13
|
+
clean(@docstrings['operations'][operation_name])
|
14
|
+
end
|
15
|
+
|
16
|
+
# @param [String] shape_name
|
17
|
+
# @return [String,nil]
|
18
|
+
def shape_docs(shape_name)
|
19
|
+
clean(shape(shape_name)['base'])
|
20
|
+
end
|
21
|
+
|
22
|
+
# @param [String] shape_name
|
23
|
+
# @param [String] target
|
24
|
+
# @return [String,nil]
|
25
|
+
def shape_ref_docs(shape_name, target)
|
26
|
+
if ref_docs = shape(shape_name)['refs'][target]
|
27
|
+
clean(ref_docs)
|
28
|
+
else
|
29
|
+
shape_docs(shape_name)
|
30
|
+
end
|
31
|
+
end
|
32
|
+
|
33
|
+
private
|
34
|
+
|
35
|
+
def shape(name)
|
36
|
+
@docstrings['shapes'][name] || { 'base' => nil, 'refs' => {} }
|
37
|
+
end
|
38
|
+
|
39
|
+
def clean(value)
|
40
|
+
if value.nil?
|
41
|
+
''
|
42
|
+
else
|
43
|
+
value.gsub(/\{(\S+)\}/, '`{\1}`').strip
|
44
|
+
end
|
45
|
+
end
|
46
|
+
|
47
|
+
end
|
48
|
+
|
49
|
+
class NullDocstringProvider
|
50
|
+
|
51
|
+
def operation_docs(operation_name)
|
52
|
+
nil
|
53
|
+
end
|
54
|
+
|
55
|
+
def shape_docs(shape_name)
|
56
|
+
nil
|
57
|
+
end
|
58
|
+
|
59
|
+
def shape_ref_docs(shape_name, target)
|
60
|
+
nil
|
61
|
+
end
|
62
|
+
|
63
|
+
end
|
64
|
+
end
|
65
|
+
end
|
66
|
+
end
|
@@ -0,0 +1,107 @@
|
|
1
|
+
module Aws
|
2
|
+
module Api
|
3
|
+
module Docs
|
4
|
+
class OperationDocumenter
|
5
|
+
|
6
|
+
include Seahorse::Model
|
7
|
+
include Utils
|
8
|
+
|
9
|
+
def initialize(service_name, namespace)
|
10
|
+
@service_name = service_name
|
11
|
+
@namespace = namespace
|
12
|
+
@optname = 'options'
|
13
|
+
end
|
14
|
+
|
15
|
+
# @param [Symbol] method_name
|
16
|
+
# @param [Seahorse::Model::Opeation] operation
|
17
|
+
def document(method_name, operation)
|
18
|
+
m = YARD::CodeObjects::MethodObject.new(@namespace, method_name)
|
19
|
+
m.group = 'API Operations'
|
20
|
+
m.scope = :instance
|
21
|
+
m.parameters << [@optname, '{}']
|
22
|
+
m.docstring = operation.documentation
|
23
|
+
tags(method_name, operation).each do |tag|
|
24
|
+
m.add_tag(tag)
|
25
|
+
end
|
26
|
+
end
|
27
|
+
|
28
|
+
private
|
29
|
+
|
30
|
+
def tags(method_name, operation)
|
31
|
+
tags = []
|
32
|
+
tags += param_tags(method_name, operation)
|
33
|
+
tags += option_tags(method_name, operation)
|
34
|
+
tags += return_tags(method_name, operation)
|
35
|
+
tags += example_tags(method_name, operation)
|
36
|
+
tags += see_also_tags(method_name, operation)
|
37
|
+
end
|
38
|
+
|
39
|
+
def param_tags(method_name, operation)
|
40
|
+
[]
|
41
|
+
end
|
42
|
+
|
43
|
+
def option_tags(method_name, operation)
|
44
|
+
operation_input_ref(operation).shape.members.map do |name, ref|
|
45
|
+
req = ref.required ? 'required,' : ''
|
46
|
+
type = input_type(ref)
|
47
|
+
tag("@option #{@optname} [#{req}#{type}] :#{name} #{ref.documentation}")
|
48
|
+
end
|
49
|
+
end
|
50
|
+
|
51
|
+
def return_tags(method_name, operation)
|
52
|
+
resp = '{Seahorse::Client::Response response}'
|
53
|
+
if operation.output && operation.output.shape.members.count > 0
|
54
|
+
rtype = output_type(operation.output)
|
55
|
+
returns = "[#{rtype}] Returns a #{resp} object which responds to "
|
56
|
+
returns << "the following methods:\n\n"
|
57
|
+
operation.output.shape.members.each do |mname, mref|
|
58
|
+
returns << " * {#{rtype}##{mname} ##{mname}} => #{output_type(mref, true)}\n"
|
59
|
+
end
|
60
|
+
else
|
61
|
+
returns = "[Struct] Returns an empty #{resp}."
|
62
|
+
end
|
63
|
+
[tag("@return #{returns}")]
|
64
|
+
end
|
65
|
+
|
66
|
+
def example_tags(method_name, operation)
|
67
|
+
examples_from_disk(method_name, operation) + [
|
68
|
+
request_syntax_example(method_name, operation),
|
69
|
+
response_structure_example(method_name, operation),
|
70
|
+
].compact
|
71
|
+
end
|
72
|
+
|
73
|
+
def examples_from_disk(method_name, operation)
|
74
|
+
dir = "examples/#{@service_name.downcase}/client/#{method_name}/*.md"
|
75
|
+
Dir.glob(dir).map do |path|
|
76
|
+
title = File.basename(path).split(/\./).first
|
77
|
+
title = title.sub(/^\d+_/, '').gsub(/_/, ' ')
|
78
|
+
title = title[0].upcase + title[1..-1]
|
79
|
+
tag("@example #{title}\n\n " + File.read(path).lines.join(' '))
|
80
|
+
end
|
81
|
+
end
|
82
|
+
|
83
|
+
def request_syntax_example(method_name, operation)
|
84
|
+
example = RequestSyntaxExample.new(method_name, operation).to_str
|
85
|
+
parts = []
|
86
|
+
parts << "@example Request syntax with placeholder values\n\n"
|
87
|
+
parts += example.lines.map { |line| " " + line }
|
88
|
+
tag(parts.join)
|
89
|
+
end
|
90
|
+
|
91
|
+
def response_structure_example(method_name, operation)
|
92
|
+
if example = ResponseStructureExample.new(method_name, operation).to_str
|
93
|
+
parts = []
|
94
|
+
parts << "@example Response structure\n\n"
|
95
|
+
parts += example.lines.map { |line| " " + line }
|
96
|
+
tag(parts.join)
|
97
|
+
end
|
98
|
+
end
|
99
|
+
|
100
|
+
def see_also_tags(method_name, operation)
|
101
|
+
[]
|
102
|
+
end
|
103
|
+
|
104
|
+
end
|
105
|
+
end
|
106
|
+
end
|
107
|
+
end
|