Sha256: 802e16601f848f74c91981fe4f5d40a57271f557eda92c04eec3cd2e29294831

Contents?: true

Size: 1.72 KB

Versions: 21

Compression:

Stored size: 1.72 KB

Contents

# frozen_string_literal: true

module Datadog
  module AppSec
    module Monitor
      module Reactive
        # Dispatch data from Datadog::Kit::Identity.set_user to the WAF context
        module SetUser
          ADDRESSES = [
            'usr.id',
          ].freeze
          private_constant :ADDRESSES

          def self.publish(op, user)
            catch(:block) do
              op.publish('usr.id', user.id)

              nil
            end
          end

          def self.subscribe(op, waf_context)
            op.subscribe(*ADDRESSES) do |*values|
              Datadog.logger.debug { "reacted to #{ADDRESSES.inspect}: #{values.inspect}" }

              user_id = values[0]

              waf_args = {
                'usr.id' => user_id,
              }

              waf_timeout = Datadog.configuration.appsec.waf_timeout
              result = waf_context.run(waf_args, waf_timeout)

              Datadog.logger.debug { "WAF TIMEOUT: #{result.inspect}" } if result.timeout

              case result.status
              when :match
                Datadog.logger.debug { "WAF: #{result.inspect}" }

                yield result
                throw(:block, true) unless result.actions.empty?
              when :ok
                Datadog.logger.debug { "WAF OK: #{result.inspect}" }
              when :invalid_call
                Datadog.logger.debug { "WAF CALL ERROR: #{result.inspect}" }
              when :invalid_rule, :invalid_flow, :no_rule
                Datadog.logger.debug { "WAF RULE ERROR: #{result.inspect}" }
              else
                Datadog.logger.debug { "WAF UNKNOWN: #{result.status.inspect} #{result.inspect}" }
              end
            end
          end
        end
      end
    end
  end
end

Version data entries

21 entries across 21 versions & 2 rubygems

Version Path
datadog-2.4.0 lib/datadog/appsec/monitor/reactive/set_user.rb
datadog-2.3.0 lib/datadog/appsec/monitor/reactive/set_user.rb
datadog-2.2.0 lib/datadog/appsec/monitor/reactive/set_user.rb
ddtrace-1.23.3 lib/datadog/appsec/monitor/reactive/set_user.rb
ddtrace-1.23.2 lib/datadog/appsec/monitor/reactive/set_user.rb
datadog-2.1.0 lib/datadog/appsec/monitor/reactive/set_user.rb
datadog-2.0.0 lib/datadog/appsec/monitor/reactive/set_user.rb
ddtrace-1.23.1 lib/datadog/appsec/monitor/reactive/set_user.rb
datadog-2.0.0.beta2 lib/datadog/appsec/monitor/reactive/set_user.rb
ddtrace-1.22.0 lib/datadog/appsec/monitor/reactive/set_user.rb
datadog-2.0.0.beta1 lib/datadog/appsec/monitor/reactive/set_user.rb
ddtrace-1.21.1 lib/datadog/appsec/monitor/reactive/set_user.rb
ddtrace-1.21.0 lib/datadog/appsec/monitor/reactive/set_user.rb
ddtrace-1.20.0 lib/datadog/appsec/monitor/reactive/set_user.rb
ddtrace-1.19.0 lib/datadog/appsec/monitor/reactive/set_user.rb
ddtrace-1.18.0 lib/datadog/appsec/monitor/reactive/set_user.rb
ddtrace-1.17.0 lib/datadog/appsec/monitor/reactive/set_user.rb
ddtrace-1.16.2 lib/datadog/appsec/monitor/reactive/set_user.rb
ddtrace-1.16.1 lib/datadog/appsec/monitor/reactive/set_user.rb
ddtrace-1.16.0 lib/datadog/appsec/monitor/reactive/set_user.rb