Class: Rex::Proto::Kerberos::KerberosLoggerSubscriber

Inherits:
KerberosSubscriber show all
Defined in:
lib/rex/proto/kerberos/kerberos_logger_subscriber.rb

Overview

Logs Kerberos requests/responses

Instance Method Summary collapse

Constructor Details

#initialize(logger:) ⇒ KerberosLoggerSubscriber

Returns a new instance of KerberosLoggerSubscriber.



16
17
18
19
20
21
# File 'lib/rex/proto/kerberos/kerberos_logger_subscriber.rb', line 16

def initialize(logger:)
  super()
  raise 'Incompatible logger' unless logger.respond_to?(:print_line) && logger.respond_to?(:datastore)

  @logger = logger
end

Instance Method Details

#on_credential(credential, source: nil) ⇒ Object

Parameters:



47
48
49
50
51
52
53
# File 'lib/rex/proto/kerberos/kerberos_logger_subscriber.rb', line 47

def on_credential(credential, source: nil)
  return unless trace_enabled?
  return if credential.nil?

  print_credential_header(source)
  @logger.print_line(format_credential(credential))
end

#on_request(request) ⇒ Object



24
25
26
27
28
29
30
# File 'lib/rex/proto/kerberos/kerberos_logger_subscriber.rb', line 24

def on_request(request)
  return unless trace_enabled?

  request_color, _response_color = trace_colors
  print_header('Request', request)
  @logger.print_line("%clr#{request_color}#{format_message(request)}%clr")
end

#on_response(response) ⇒ Object



33
34
35
36
37
38
39
40
41
42
43
44
# File 'lib/rex/proto/kerberos/kerberos_logger_subscriber.rb', line 33

def on_response(response)
  return unless trace_enabled?

  _request_color, response_color = trace_colors
  print_header('Response', response)
  if response.nil?
    @logger.print_line('No response received')
    return
  end

  @logger.print_line("%clr#{response_color}#{format_message(response)}%clr")
end