Module: NewRelic::Security::Instrumentation::File

Included in:
Prepend
Defined in:
lib/newrelic_security/instrumentation-security/file/chain.rb,
lib/newrelic_security/instrumentation-security/file/prepend.rb,
lib/newrelic_security/instrumentation-security/file/instrumentation.rb

Defined Under Namespace

Modules: Chain, Prepend

Instance Method Summary collapse

Instance Method Details

#delete_on_enter(*var) ⇒ Object



8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
# File 'lib/newrelic_security/instrumentation-security/file/instrumentation.rb', line 8

def delete_on_enter(*var)
  event = nil
  NewRelic::Security::Agent.logger.debug "OnEnter : #{self.class}.#{__method__}"
  if NewRelic::Security::Instrumentation::InstrumentationUtils.notify_app_integrity_delete?(var)
    event = NewRelic::Security::Agent::Control::Collector.collect(FILE_INTEGRITY, var, DELETE)
  else
    # TODO: Add handling read_filter for outside app root directory files, example ../abc.txt
    NewRelic::Security::Agent.logger.debug "Filtered because File name exist in filtered list #{self.class}.#{__method__} Args:: #{var}"
  end
rescue => exception
  NewRelic::Security::Agent.logger.error "Exception in hook in #{self.class}.#{__method__}, #{exception.inspect}, #{exception.backtrace}"
ensure
  yield
  return event
end

#delete_on_exit(event, retval) ⇒ Object



24
25
26
27
28
29
30
31
# File 'lib/newrelic_security/instrumentation-security/file/instrumentation.rb', line 24

def delete_on_exit(event, retval)
  NewRelic::Security::Agent.logger.debug "OnExit :  #{self.class}.#{__method__}"
  NewRelic::Security::Agent::Utils.create_exit_event(event) if retval.is_a?(Integer)
rescue => exception
  NewRelic::Security::Agent.logger.error "Exception in hook in #{self.class}.#{__method__}, #{exception.inspect}, #{exception.backtrace}"
ensure
  yield
end


33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
# File 'lib/newrelic_security/instrumentation-security/file/instrumentation.rb', line 33

def unlink_on_enter(*var)
  event = nil
  NewRelic::Security::Agent.logger.debug "OnEnter : #{self.class}.#{__method__}"
  if NewRelic::Security::Instrumentation::InstrumentationUtils.notify_app_integrity_delete?(var)
    event = NewRelic::Security::Agent::Control::Collector.collect(FILE_INTEGRITY, var, DELETE)
  else
    # TODO: Add handling read_filter for outside app root directory files, example ../abc.txt
    NewRelic::Security::Agent.logger.debug "Filtered because File name exist in filtered list #{self.class}.#{__method__} Args:: #{var}"
  end
rescue => exception
  NewRelic::Security::Agent.logger.error "Exception in hook in #{self.class}.#{__method__}, #{exception.inspect}, #{exception.backtrace}"
ensure
  yield
  return event
end


49
50
51
52
53
54
55
56
# File 'lib/newrelic_security/instrumentation-security/file/instrumentation.rb', line 49

def unlink_on_exit(event, retval)
  NewRelic::Security::Agent.logger.debug "OnExit :  #{self.class}.#{__method__}"
  NewRelic::Security::Agent::Utils.create_exit_event(event) if retval.is_a?(Integer)
rescue => exception
  NewRelic::Security::Agent.logger.error "Exception in hook in #{self.class}.#{__method__}, #{exception.inspect}, #{exception.backtrace}"
ensure
  yield
end