opentelemetry-instrumentation-aws_lambda 0.2.0 → 0.4.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/CHANGELOG.md +11 -0
- data/README.md +26 -0
- data/lib/opentelemetry/instrumentation/aws_lambda/handler.rb +4 -131
- data/lib/opentelemetry/instrumentation/aws_lambda/instrumentation.rb +1 -0
- data/lib/opentelemetry/instrumentation/aws_lambda/version.rb +1 -1
- data/lib/opentelemetry/instrumentation/aws_lambda/wrap.rb +171 -0
- metadata +5 -186
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: f77689e0ce528810a607fdc4ade6ebd44f85998ab46a5a02ba1a433b464407c6
|
4
|
+
data.tar.gz: db18e6d64bf3d89d91db3c083cea7d6796f5b40653e3c56094e0d1ff12278a03
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 824243ae00dc887e454c7db56c3c1555701c84029426dfa8c9624cc9ad4da569ffbd5fbc808f577325d5bcb1cc7aff13038eaec130834107e3cd81f59077d0c8
|
7
|
+
data.tar.gz: bba914a8c1433299f81d52cbaa7f71a26d5b6c3eaf85a5781dad25cafd3574d1b71b5fb1cd4d6f3496a99c2d7c40768315429d65b669b0bbc58869db27fceb77
|
data/CHANGELOG.md
CHANGED
@@ -1,5 +1,16 @@
|
|
1
1
|
# Release History: opentelemetry-instrumentation-aws_lambda
|
2
2
|
|
3
|
+
### v0.4.0 / 2025-09-18
|
4
|
+
|
5
|
+
* BREAKING CHANGE: Check if span has the attributes method to avoid internal error
|
6
|
+
|
7
|
+
* FIXED: Check if span has the attributes method to avoid internal error
|
8
|
+
|
9
|
+
### v0.3.0 / 2025-02-04
|
10
|
+
|
11
|
+
* ADDED: AWS Lambda programmatic wrap
|
12
|
+
* FIXED: AWS Lambda test fix
|
13
|
+
|
3
14
|
### v0.2.0 / 2025-01-16
|
4
15
|
|
5
16
|
* BREAKING CHANGE: Set minimum supported version to Ruby 3.1
|
data/README.md
CHANGED
@@ -28,6 +28,32 @@ def otel_wrapper(event:, context:)
|
|
28
28
|
end
|
29
29
|
```
|
30
30
|
|
31
|
+
### Alternative Usage
|
32
|
+
|
33
|
+
If using a Lambda Layer is not an option for your given setup, you can programmatically instrument a handler by using the `OpenTelemetry::Instrumentation::AwsLambda::Wrap` module.
|
34
|
+
|
35
|
+
```ruby
|
36
|
+
require 'opentelemetry/sdk'
|
37
|
+
require 'opentelemetry/instrumentation/aws_lambda'
|
38
|
+
|
39
|
+
OpenTelemetry::SDK.configure do |c|
|
40
|
+
c.service_name = '<YOUR_SERVICE_NAME>'
|
41
|
+
c.use 'OpenTelemetry::Instrumentation::AwsLambda'
|
42
|
+
end
|
43
|
+
|
44
|
+
# Lambda Handler
|
45
|
+
module Example
|
46
|
+
class Handler
|
47
|
+
extend OpenTelemetry::Instrumentation::AwsLambda::Wrap
|
48
|
+
|
49
|
+
def self.process(event:, context:)
|
50
|
+
puts event.inspect
|
51
|
+
end
|
52
|
+
instrument_handler :process
|
53
|
+
end
|
54
|
+
end
|
55
|
+
```
|
56
|
+
|
31
57
|
## Example
|
32
58
|
|
33
59
|
To run the example:
|
@@ -7,10 +7,10 @@
|
|
7
7
|
module OpenTelemetry
|
8
8
|
module Instrumentation
|
9
9
|
module AwsLambda
|
10
|
-
AWS_TRIGGERS = ['aws:sqs', 'aws:s3', 'aws:sns', 'aws:dynamodb'].freeze
|
11
|
-
|
12
10
|
# Handler class that creates a span around the _HANDLER
|
13
11
|
class Handler
|
12
|
+
extend OpenTelemetry::Instrumentation::AwsLambda::Wrap
|
13
|
+
|
14
14
|
attr_reader :handler_method, :handler_class
|
15
15
|
|
16
16
|
# anytime when the code in a Lambda function is updated or the functional configuration is changed,
|
@@ -28,47 +28,9 @@ module OpenTelemetry
|
|
28
28
|
# Try to record and re-raise any exception from the wrapped function handler
|
29
29
|
# Instrumentation should never raise its own exception
|
30
30
|
def call_wrapped(event:, context:)
|
31
|
-
|
32
|
-
|
33
|
-
span_kind = if event['Records'] && AWS_TRIGGERS.include?(event['Records'].dig(0, 'eventSource'))
|
34
|
-
:consumer
|
35
|
-
else
|
36
|
-
:server
|
37
|
-
end
|
38
|
-
|
39
|
-
original_handler_error = nil
|
40
|
-
original_response = nil
|
41
|
-
OpenTelemetry::Context.with_current(parent_context) do
|
42
|
-
tracer.in_span(@original_handler, attributes: otel_attributes(event, context), kind: span_kind) do |span|
|
43
|
-
begin
|
44
|
-
response = call_original_handler(event: event, context: context)
|
45
|
-
status_code = response['statusCode'] || response[:statusCode] if response.is_a?(Hash)
|
46
|
-
span.set_attribute(OpenTelemetry::SemanticConventions::Trace::HTTP_STATUS_CODE, status_code) if status_code
|
47
|
-
rescue StandardError => e
|
48
|
-
original_handler_error = e
|
49
|
-
ensure
|
50
|
-
original_response = response
|
51
|
-
end
|
52
|
-
if original_handler_error
|
53
|
-
span.record_exception(original_handler_error)
|
54
|
-
span.status = OpenTelemetry::Trace::Status.error(original_handler_error.message)
|
55
|
-
end
|
56
|
-
end
|
31
|
+
self.class.wrap_lambda(event: event, context: context, handler: @original_handler, flush_timeout: @flush_timeout) do
|
32
|
+
call_original_handler(event: event, context: context)
|
57
33
|
end
|
58
|
-
|
59
|
-
OpenTelemetry.tracer_provider.force_flush(timeout: @flush_timeout)
|
60
|
-
|
61
|
-
raise original_handler_error if original_handler_error
|
62
|
-
|
63
|
-
original_response
|
64
|
-
end
|
65
|
-
|
66
|
-
def instrumentation_config
|
67
|
-
AwsLambda::Instrumentation.instance.config
|
68
|
-
end
|
69
|
-
|
70
|
-
def tracer
|
71
|
-
AwsLambda::Instrumentation.instance.tracer
|
72
34
|
end
|
73
35
|
|
74
36
|
private
|
@@ -94,95 +56,6 @@ module OpenTelemetry
|
|
94
56
|
__send__(@handler_method, event: event, context: context)
|
95
57
|
end
|
96
58
|
end
|
97
|
-
|
98
|
-
# Extract parent context from request headers
|
99
|
-
# Downcase Traceparent and Tracestate because TraceContext::TextMapPropagator's TRACEPARENT_KEY and TRACESTATE_KEY are all lowercase
|
100
|
-
# If any error occur, rescue and give empty context
|
101
|
-
def extract_parent_context(event)
|
102
|
-
headers = event['headers'] || {}
|
103
|
-
headers.transform_keys! do |key|
|
104
|
-
%w[Traceparent Tracestate].include?(key) ? key.downcase : key
|
105
|
-
end
|
106
|
-
|
107
|
-
OpenTelemetry.propagation.extract(
|
108
|
-
headers,
|
109
|
-
getter: OpenTelemetry::Context::Propagation.text_map_getter
|
110
|
-
)
|
111
|
-
rescue StandardError => e
|
112
|
-
OpenTelemetry.logger.error("aws-lambda instrumentation exception occurred while extracting the parent context: #{e.message}")
|
113
|
-
OpenTelemetry::Context.empty
|
114
|
-
end
|
115
|
-
|
116
|
-
# lambda event version 1.0 and version 2.0
|
117
|
-
# https://docs.aws.amazon.com/apigateway/latest/developerguide/http-api-develop-integrations-lambda.html
|
118
|
-
def v1_proxy_attributes(event)
|
119
|
-
attributes = {
|
120
|
-
OpenTelemetry::SemanticConventions::Trace::HTTP_METHOD => event['httpMethod'],
|
121
|
-
OpenTelemetry::SemanticConventions::Trace::HTTP_ROUTE => event['resource'],
|
122
|
-
OpenTelemetry::SemanticConventions::Trace::HTTP_TARGET => event['resource']
|
123
|
-
}
|
124
|
-
attributes[OpenTelemetry::SemanticConventions::Trace::HTTP_TARGET] += "?#{event['queryStringParameters']}" if event['queryStringParameters']
|
125
|
-
|
126
|
-
headers = event['headers']
|
127
|
-
if headers
|
128
|
-
attributes[OpenTelemetry::SemanticConventions::Trace::HTTP_USER_AGENT] = headers['User-Agent']
|
129
|
-
attributes[OpenTelemetry::SemanticConventions::Trace::HTTP_SCHEME] = headers['X-Forwarded-Proto']
|
130
|
-
attributes[OpenTelemetry::SemanticConventions::Trace::NET_HOST_NAME] = headers['Host']
|
131
|
-
end
|
132
|
-
attributes
|
133
|
-
end
|
134
|
-
|
135
|
-
def v2_proxy_attributes(event)
|
136
|
-
request_context = event['requestContext']
|
137
|
-
attributes = {
|
138
|
-
OpenTelemetry::SemanticConventions::Trace::NET_HOST_NAME => request_context['domainName'],
|
139
|
-
OpenTelemetry::SemanticConventions::Trace::HTTP_METHOD => request_context['http']['method'],
|
140
|
-
OpenTelemetry::SemanticConventions::Trace::HTTP_USER_AGENT => request_context['http']['userAgent'],
|
141
|
-
OpenTelemetry::SemanticConventions::Trace::HTTP_ROUTE => request_context['http']['path'],
|
142
|
-
OpenTelemetry::SemanticConventions::Trace::HTTP_TARGET => request_context['http']['path']
|
143
|
-
}
|
144
|
-
attributes[OpenTelemetry::SemanticConventions::Trace::HTTP_TARGET] += "?#{event['rawQueryString']}" if event['rawQueryString']
|
145
|
-
attributes
|
146
|
-
end
|
147
|
-
|
148
|
-
# fass.trigger set to http: https://github.com/open-telemetry/semantic-conventions/blob/main/docs/faas/aws-lambda.md#api-gateway
|
149
|
-
# TODO: need to update Semantic Conventions for invocation_id, trigger and resource_id
|
150
|
-
def otel_attributes(event, context)
|
151
|
-
span_attributes = {}
|
152
|
-
span_attributes['faas.invocation_id'] = context.aws_request_id
|
153
|
-
span_attributes['cloud.resource_id'] = context.invoked_function_arn
|
154
|
-
span_attributes[OpenTelemetry::SemanticConventions::Trace::AWS_LAMBDA_INVOKED_ARN] = context.invoked_function_arn
|
155
|
-
span_attributes[OpenTelemetry::SemanticConventions::Resource::CLOUD_ACCOUNT_ID] = context.invoked_function_arn.split(':')[4]
|
156
|
-
|
157
|
-
if event['requestContext']
|
158
|
-
request_attributes = event['version'] == '2.0' ? v2_proxy_attributes(event) : v1_proxy_attributes(event)
|
159
|
-
request_attributes[OpenTelemetry::SemanticConventions::Trace::FAAS_TRIGGER] = 'http'
|
160
|
-
span_attributes.merge!(request_attributes)
|
161
|
-
end
|
162
|
-
|
163
|
-
if event['Records']
|
164
|
-
trigger_attributes = trigger_type_attributes(event)
|
165
|
-
span_attributes.merge!(trigger_attributes)
|
166
|
-
end
|
167
|
-
|
168
|
-
span_attributes
|
169
|
-
rescue StandardError => e
|
170
|
-
OpenTelemetry.logger.error("aws-lambda instrumentation exception occurred while preparing span attributes: #{e.message}")
|
171
|
-
{}
|
172
|
-
end
|
173
|
-
|
174
|
-
# sqs spec for lambda: https://github.com/open-telemetry/semantic-conventions/blob/main/docs/faas/aws-lambda.md#sqs
|
175
|
-
# current there is no spec for 'aws:sns', 'aws:s3' and 'aws:dynamodb'
|
176
|
-
def trigger_type_attributes(event)
|
177
|
-
attributes = {}
|
178
|
-
case event['Records'].dig(0, 'eventSource')
|
179
|
-
when 'aws:sqs'
|
180
|
-
attributes[OpenTelemetry::SemanticConventions::Trace::FAAS_TRIGGER] = 'pubsub'
|
181
|
-
attributes[OpenTelemetry::SemanticConventions::Trace::MESSAGING_OPERATION] = 'process'
|
182
|
-
attributes[OpenTelemetry::SemanticConventions::Trace::MESSAGING_SYSTEM] = 'AmazonSQS'
|
183
|
-
end
|
184
|
-
attributes
|
185
|
-
end
|
186
59
|
end
|
187
60
|
end
|
188
61
|
end
|
@@ -0,0 +1,171 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
# Copyright The OpenTelemetry Authors
|
4
|
+
#
|
5
|
+
# SPDX-License-Identifier: Apache-2.0
|
6
|
+
|
7
|
+
module OpenTelemetry
|
8
|
+
module Instrumentation
|
9
|
+
module AwsLambda
|
10
|
+
# Helper module that can be used to wrap a lambda handler method
|
11
|
+
module Wrap # rubocop:disable Metrics/ModuleLength
|
12
|
+
AWS_TRIGGERS = ['aws:sqs', 'aws:s3', 'aws:sns', 'aws:dynamodb'].freeze
|
13
|
+
DEFAULT_FLUSH_TIMEOUT = ENV.fetch('OTEL_INSTRUMENTATION_AWS_LAMBDA_FLUSH_TIMEOUT', '30000').to_i
|
14
|
+
|
15
|
+
def instrument_handler(method, flush_timeout: DEFAULT_FLUSH_TIMEOUT)
|
16
|
+
raise ArgumentError, "#{method} is not a method of #{name}" unless respond_to?(method)
|
17
|
+
|
18
|
+
uninstrumented_method = "#{method}_without_instrumentation"
|
19
|
+
singleton_class.alias_method uninstrumented_method, method
|
20
|
+
|
21
|
+
handler = "#{name}.#{method}"
|
22
|
+
|
23
|
+
define_singleton_method(method) do |event:, context:|
|
24
|
+
wrap_lambda(event: event, context: context, handler: handler, flush_timeout: flush_timeout) { public_send(uninstrumented_method, event: event, context: context) }
|
25
|
+
end
|
26
|
+
end
|
27
|
+
|
28
|
+
# Try to record and re-raise any exception from the wrapped function handler
|
29
|
+
# Instrumentation should never raise its own exception
|
30
|
+
def wrap_lambda(event:, context:, handler:, flush_timeout: DEFAULT_FLUSH_TIMEOUT)
|
31
|
+
parent_context = extract_parent_context(event)
|
32
|
+
|
33
|
+
span_kind = if event['Records'] && AWS_TRIGGERS.include?(event['Records'].dig(0, 'eventSource'))
|
34
|
+
:consumer
|
35
|
+
else
|
36
|
+
:server
|
37
|
+
end
|
38
|
+
|
39
|
+
original_handler_error = nil
|
40
|
+
original_response = nil
|
41
|
+
OpenTelemetry::Context.with_current(parent_context) do
|
42
|
+
tracer.in_span(handler, attributes: otel_attributes(event, context), kind: span_kind) do |span|
|
43
|
+
begin
|
44
|
+
response = yield
|
45
|
+
|
46
|
+
if span.recording? && !span.attributes.key?(OpenTelemetry::SemanticConventions::Trace::HTTP_STATUS_CODE)
|
47
|
+
status_code = response['statusCode'] || response[:statusCode] if response.is_a?(Hash)
|
48
|
+
span.set_attribute(OpenTelemetry::SemanticConventions::Trace::HTTP_STATUS_CODE, status_code) if status_code
|
49
|
+
end
|
50
|
+
rescue StandardError => e
|
51
|
+
original_handler_error = e
|
52
|
+
ensure
|
53
|
+
original_response = response
|
54
|
+
end
|
55
|
+
if original_handler_error
|
56
|
+
span.record_exception(original_handler_error)
|
57
|
+
span.status = OpenTelemetry::Trace::Status.error(original_handler_error.message)
|
58
|
+
end
|
59
|
+
end
|
60
|
+
end
|
61
|
+
|
62
|
+
OpenTelemetry.tracer_provider.force_flush(timeout: flush_timeout)
|
63
|
+
OpenTelemetry.meter_provider.force_flush(timeout: flush_timeout) if OpenTelemetry.respond_to?(:meter_provider)
|
64
|
+
|
65
|
+
raise original_handler_error if original_handler_error
|
66
|
+
|
67
|
+
original_response
|
68
|
+
end
|
69
|
+
|
70
|
+
def instrumentation_config
|
71
|
+
AwsLambda::Instrumentation.instance.config
|
72
|
+
end
|
73
|
+
|
74
|
+
def tracer
|
75
|
+
AwsLambda::Instrumentation.instance.tracer
|
76
|
+
end
|
77
|
+
|
78
|
+
private
|
79
|
+
|
80
|
+
# Extract parent context from request headers
|
81
|
+
# Downcase Traceparent and Tracestate because TraceContext::TextMapPropagator's TRACEPARENT_KEY and TRACESTATE_KEY are all lowercase
|
82
|
+
# If any error occur, rescue and give empty context
|
83
|
+
def extract_parent_context(event)
|
84
|
+
headers = event['headers'] || {}
|
85
|
+
headers.transform_keys! do |key|
|
86
|
+
%w[Traceparent Tracestate].include?(key) ? key.downcase : key
|
87
|
+
end
|
88
|
+
|
89
|
+
OpenTelemetry.propagation.extract(
|
90
|
+
headers,
|
91
|
+
getter: OpenTelemetry::Context::Propagation.text_map_getter
|
92
|
+
)
|
93
|
+
rescue StandardError => e
|
94
|
+
OpenTelemetry.logger.error("aws-lambda instrumentation exception occurred while extracting the parent context: #{e.message}")
|
95
|
+
OpenTelemetry::Context.empty
|
96
|
+
end
|
97
|
+
|
98
|
+
# lambda event version 1.0 and version 2.0
|
99
|
+
# https://docs.aws.amazon.com/apigateway/latest/developerguide/http-api-develop-integrations-lambda.html
|
100
|
+
def v1_proxy_attributes(event)
|
101
|
+
attributes = {
|
102
|
+
OpenTelemetry::SemanticConventions::Trace::HTTP_METHOD => event['httpMethod'],
|
103
|
+
OpenTelemetry::SemanticConventions::Trace::HTTP_ROUTE => event['resource'],
|
104
|
+
OpenTelemetry::SemanticConventions::Trace::HTTP_TARGET => event['resource']
|
105
|
+
}
|
106
|
+
attributes[OpenTelemetry::SemanticConventions::Trace::HTTP_TARGET] += "?#{event['queryStringParameters']}" if event['queryStringParameters']
|
107
|
+
|
108
|
+
headers = event['headers']
|
109
|
+
if headers
|
110
|
+
attributes[OpenTelemetry::SemanticConventions::Trace::HTTP_USER_AGENT] = headers['User-Agent']
|
111
|
+
attributes[OpenTelemetry::SemanticConventions::Trace::HTTP_SCHEME] = headers['X-Forwarded-Proto']
|
112
|
+
attributes[OpenTelemetry::SemanticConventions::Trace::NET_HOST_NAME] = headers['Host']
|
113
|
+
end
|
114
|
+
attributes
|
115
|
+
end
|
116
|
+
|
117
|
+
def v2_proxy_attributes(event)
|
118
|
+
request_context = event['requestContext']
|
119
|
+
attributes = {
|
120
|
+
OpenTelemetry::SemanticConventions::Trace::NET_HOST_NAME => request_context['domainName'],
|
121
|
+
OpenTelemetry::SemanticConventions::Trace::HTTP_METHOD => request_context['http']['method'],
|
122
|
+
OpenTelemetry::SemanticConventions::Trace::HTTP_USER_AGENT => request_context['http']['userAgent'],
|
123
|
+
OpenTelemetry::SemanticConventions::Trace::HTTP_ROUTE => request_context['http']['path'],
|
124
|
+
OpenTelemetry::SemanticConventions::Trace::HTTP_TARGET => request_context['http']['path']
|
125
|
+
}
|
126
|
+
attributes[OpenTelemetry::SemanticConventions::Trace::HTTP_TARGET] += "?#{event['rawQueryString']}" if event['rawQueryString']
|
127
|
+
attributes
|
128
|
+
end
|
129
|
+
|
130
|
+
# fass.trigger set to http: https://github.com/open-telemetry/semantic-conventions/blob/main/docs/faas/aws-lambda.md#api-gateway
|
131
|
+
# TODO: need to update Semantic Conventions for invocation_id, trigger and resource_id
|
132
|
+
def otel_attributes(event, context)
|
133
|
+
span_attributes = {}
|
134
|
+
span_attributes['faas.invocation_id'] = context.aws_request_id
|
135
|
+
span_attributes['cloud.resource_id'] = context.invoked_function_arn
|
136
|
+
span_attributes[OpenTelemetry::SemanticConventions::Trace::AWS_LAMBDA_INVOKED_ARN] = context.invoked_function_arn
|
137
|
+
span_attributes[OpenTelemetry::SemanticConventions::Resource::CLOUD_ACCOUNT_ID] = context.invoked_function_arn.split(':')[4]
|
138
|
+
|
139
|
+
if event['requestContext']
|
140
|
+
request_attributes = event['version'] == '2.0' ? v2_proxy_attributes(event) : v1_proxy_attributes(event)
|
141
|
+
request_attributes[OpenTelemetry::SemanticConventions::Trace::FAAS_TRIGGER] = 'http'
|
142
|
+
span_attributes.merge!(request_attributes)
|
143
|
+
end
|
144
|
+
|
145
|
+
if event['Records']
|
146
|
+
trigger_attributes = trigger_type_attributes(event)
|
147
|
+
span_attributes.merge!(trigger_attributes)
|
148
|
+
end
|
149
|
+
|
150
|
+
span_attributes
|
151
|
+
rescue StandardError => e
|
152
|
+
OpenTelemetry.logger.error("aws-lambda instrumentation exception occurred while preparing span attributes: #{e.message}")
|
153
|
+
{}
|
154
|
+
end
|
155
|
+
|
156
|
+
# sqs spec for lambda: https://github.com/open-telemetry/semantic-conventions/blob/main/docs/faas/aws-lambda.md#sqs
|
157
|
+
# current there is no spec for 'aws:sns', 'aws:s3' and 'aws:dynamodb'
|
158
|
+
def trigger_type_attributes(event)
|
159
|
+
attributes = {}
|
160
|
+
case event['Records'].dig(0, 'eventSource')
|
161
|
+
when 'aws:sqs'
|
162
|
+
attributes[OpenTelemetry::SemanticConventions::Trace::FAAS_TRIGGER] = 'pubsub'
|
163
|
+
attributes[OpenTelemetry::SemanticConventions::Trace::MESSAGING_OPERATION] = 'process'
|
164
|
+
attributes[OpenTelemetry::SemanticConventions::Trace::MESSAGING_SYSTEM] = 'AmazonSQS'
|
165
|
+
end
|
166
|
+
attributes
|
167
|
+
end
|
168
|
+
end
|
169
|
+
end
|
170
|
+
end
|
171
|
+
end
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: opentelemetry-instrumentation-aws_lambda
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.
|
4
|
+
version: 0.4.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- OpenTelemetry Authors
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2025-
|
11
|
+
date: 2025-09-18 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: opentelemetry-api
|
@@ -38,188 +38,6 @@ dependencies:
|
|
38
38
|
- - "~>"
|
39
39
|
- !ruby/object:Gem::Version
|
40
40
|
version: 0.23.0
|
41
|
-
- !ruby/object:Gem::Dependency
|
42
|
-
name: appraisal
|
43
|
-
requirement: !ruby/object:Gem::Requirement
|
44
|
-
requirements:
|
45
|
-
- - "~>"
|
46
|
-
- !ruby/object:Gem::Version
|
47
|
-
version: '2.5'
|
48
|
-
type: :development
|
49
|
-
prerelease: false
|
50
|
-
version_requirements: !ruby/object:Gem::Requirement
|
51
|
-
requirements:
|
52
|
-
- - "~>"
|
53
|
-
- !ruby/object:Gem::Version
|
54
|
-
version: '2.5'
|
55
|
-
- !ruby/object:Gem::Dependency
|
56
|
-
name: bundler
|
57
|
-
requirement: !ruby/object:Gem::Requirement
|
58
|
-
requirements:
|
59
|
-
- - "~>"
|
60
|
-
- !ruby/object:Gem::Version
|
61
|
-
version: '2.4'
|
62
|
-
type: :development
|
63
|
-
prerelease: false
|
64
|
-
version_requirements: !ruby/object:Gem::Requirement
|
65
|
-
requirements:
|
66
|
-
- - "~>"
|
67
|
-
- !ruby/object:Gem::Version
|
68
|
-
version: '2.4'
|
69
|
-
- !ruby/object:Gem::Dependency
|
70
|
-
name: minitest
|
71
|
-
requirement: !ruby/object:Gem::Requirement
|
72
|
-
requirements:
|
73
|
-
- - "~>"
|
74
|
-
- !ruby/object:Gem::Version
|
75
|
-
version: '5.0'
|
76
|
-
type: :development
|
77
|
-
prerelease: false
|
78
|
-
version_requirements: !ruby/object:Gem::Requirement
|
79
|
-
requirements:
|
80
|
-
- - "~>"
|
81
|
-
- !ruby/object:Gem::Version
|
82
|
-
version: '5.0'
|
83
|
-
- !ruby/object:Gem::Dependency
|
84
|
-
name: opentelemetry-sdk
|
85
|
-
requirement: !ruby/object:Gem::Requirement
|
86
|
-
requirements:
|
87
|
-
- - "~>"
|
88
|
-
- !ruby/object:Gem::Version
|
89
|
-
version: '1.1'
|
90
|
-
type: :development
|
91
|
-
prerelease: false
|
92
|
-
version_requirements: !ruby/object:Gem::Requirement
|
93
|
-
requirements:
|
94
|
-
- - "~>"
|
95
|
-
- !ruby/object:Gem::Version
|
96
|
-
version: '1.1'
|
97
|
-
- !ruby/object:Gem::Dependency
|
98
|
-
name: opentelemetry-test-helpers
|
99
|
-
requirement: !ruby/object:Gem::Requirement
|
100
|
-
requirements:
|
101
|
-
- - "~>"
|
102
|
-
- !ruby/object:Gem::Version
|
103
|
-
version: '0.3'
|
104
|
-
type: :development
|
105
|
-
prerelease: false
|
106
|
-
version_requirements: !ruby/object:Gem::Requirement
|
107
|
-
requirements:
|
108
|
-
- - "~>"
|
109
|
-
- !ruby/object:Gem::Version
|
110
|
-
version: '0.3'
|
111
|
-
- !ruby/object:Gem::Dependency
|
112
|
-
name: pry
|
113
|
-
requirement: !ruby/object:Gem::Requirement
|
114
|
-
requirements:
|
115
|
-
- - ">="
|
116
|
-
- !ruby/object:Gem::Version
|
117
|
-
version: '0'
|
118
|
-
type: :development
|
119
|
-
prerelease: false
|
120
|
-
version_requirements: !ruby/object:Gem::Requirement
|
121
|
-
requirements:
|
122
|
-
- - ">="
|
123
|
-
- !ruby/object:Gem::Version
|
124
|
-
version: '0'
|
125
|
-
- !ruby/object:Gem::Dependency
|
126
|
-
name: pry-byebug
|
127
|
-
requirement: !ruby/object:Gem::Requirement
|
128
|
-
requirements:
|
129
|
-
- - ">="
|
130
|
-
- !ruby/object:Gem::Version
|
131
|
-
version: '0'
|
132
|
-
type: :development
|
133
|
-
prerelease: false
|
134
|
-
version_requirements: !ruby/object:Gem::Requirement
|
135
|
-
requirements:
|
136
|
-
- - ">="
|
137
|
-
- !ruby/object:Gem::Version
|
138
|
-
version: '0'
|
139
|
-
- !ruby/object:Gem::Dependency
|
140
|
-
name: rspec-mocks
|
141
|
-
requirement: !ruby/object:Gem::Requirement
|
142
|
-
requirements:
|
143
|
-
- - ">="
|
144
|
-
- !ruby/object:Gem::Version
|
145
|
-
version: '0'
|
146
|
-
type: :development
|
147
|
-
prerelease: false
|
148
|
-
version_requirements: !ruby/object:Gem::Requirement
|
149
|
-
requirements:
|
150
|
-
- - ">="
|
151
|
-
- !ruby/object:Gem::Version
|
152
|
-
version: '0'
|
153
|
-
- !ruby/object:Gem::Dependency
|
154
|
-
name: rubocop
|
155
|
-
requirement: !ruby/object:Gem::Requirement
|
156
|
-
requirements:
|
157
|
-
- - "~>"
|
158
|
-
- !ruby/object:Gem::Version
|
159
|
-
version: 1.69.1
|
160
|
-
type: :development
|
161
|
-
prerelease: false
|
162
|
-
version_requirements: !ruby/object:Gem::Requirement
|
163
|
-
requirements:
|
164
|
-
- - "~>"
|
165
|
-
- !ruby/object:Gem::Version
|
166
|
-
version: 1.69.1
|
167
|
-
- !ruby/object:Gem::Dependency
|
168
|
-
name: rubocop-performance
|
169
|
-
requirement: !ruby/object:Gem::Requirement
|
170
|
-
requirements:
|
171
|
-
- - "~>"
|
172
|
-
- !ruby/object:Gem::Version
|
173
|
-
version: 1.23.0
|
174
|
-
type: :development
|
175
|
-
prerelease: false
|
176
|
-
version_requirements: !ruby/object:Gem::Requirement
|
177
|
-
requirements:
|
178
|
-
- - "~>"
|
179
|
-
- !ruby/object:Gem::Version
|
180
|
-
version: 1.23.0
|
181
|
-
- !ruby/object:Gem::Dependency
|
182
|
-
name: simplecov
|
183
|
-
requirement: !ruby/object:Gem::Requirement
|
184
|
-
requirements:
|
185
|
-
- - "~>"
|
186
|
-
- !ruby/object:Gem::Version
|
187
|
-
version: 0.17.1
|
188
|
-
type: :development
|
189
|
-
prerelease: false
|
190
|
-
version_requirements: !ruby/object:Gem::Requirement
|
191
|
-
requirements:
|
192
|
-
- - "~>"
|
193
|
-
- !ruby/object:Gem::Version
|
194
|
-
version: 0.17.1
|
195
|
-
- !ruby/object:Gem::Dependency
|
196
|
-
name: webmock
|
197
|
-
requirement: !ruby/object:Gem::Requirement
|
198
|
-
requirements:
|
199
|
-
- - "~>"
|
200
|
-
- !ruby/object:Gem::Version
|
201
|
-
version: 3.24.0
|
202
|
-
type: :development
|
203
|
-
prerelease: false
|
204
|
-
version_requirements: !ruby/object:Gem::Requirement
|
205
|
-
requirements:
|
206
|
-
- - "~>"
|
207
|
-
- !ruby/object:Gem::Version
|
208
|
-
version: 3.24.0
|
209
|
-
- !ruby/object:Gem::Dependency
|
210
|
-
name: yard
|
211
|
-
requirement: !ruby/object:Gem::Requirement
|
212
|
-
requirements:
|
213
|
-
- - "~>"
|
214
|
-
- !ruby/object:Gem::Version
|
215
|
-
version: '0.9'
|
216
|
-
type: :development
|
217
|
-
prerelease: false
|
218
|
-
version_requirements: !ruby/object:Gem::Requirement
|
219
|
-
requirements:
|
220
|
-
- - "~>"
|
221
|
-
- !ruby/object:Gem::Version
|
222
|
-
version: '0.9'
|
223
41
|
description: AWS Lambda instrumentation for the OpenTelemetry framework
|
224
42
|
email:
|
225
43
|
- cncf-opentelemetry-contributors@lists.cncf.io
|
@@ -237,14 +55,15 @@ files:
|
|
237
55
|
- lib/opentelemetry/instrumentation/aws_lambda/handler.rb
|
238
56
|
- lib/opentelemetry/instrumentation/aws_lambda/instrumentation.rb
|
239
57
|
- lib/opentelemetry/instrumentation/aws_lambda/version.rb
|
58
|
+
- lib/opentelemetry/instrumentation/aws_lambda/wrap.rb
|
240
59
|
homepage: https://github.com/open-telemetry/opentelemetry-ruby-contrib
|
241
60
|
licenses:
|
242
61
|
- Apache-2.0
|
243
62
|
metadata:
|
244
|
-
changelog_uri: https://rubydoc.info/gems/opentelemetry-instrumentation-aws_lambda/0.
|
63
|
+
changelog_uri: https://rubydoc.info/gems/opentelemetry-instrumentation-aws_lambda/0.4.0/file/CHANGELOG.md
|
245
64
|
source_code_uri: https://github.com/open-telemetry/opentelemetry-ruby-contrib/tree/main/instrumentation/aws_lambda
|
246
65
|
bug_tracker_uri: https://github.com/open-telemetry/opentelemetry-ruby-contrib/issues
|
247
|
-
documentation_uri: https://rubydoc.info/gems/opentelemetry-instrumentation-aws_lambda/0.
|
66
|
+
documentation_uri: https://rubydoc.info/gems/opentelemetry-instrumentation-aws_lambda/0.4.0
|
248
67
|
post_install_message:
|
249
68
|
rdoc_options: []
|
250
69
|
require_paths:
|