vigiles 0.1.0.pre.beta8 → 0.1.0.pre.beta9

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: 9ae2f2c7a8b3a0642d0fb228264821c882b9b98cf7a59380dcf139e1a514221c
4
- data.tar.gz: 7ca651c0579f55907094ade6d43825cae72627fef6c8e995fd621d7f94e9acc4
3
+ metadata.gz: 7c95b320d216c89bd72c728b2b0402cae897d984554fd6c41e66739eac544e9b
4
+ data.tar.gz: 55bd64c8191703e6d5b6aac98945c54fd9d06a65b5b094e2c338ad64c9641fb8
5
5
  SHA512:
6
- metadata.gz: a942ca1c61aefdb02f843b7d3defd046ebce9935b47d406e8193c2c54b7befd360b19f974618f24f42c23278e8c313be513d25b68fece32985d2272f504b8c2e
7
- data.tar.gz: 2a70d2be56a5c86fa4f30f881b6b9002e6967cfe6cd04339f1bb4f70f1a6f8bd28b6ae34281a19b5504ad82a594fa8b0660591ff0ab28e9ad3fdd94214c26d78
6
+ metadata.gz: e98f9cf83934a297eed7ac621f0200b118610690ccd1c9f51279759edce9bfa0db23bd4161adcd762a891b7a3aad6c3606d3e2d66b5ae566615c971ee3bd6460
7
+ data.tar.gz: 8b90d7d720d5104d3280aefbf6065892f24d677489ae6c096bab31a887fbc4237ac76765f0425a16ed011aaee2dba4c2828f90a6411d6cc6dff95e761eddf943
@@ -35,12 +35,21 @@ module Vigiles
35
35
  const :url, T.any(URI::HTTPS, URI::HTTP)
36
36
  const :id, String
37
37
 
38
+ sig { params(header_key: String).returns(String) }
39
+ private_class_method def self.best_effort_unfuck_http_header(header_key)
40
+ (header_key.starts_with?("HTTP_") ? T.must(header_key[5..]) : header_key)
41
+ .split(/_/)
42
+ .map(&:titlecase)
43
+ .join("-")
44
+ end
45
+
38
46
  sig { params(request: ActionDispatch::Request).returns(Request) }
39
47
  def self.from(request)
40
48
  preferred_headers = Vigiles.spec.request_headers
41
49
  available_headers = request.original_headers
42
50
  recorded_headers = (available_headers if preferred_headers.empty?)
43
51
  recorded_headers ||= preferred_headers.to_h { |h| [h, available_headers[h]] }
52
+ unfucked_headers = recorded_headers.transform_keys { best_effort_unfuck_http_header _1 }
44
53
 
45
54
  Request.new(
46
55
  content_type: request.content_type || (raise InvalidParameterError, "content_type"),
@@ -48,7 +57,7 @@ module Vigiles
48
57
  timestamp: DateTime.now,
49
58
  remote_ip: IPAddr.new(request.remote_ip),
50
59
  protocol: request.protocol,
51
- headers: recorded_headers,
60
+ headers: unfucked_headers,
52
61
  origin: request.origin || "unknown_origin_url",
53
62
  payload: request.body.read,
54
63
  http_method: Types::HttpMethod.deserialize(request.method),
@@ -27,48 +27,5 @@ module Vigiles
27
27
 
28
28
  recorder.record(req:, res:)
29
29
  end
30
-
31
- sig do
32
- params(
33
- request: Request,
34
- response: Response,
35
- metadata: Metadata,
36
- extras: Extras
37
- )
38
- .returns(T.nilable(Conversation))
39
- end
40
- private_class_method def self.record_json_conversation(request:, response:, metadata:, extras:)
41
- Conversation.create!(
42
- request_content_type: request.content_type,
43
- request_user_agent: request.user_agent,
44
- request_timestamp: request.timestamp,
45
- request_remote_ip: request.remote_ip,
46
- request_protocol: request.protocol,
47
- request_headers: request.headers,
48
- request_origin: request.origin,
49
- request_payload: request.payload,
50
- request_method: request.http_method.serialize,
51
- request_path: request.path,
52
- request_url: request.url,
53
- request_id: request.id,
54
- response_content_type: response.content_type,
55
- response_headers: response.headers,
56
- response_payload: response.payload,
57
- response_status: response.status
58
- )
59
- rescue => e
60
- end
61
-
62
- sig { params(request: Request, response: Response, metadata: Metadata, extras: Extras).returns(T.nilable(Conversation)) }
63
- private_class_method def self.record_html_conversation(request:, response:, metadata:, extras:); end
64
-
65
- sig { params(request: Request, response: Response, metadata: Metadata, extras: Extras).returns(T.nilable(Conversation)) }
66
- private_class_method def self.record_conversation_with_unknown_content_type(
67
- request:,
68
- response:,
69
- metadata:,
70
- extras:
71
- )
72
- end
73
30
  end
74
31
  end
data/lib/vigiles/spec.rb CHANGED
@@ -3,9 +3,9 @@
3
3
 
4
4
  module Vigiles
5
5
  class Spec < T::Struct
6
- const :request_content_types, T::Set[String]
7
- const :request_headers, T::Set[String]
8
- const :recorders, T::Hash[String, ConversationRecorder]
6
+ const :request_content_types, T::Set[String]
7
+ const :request_headers, T::Set[String]
8
+ const :recorders, T::Hash[String, ConversationRecorder]
9
9
 
10
10
  sig { returns(Spec) }
11
11
  def self.make_default_spec
@@ -2,5 +2,5 @@
2
2
  # frozen_string_literal: true
3
3
 
4
4
  module Vigiles
5
- VERSION = "0.1.0-beta8"
5
+ VERSION = "0.1.0-beta9"
6
6
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: vigiles
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.1.0.pre.beta8
4
+ version: 0.1.0.pre.beta9
5
5
  platform: ruby
6
6
  authors:
7
7
  - Yaw Boakye
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2024-05-24 00:00:00.000000000 Z
11
+ date: 2024-05-26 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: sorbet-runtime