Class: Datadog::AppSec::Processor

Inherits:
Object
  • Object
show all
Defined in:
lib/datadog/appsec/processor.rb,
lib/datadog/appsec/processor/rule_loader.rb,
lib/datadog/appsec/processor/rule_merger.rb

Overview

Processor integrates libddwaf into datadog/appsec NOTE: This class will be moved under AppSec::SecurityEngine namespace

Defined Under Namespace

Modules: RuleLoader, RuleMerger

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(ruleset:, telemetry:) ⇒ Processor

Returns a new instance of Processor.



12
13
14
15
16
17
18
19
20
21
22
23
# File 'lib/datadog/appsec/processor.rb', line 12

def initialize(ruleset:, telemetry:)
  @telemetry = telemetry
  @diagnostics = nil
  @addresses = []

  settings = Datadog.configuration.appsec

  # TODO: Refactor to make it easier to test
  unless require_libddwaf && libddwaf_provides_waf? && create_waf_handle(settings, ruleset)
    Datadog.logger.warn('AppSec is disabled, see logged errors above')
  end
end

Instance Attribute Details

#addressesObject (readonly)

Returns the value of attribute addresses.



10
11
12
# File 'lib/datadog/appsec/processor.rb', line 10

def addresses
  @addresses
end

#diagnosticsObject (readonly)

Returns the value of attribute diagnostics.



10
11
12
# File 'lib/datadog/appsec/processor.rb', line 10

def diagnostics
  @diagnostics
end

Instance Method Details

#finalizeObject



29
30
31
# File 'lib/datadog/appsec/processor.rb', line 29

def finalize
  @handle.finalize
end

#new_runnerObject



33
34
35
# File 'lib/datadog/appsec/processor.rb', line 33

def new_runner
  SecurityEngine::Runner.new(@handle, telemetry: @telemetry)
end

#ready?Boolean

Returns:

  • (Boolean)


25
26
27
# File 'lib/datadog/appsec/processor.rb', line 25

def ready?
  !@handle.nil?
end