nla

package
v0.0.0-...-f308def Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Dec 10, 2020 License: GPL-3.0 Imports: 13 Imported by: 0

Documentation

Index

Constants

View Source
const (
	MsvAvEOL             = 0x0000
	MsvAvNbComputerName  = 0x0001
	MsvAvNbDomainName    = 0x0002
	MsvAvDnsComputerName = 0x0003
	MsvAvDnsDomainName   = 0x0004
	MsvAvDnsTreeName     = 0x0005
	MsvAvFlags           = 0x0006
	MsvAvTimestamp       = 0x0007
	MsvAvSingleHost      = 0x0008
	MsvAvTargetName      = 0x0009
	MsvChannelBindings   = 0x000A
)
View Source
const (
	NTLMSSP_NEGOTIATE_56                       = 0x80000000
	NTLMSSP_NEGOTIATE_KEY_EXCH                 = 0x40000000
	NTLMSSP_NEGOTIATE_128                      = 0x20000000
	NTLMSSP_NEGOTIATE_VERSION                  = 0x02000000
	NTLMSSP_NEGOTIATE_TARGET_INFO              = 0x00800000
	NTLMSSP_REQUEST_NON_NT_SESSION_KEY         = 0x00400000
	NTLMSSP_NEGOTIATE_IDENTIFY                 = 0x00100000
	NTLMSSP_NEGOTIATE_EXTENDED_SESSIONSECURITY = 0x00080000
	NTLMSSP_TARGET_TYPE_SERVER                 = 0x00020000
	NTLMSSP_TARGET_TYPE_DOMAIN                 = 0x00010000
	NTLMSSP_NEGOTIATE_ALWAYS_SIGN              = 0x00008000
	NTLMSSP_NEGOTIATE_OEM_WORKSTATION_SUPPLIED = 0x00002000
	NTLMSSP_NEGOTIATE_OEM_DOMAIN_SUPPLIED      = 0x00001000
	NTLMSSP_NEGOTIATE_NTLM                     = 0x00000200
	NTLMSSP_NEGOTIATE_LM_KEY                   = 0x00000080
	NTLMSSP_NEGOTIATE_DATAGRAM                 = 0x00000040
	NTLMSSP_NEGOTIATE_SEAL                     = 0x00000020
	NTLMSSP_NEGOTIATE_SIGN                     = 0x00000010
	NTLMSSP_REQUEST_TARGET                     = 0x00000004
	NTLM_NEGOTIATE_OEM                         = 0x00000002
	NTLMSSP_NEGOTIATE_UNICODE                  = 0x00000001
)

Variables

This section is empty.

Functions

func EncodeDERTRequest

func EncodeDERTRequest(msgs []Message, authInfo string, pubKeyAuth string) []byte

func HMAC_MD5

func HMAC_MD5(key, data []byte) []byte

func LMOWFv2

func LMOWFv2(password, user, domain string) []byte

Same as NTOWFv2

func MD4

func MD4(data []byte) []byte

func MD5

func MD5(data []byte) []byte

func MIC

func MIC(exportedSessionKey []byte, negotiateMessage, challengeMessage, authenticateMessage Message) []byte

func NTOWFv2

func NTOWFv2(password, user, domain string) []byte

Version 2 of NTLM hash function

func RC4K

func RC4K(key, src []byte) []byte

func SIGNKEY

func SIGNKEY(exportedSessionKey []byte, isClient bool) []byte

func UnicodeEncode

func UnicodeEncode(p string) []byte

s.encode('utf-16le')

Types

type AVPair

type AVPair struct {
	Id    uint16 `struc:"little"`
	Len   uint16 `struc:"little,sizeof=Value"`
	Value []byte
}

type AuthenticateMessage

type AuthenticateMessage struct {
	Signature                          [8]byte
	MessageType                        uint32 `struc:"little"`
	LmChallengeResponseLen             uint16 `struc:"little"`
	LmChallengeResponseMaxLen          uint16 `struc:"little"`
	LmChallengeResponseBufferOffset    uint32 `struc:"little"`
	NtChallengeResponseLen             uint16 `struc:"little"`
	NtChallengeResponseMaxLen          uint16 `struc:"little"`
	NtChallengeResponseBufferOffset    uint32 `struc:"little"`
	DomainNameLen                      uint16 `struc:"little"`
	DomainNameMaxLen                   uint16 `struc:"little"`
	DomainNameBufferOffset             uint32 `struc:"little"`
	UserNameLen                        uint16 `struc:"little"`
	UserNameMaxLen                     uint16 `struc:"little"`
	UserNameBufferOffset               uint32 `struc:"little"`
	WorkstationLen                     uint16 `struc:"little"`
	WorkstationMaxLen                  uint16 `struc:"little"`
	WorkstationBufferOffset            uint32 `struc:"little"`
	EncryptedRandomSessionLen          uint16 `struc:"little"`
	EncryptedRandomSessionMaxLen       uint16 `struc:"little"`
	EncryptedRandomSessionBufferOffset uint32 `struc:"little"`
	NegotiateFlags                     uint32 `struc:"little"`
	Version                            NVersion
	MIC                                [16]byte
	Payload                            []byte `struc:"skip"`
}

func NewAuthenticateMessage

func NewAuthenticateMessage(negFlag uint32, domain, user, workstation string,
	lmchallResp, ntchallResp, enRandomSessKey []byte) *AuthenticateMessage

func (*AuthenticateMessage) BaseLen

func (m *AuthenticateMessage) BaseLen() uint32

func (*AuthenticateMessage) Serialize

func (m *AuthenticateMessage) Serialize() []byte

type ChallengeMessage

type ChallengeMessage struct {
	Signature              [8]byte
	MessageType            uint32 `struc:"little"`
	TargetNameLen          uint16 `struc:"little"`
	TargetNameMaxLen       uint16 `struc:"little"`
	TargetNameBufferOffset uint32 `struc:"little"`
	NegotiateFlags         uint32 `struc:"little"`
	ServerChallenge        [8]byte
	Reserved               [8]byte
	TargetInfoLen          uint16 `struc:"little"`
	TargetInfoMaxLen       uint16 `struc:"little"`
	TargetInfoBufferOffset uint32 `struc:"little"`
	Version                NVersion
	Payload                []byte `struc:"skip"`
}

func NewChallengeMessage

func NewChallengeMessage() *ChallengeMessage

func (*ChallengeMessage) BaseLen

func (m *ChallengeMessage) BaseLen() uint32

total len - payload len

func (*ChallengeMessage) Serialize

func (m *ChallengeMessage) Serialize() []byte

type Message

type Message interface {
	Serialize() []byte
}

type NTLMv2

type NTLMv2 struct {
	// contains filtered or unexported fields
}

func NewNTLMv2

func NewNTLMv2(domain, user, password string) *NTLMv2

func (*NTLMv2) ComputeResponse

func (n *NTLMv2) ComputeResponse(respKeyNT, respKeyLM, serverChallenge, clientChallenge,
	timestamp, serverName []byte) (ntChallResp, lmChallResp, SessBaseKey []byte)

process NTLMv2 Authenticate hash

func (*NTLMv2) GetAuthenticateMessage

func (n *NTLMv2) GetAuthenticateMessage(s []byte) *AuthenticateMessage

func (*NTLMv2) GetNegotiateMessage

func (n *NTLMv2) GetNegotiateMessage() *NegotiateMessage

generate first handshake messgae

type NVersion

type NVersion struct {
	ProductMajorVersion uint8
	ProductMinorVersion uint8
	ProductBuild        uint16 `struc:"little"`
	Reserved            [3]byte
	UInt8               uint8
}

type NegoToken

type NegoToken struct {
	Data []byte `asn1:"explicit,tag:0"`
}

type NegotiateMessage

type NegotiateMessage struct {
	Signature               [8]byte
	MessageType             uint32 `struc:"little"`
	NegotiateFlags          uint32 `struc:"little"`
	DomainNameLen           uint16 `struc:"little"`
	DomainNameMaxLen        uint16 `struc:"little"`
	DomainNameBufferOffset  uint32 `struc:"little"`
	WorkstationLen          uint16 `struc:"little"`
	WorkstationMaxLen       uint16 `struc:"little"`
	WorkstationBufferOffset uint32 `struc:"little"`
	Varsion                 NVersion
	Payload                 []byte `struc:"skip"`
}

func NewNegotiateMessage

func NewNegotiateMessage() *NegotiateMessage

func (*NegotiateMessage) Serialize

func (m *NegotiateMessage) Serialize() []byte

type OpenSSLRSAPublicKey

type OpenSSLRSAPublicKey struct {
}

type TSCredentials

type TSCredentials struct {
}

type TSCspDataDetail

type TSCspDataDetail struct {
}

type TSPasswordCreds

type TSPasswordCreds struct {
}

type TSRequest

type TSRequest struct {
	Version    int         `asn1:"explicit,tag:0"`
	NegoTokens []NegoToken `asn1:"optional,explicit,tag:1"`
	AuthInfo   string      `asn1:"optional,explicit,tag:2"`
	PubKeyAuth string      `asn1:"optional,explicit,tag:3"`
	ErrorCode  int         `asn1:"optional,explicit,tag:4"`
}

func DecodeDERTRequest

func DecodeDERTRequest(s []byte) (*TSRequest, error)

type TSSmartCardCreds

type TSSmartCardCreds struct {
}

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL