# This library is free software: you can redistribute it and/or # modify it under the terms of the GNU Lesser General Public # License as published by the Free Software Foundation, either # version 3 of the License, or (at your option) any later version. # This library is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU # Lesser General Public License for more details. # You should have received a copy of the GNU Lesser General Public # License along with this library. If not, see or . import hmac import os import struct from ntlm_auth.compute_response import ComputeResponse from ntlm_auth.constants import NegotiateFlags, MessageTypes, NTLM_SIGNATURE, AvFlags from ntlm_auth.rc4 import ARC4 from ntlm_auth.target_info import TargetInfo class NegotiateMessage(object): EXPECTED_BODY_LENGTH = 40 """ [MS-NLMP] v28.0 2016-07-14 2.2.1.1 NEGOTIATE_MESSAGE The NEGOTIATE_MESSAGE defines an NTLM Negotiate message that is sent from the client to the server. This message allows the client to specify its supported NTLM options to the server. :param negotiate_flags: A NEGOTIATE structure that contains a set of bit flags. These flags are the options the client supports :param domain_name: The domain name of the user to authenticate with, default is None :param workstation: The worksation of the client machine, default is None Attributes: signature: An 8-byte character array that MUST contain the ASCII string 'NTLMSSP\0' message_type: A 32-bit unsigned integer that indicates the message type. This field must be set to 0x00000001 negotiate_flags: A NEGOTIATE structure that contains a set of bit flags. These flags are the options the client supports version: Contains the windows version info of the client. It is used only debugging purposes and are only set when NTLMSSP_NEGOTIATE_VERSION flag is set domain_name: A byte-array that contains the name of the client authentication domain that MUST Be encoded in the negotiated character set workstation: A byte-array that contains the name of the client machine that MUST Be encoded in the negotiated character set """ def __init__(self, negotiate_flags, domain_name, workstation): self.signature = NTLM_SIGNATURE self.message_type = struct.pack('