Class: Coach::RequestSerializer
- Inherits:
-
Object
- Object
- Coach::RequestSerializer
- Defined in:
- lib/coach/request_serializer.rb
Class Method Summary collapse
-
.apply_header_rule(header, value) ⇒ Object
Applies sanitizing rules.
-
.clear_header_rules! ⇒ Object
Resets all header sanitizing.
- .header_rules ⇒ Object
-
.sanitize_header(header, &rule) ⇒ Object
Sets global rules on how to sanitize headers.
Instance Method Summary collapse
-
#initialize(request) ⇒ RequestSerializer
constructor
A new instance of RequestSerializer.
- #serialize ⇒ Object
Constructor Details
#initialize(request) ⇒ RequestSerializer
Returns a new instance of RequestSerializer.
28 29 30 |
# File 'lib/coach/request_serializer.rb', line 28 def initialize(request) @request = request end |
Class Method Details
.apply_header_rule(header, value) ⇒ Object
Applies sanitizing rules. Expects header to be in ‘http_header_name’ form.
17 18 19 20 21 |
# File 'lib/coach/request_serializer.rb', line 17 def self.apply_header_rule(header, value) return value if header_rules[header].nil? header_rules[header].call(value) end |
.clear_header_rules! ⇒ Object
Resets all header sanitizing
24 25 26 |
# File 'lib/coach/request_serializer.rb', line 24 def self.clear_header_rules! @header_rules = {} end |
.header_rules ⇒ Object
5 6 7 |
# File 'lib/coach/request_serializer.rb', line 5 def self.header_rules @header_rules ||= {} end |
.sanitize_header(header, &rule) ⇒ Object
Sets global rules on how to sanitize headers. An optional block can be supplied that will determine how to transform the original header value, otherwise a default string is used.
12 13 14 |
# File 'lib/coach/request_serializer.rb', line 12 def self.sanitize_header(header, &rule) header_rules[header] = rule || ->(_value) { "[FILTERED]" } end |
Instance Method Details
#serialize ⇒ Object
32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 |
# File 'lib/coach/request_serializer.rb', line 32 def serialize { # Identification request_id: @request.uuid, # Request details method: @request.method, path: request_path, format: @request.format.try(:ref), params: @request.filtered_parameters, # uses config.filter_parameters # Extra request info headers: filtered_headers, session_id: @request.remote_ip, # TODO: remove in a future release session_ip: @request.remote_ip, } end |