rapid7/metasploit-framework

View on GitHub
lib/metasploit/framework/login_scanner/ntlm.rb

Summary

Maintainability
A
0 mins
Test Coverage
require 'metasploit/framework/login_scanner'

module Metasploit
  module Framework
    module LoginScanner

      # This Concern provides the basic accessors and validations
      # for protocols that require the use of NTLM for Authentication.
      module NTLM
        extend ActiveSupport::Concern
        include ActiveModel::Validations

        included do
          # @!attribute send_lm
          #   @return [Boolean] Whether to always send the LANMAN response(except if using NTLM2 Session)
          attr_accessor :send_lm

          # @!attribute send_ntlm
          #   @return [Boolean] Whether to use NTLM responses
          attr_accessor :send_ntlm

          # @!attribute send_spn
          #   @return [Boolean] Whether to support SPN for newer Windows OSes
          attr_accessor :send_spn

          # @!attribute use_lmkey
          #   @return [Boolean] Whether to negotiate with a LANMAN key
          attr_accessor :use_lmkey

          # @!attribute send_lm
          #   @return [Boolean] Whether to force the use of NTLM2 session
          attr_accessor :use_ntlm2_session

          # @!attribute send_lm
          #   @return [Boolean] Whether to force the use of NTLMv2 instead of NTLM2 Session
          attr_accessor :use_ntlmv2

          validates :send_lm,
                    inclusion: { in: [true, false] }

          validates :send_ntlm,
                    inclusion: { in: [true, false] }

          validates :send_spn,
                    inclusion: { in: [true, false] }

          validates :use_lmkey,
                    inclusion: { in: [true, false] }

          validates :use_ntlm2_session,
                    inclusion: { in: [true, false] }

          validates :use_ntlmv2,
                    inclusion: { in: [true, false] }
        end

      end

    end
  end
end