Class: DataDomeModule

Inherits:
Object
  • Object
show all
Includes:
Configurable
Defined in:
lib/datadome_module.rb

Constant Summary

Constants included from Configurable

Configurable::ALL_ENDPOINT_INCLUSION_REGEXP, Configurable::STATIC_PAGE_EXCLUSION_REGEXP

Instance Method Summary collapse

Methods included from Configurable

included

Constructor Details

#initialize(app) ⇒ DataDomeModule

Returns a new instance of DataDomeModule.



14
15
16
17
# File 'lib/datadome_module.rb', line 14

def initialize(app)
  @app = app
  @configuration = self.class.configuration
end

Instance Method Details

#call(env) ⇒ Object



19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
# File 'lib/datadome_module.rb', line 19

def call(env)
  request = ActionDispatch::Request.new(env)

  assessment_result = datadome_assessment(request)
  return @app.call(env) unless assessment_result
  return assessment_result.response_array unless assessment_result.legitimate_request?

  status, headers, payload = @app.call(env)

  # Merge the headers from DataDome with the original headers
  headers = headers.merge(assessment_result.headers) do |key, request_header_val, datadome_header_val|
    if key.downcase == "set-cookie" && request_header_val
      # Handle the merge for cookies when the protected request has at least one cookie
      # If the original request contains one cookie, ensure it's in an array format for uniform handling
      request_header_val = [request_header_val] unless request_header_val.is_a?(Array) 
      
      # Remove any cookies that start with 'datadome=' from the original request's cookies
      request_header_val.reject! { |cookie| cookie.downcase.start_with?("datadome=") }
      
      # Return the cookies merged with the new value of the datadome cookie
      [datadome_header_val, *request_header_val]
    else
      # For DataDome headers other than 'Set-Cookie', return the value.
      datadome_header_val
    end
  end

  [status, headers, payload]
end