aws-sdk-kinesis 1.38.0 → 1.52.0

Sign up to get free protection for your applications and to get access to all the features.
@@ -0,0 +1,126 @@
1
+ # frozen_string_literal: true
2
+
3
+ # WARNING ABOUT GENERATED CODE
4
+ #
5
+ # This file is generated. See the contributing guide for more information:
6
+ # https://github.com/aws/aws-sdk-ruby/blob/version-3/CONTRIBUTING.md
7
+ #
8
+ # WARNING ABOUT GENERATED CODE
9
+
10
+
11
+ module Aws::Kinesis
12
+ module Plugins
13
+ class Endpoints < Seahorse::Client::Plugin
14
+ option(
15
+ :endpoint_provider,
16
+ doc_type: 'Aws::Kinesis::EndpointProvider',
17
+ docstring: 'The endpoint provider used to resolve endpoints. Any '\
18
+ 'object that responds to `#resolve_endpoint(parameters)` '\
19
+ 'where `parameters` is a Struct similar to '\
20
+ '`Aws::Kinesis::EndpointParameters`'
21
+ ) do |cfg|
22
+ Aws::Kinesis::EndpointProvider.new
23
+ end
24
+
25
+ # @api private
26
+ class Handler < Seahorse::Client::Handler
27
+ def call(context)
28
+ # If endpoint was discovered, do not resolve or apply the endpoint.
29
+ unless context[:discovered_endpoint]
30
+ params = parameters_for_operation(context)
31
+ endpoint = context.config.endpoint_provider.resolve_endpoint(params)
32
+
33
+ context.http_request.endpoint = endpoint.url
34
+ apply_endpoint_headers(context, endpoint.headers)
35
+ end
36
+
37
+ context[:endpoint_params] = params
38
+ context[:auth_scheme] =
39
+ Aws::Endpoints.resolve_auth_scheme(context, endpoint)
40
+
41
+ @handler.call(context)
42
+ end
43
+
44
+ private
45
+
46
+ def apply_endpoint_headers(context, headers)
47
+ headers.each do |key, values|
48
+ value = values
49
+ .compact
50
+ .map { |s| Seahorse::Util.escape_header_list_string(s.to_s) }
51
+ .join(',')
52
+
53
+ context.http_request.headers[key] = value
54
+ end
55
+ end
56
+
57
+ def parameters_for_operation(context)
58
+ case context.operation_name
59
+ when :add_tags_to_stream
60
+ Aws::Kinesis::Endpoints::AddTagsToStream.build(context)
61
+ when :create_stream
62
+ Aws::Kinesis::Endpoints::CreateStream.build(context)
63
+ when :decrease_stream_retention_period
64
+ Aws::Kinesis::Endpoints::DecreaseStreamRetentionPeriod.build(context)
65
+ when :delete_stream
66
+ Aws::Kinesis::Endpoints::DeleteStream.build(context)
67
+ when :deregister_stream_consumer
68
+ Aws::Kinesis::Endpoints::DeregisterStreamConsumer.build(context)
69
+ when :describe_limits
70
+ Aws::Kinesis::Endpoints::DescribeLimits.build(context)
71
+ when :describe_stream
72
+ Aws::Kinesis::Endpoints::DescribeStream.build(context)
73
+ when :describe_stream_consumer
74
+ Aws::Kinesis::Endpoints::DescribeStreamConsumer.build(context)
75
+ when :describe_stream_summary
76
+ Aws::Kinesis::Endpoints::DescribeStreamSummary.build(context)
77
+ when :disable_enhanced_monitoring
78
+ Aws::Kinesis::Endpoints::DisableEnhancedMonitoring.build(context)
79
+ when :enable_enhanced_monitoring
80
+ Aws::Kinesis::Endpoints::EnableEnhancedMonitoring.build(context)
81
+ when :get_records
82
+ Aws::Kinesis::Endpoints::GetRecords.build(context)
83
+ when :get_shard_iterator
84
+ Aws::Kinesis::Endpoints::GetShardIterator.build(context)
85
+ when :increase_stream_retention_period
86
+ Aws::Kinesis::Endpoints::IncreaseStreamRetentionPeriod.build(context)
87
+ when :list_shards
88
+ Aws::Kinesis::Endpoints::ListShards.build(context)
89
+ when :list_stream_consumers
90
+ Aws::Kinesis::Endpoints::ListStreamConsumers.build(context)
91
+ when :list_streams
92
+ Aws::Kinesis::Endpoints::ListStreams.build(context)
93
+ when :list_tags_for_stream
94
+ Aws::Kinesis::Endpoints::ListTagsForStream.build(context)
95
+ when :merge_shards
96
+ Aws::Kinesis::Endpoints::MergeShards.build(context)
97
+ when :put_record
98
+ Aws::Kinesis::Endpoints::PutRecord.build(context)
99
+ when :put_records
100
+ Aws::Kinesis::Endpoints::PutRecords.build(context)
101
+ when :register_stream_consumer
102
+ Aws::Kinesis::Endpoints::RegisterStreamConsumer.build(context)
103
+ when :remove_tags_from_stream
104
+ Aws::Kinesis::Endpoints::RemoveTagsFromStream.build(context)
105
+ when :split_shard
106
+ Aws::Kinesis::Endpoints::SplitShard.build(context)
107
+ when :start_stream_encryption
108
+ Aws::Kinesis::Endpoints::StartStreamEncryption.build(context)
109
+ when :stop_stream_encryption
110
+ Aws::Kinesis::Endpoints::StopStreamEncryption.build(context)
111
+ when :subscribe_to_shard
112
+ Aws::Kinesis::Endpoints::SubscribeToShard.build(context)
113
+ when :update_shard_count
114
+ Aws::Kinesis::Endpoints::UpdateShardCount.build(context)
115
+ when :update_stream_mode
116
+ Aws::Kinesis::Endpoints::UpdateStreamMode.build(context)
117
+ end
118
+ end
119
+ end
120
+
121
+ def add_handlers(handlers, _config)
122
+ handlers.add(Handler, step: :build, priority: 75)
123
+ end
124
+ end
125
+ end
126
+ end