moesif_rack 2.2.2 → 2.2.3

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 CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: d22e96756a6c9b59c31a4615d96968dd2ab335540396a65389ddda9d8604b8b2
4
- data.tar.gz: 40e942e0599207bb00917b0894f09f3cd42260bbf1bf3fa8e50c54abde0b57c3
3
+ metadata.gz: 4d071d1417f743a04c59a0c76348c72c71785e7be66643f9249598cd499ecda4
4
+ data.tar.gz: '090c2af91b03e6ba513008de2996e4097ed769b9239ae06cf1449d6feec206d0'
5
5
  SHA512:
6
- metadata.gz: 8fcff7759ab68baa2d7fad3c41e34816da6fb401106ade305e199347293971d52a9be62d52114915e318e46a945060608345bfa85619a1f364680af7211bef4d
7
- data.tar.gz: f4740cb9b0181e73884d250b6c16bcdc9223366af390ebfb399e6731c4528a8c5d20ddb04c582234d0c7e763d58991c146d6cbf4da5ebe45d8a9ef69b303cd31
6
+ metadata.gz: b883d1aca510cd2f3255f4e38e31e2ed057fd4090b214ab5dcedb5f6abd9a2d169e0257bb547ad82ce966737923346ee7bef446eb0a4b7716774ed5bf067ffa3
7
+ data.tar.gz: 0b1d306b76342ec2e09fd2739806f0346f82e6c75c87a77cfaf6bb7fc641a95c6ca792ac50becb3728d5d78ca51f52726d676038c22791729f2dcd9a564f88d1
@@ -18,7 +18,7 @@ module MoesifRack
18
18
  @app = app
19
19
  raise 'application_id required for Moesif Middleware' unless options['application_id']
20
20
 
21
- @api_client = MoesifApi::MoesifAPIClient.new(options['application_id'], 'moesif-rack/2.2.2')
21
+ @api_client = MoesifApi::MoesifAPIClient.new(options['application_id'], 'moesif-rack/2.2.3')
22
22
  @api_controller = @api_client.api
23
23
 
24
24
  @api_version = options['api_version']
@@ -4,6 +4,25 @@ module Net
4
4
  class HTTP
5
5
  alias orig_request request unless method_defined?(:orig_request)
6
6
 
7
+ def extract_body_from_body_stream(body_stream)
8
+ begin
9
+ result = nil
10
+ if body_stream.respond_to?(:rewind) and body_stream.respond_to?(:read)
11
+ result = body_stream.read
12
+ body_stream.rewind
13
+ elsif body_stream.respond_to?(:to_s)
14
+ result = body_stream.to_s
15
+ if body_stream.respond_to?(:seek)
16
+ # if stream respond to seek let's reset seek to 0
17
+ body_stream.seek(0)
18
+ end
19
+ end
20
+ result
21
+ rescue StandardError => e
22
+ return nil
23
+ end
24
+ end
25
+
7
26
  def request(request, body = nil, &block)
8
27
  # Request Start Time
9
28
  request_time = Time.now.utc.iso8601(3)
@@ -11,8 +30,7 @@ module Net
11
30
  url = "https://#{@address}#{request.path}"
12
31
 
13
32
  if (not request.body_stream.nil?) && MoesifCaptureOutgoing.should_capture_body
14
- req_body_from_stream = request.body_stream.read
15
- request.body_stream.rewind
33
+ req_body_from_stream = extract_body_from_body_stream(request.body_stream)
16
34
  end
17
35
 
18
36
  # Response
@@ -61,7 +61,15 @@ module MoesifCaptureOutgoing
61
61
  req_content_type = req_headers['content-type'].nil? ? req_headers['Content-Type'] : req_headers['content-type']
62
62
 
63
63
  # Request Body
64
- req_body_string = request.body.nil? || request.body.empty? ? body_from_req_call : request.body
64
+ req_body_string = nil
65
+ if not (request.body.nil? || request.body.empty?)
66
+ req_body_string = request.body;
67
+ elsif not body_from_req_call.nil?
68
+ req_body_string = body_from_req_call
69
+ elsif req_body_from_stream.is_a? String
70
+ req_body_string = req_body_from_stream
71
+ end
72
+
65
73
  req_body_transfer_encoding = nil
66
74
  req_body = nil
67
75
 
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: moesif_rack
3
3
  version: !ruby/object:Gem::Version
4
- version: 2.2.2
4
+ version: 2.2.3
5
5
  platform: ruby
6
6
  authors:
7
7
  - Moesif, Inc
@@ -9,7 +9,7 @@ authors:
9
9
  autorequire:
10
10
  bindir: bin
11
11
  cert_chain: []
12
- date: 2023-11-15 00:00:00.000000000 Z
12
+ date: 2024-01-29 00:00:00.000000000 Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: test-unit