2007-01-10 01:57:32 +00:00
/*
2008-10-27 11:35:07 +01:00
* Copyright ( c ) 2006 Kungliga Tekniska Högskolan
* ( Royal Institute of Technology , Stockholm , Sweden ) .
* All rights reserved .
2007-01-10 01:57:32 +00:00
*
2008-10-27 11:35:07 +01:00
* Redistribution and use in source and binary forms , with or without
* modification , are permitted provided that the following conditions
* are met :
2007-01-10 01:57:32 +00:00
*
2008-10-27 11:35:07 +01:00
* 1. Redistributions of source code must retain the above copyright
* notice , this list of conditions and the following disclaimer .
2007-01-10 01:57:32 +00:00
*
2008-10-27 11:35:07 +01:00
* 2. Redistributions in binary form must reproduce the above copyright
* notice , this list of conditions and the following disclaimer in the
* documentation and / or other materials provided with the distribution .
2007-01-10 01:57:32 +00:00
*
2008-10-27 11:35:07 +01:00
* 3. Neither the name of the Institute nor the names of its contributors
* may be used to endorse or promote products derived from this software
* without specific prior written permission .
2007-01-10 01:57:32 +00:00
*
2008-10-27 11:35:07 +01:00
* THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ` ` AS IS ' ' AND
* ANY EXPRESS OR IMPLIED WARRANTIES , INCLUDING , BUT NOT LIMITED TO , THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED . IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE
* FOR ANY DIRECT , INDIRECT , INCIDENTAL , SPECIAL , EXEMPLARY , OR CONSEQUENTIAL
* DAMAGES ( INCLUDING , BUT NOT LIMITED TO , PROCUREMENT OF SUBSTITUTE GOODS
* OR SERVICES ; LOSS OF USE , DATA , OR PROFITS ; OR BUSINESS INTERRUPTION )
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY , WHETHER IN CONTRACT , STRICT
* LIABILITY , OR TORT ( INCLUDING NEGLIGENCE OR OTHERWISE ) ARISING IN ANY WAY
* OUT OF THE USE OF THIS SOFTWARE , EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE .
2007-01-10 01:57:32 +00:00
*/
2008-08-26 19:35:52 +02:00
/* $Id$ */
2007-01-10 01:57:32 +00:00
# ifndef HEIM_NTLM_H
# define HEIM_NTLM_H
2008-03-19 10:17:42 +11:00
/**
* Buffer for storing data in the NTLM library . When filled in by the
* library it should be freed with heim_ntlm_free_buf ( ) .
*/
2007-01-10 01:57:32 +00:00
struct ntlm_buf {
2008-03-19 10:17:42 +11:00
size_t length ; /**< length buffer data */
void * data ; /**< pointer to the data itself */
2007-01-10 01:57:32 +00:00
} ;
# define NTLM_NEG_UNICODE 0x00000001
2010-11-11 11:27:33 +11:00
# define NTLM_NEG_OEM 0x00000002
2008-03-19 10:17:42 +11:00
# define NTLM_NEG_TARGET 0x00000004
2010-01-12 18:16:45 +11:00
# define NTLM_MBZ9 0x00000008
2007-01-10 01:57:32 +00:00
# define NTLM_NEG_SIGN 0x00000010
# define NTLM_NEG_SEAL 0x00000020
2010-11-11 11:27:33 +11:00
# define NTLM_NEG_DATAGRAM 0x00000040
# define NTLM_NEG_LM_KEY 0x00000080
# define NTLM_NEG_NTLM 0x00000200
# define NTLM_NEG_ANONYMOUS 0x00000800
2007-01-10 01:57:32 +00:00
2010-01-12 18:16:45 +11:00
# define NTLM_MBZ8 0x00000100
# define NTLM_NEG_NTLM 0x00000200
# define NTLM_NEG_NT_ONLY 0x00000400
# define NTLM_MBZ7 0x00000800 /* anon ? */
2007-01-10 01:57:32 +00:00
2010-01-12 18:16:45 +11:00
# define NTLM_OEM_SUPPLIED_DOMAIN 0x00001000
2010-11-11 11:27:33 +11:00
# define NTLM_OEM_SUPPLIED_WORKSTATION 0x00002000
2010-01-12 18:16:45 +11:00
# define NTLM_MBZ6 0x00004000 /* local call ? */
2007-01-10 01:57:32 +00:00
# define NTLM_NEG_ALWAYS_SIGN 0x00008000
2008-03-19 10:17:42 +11:00
# define NTLM_TARGET_DOMAIN 0x00010000
# define NTLM_TARGET_SERVER 0x00020000
2010-11-11 11:27:33 +11:00
2021-12-24 01:52:32 +01:00
# define NTLM_TARGET_SHARE 0x00040000 /* mbz */
# define NTLM_NEG_NTLM2_SESSION 0x00080000 /* EXTENDED_SESSIONSECURITY */
2010-01-12 18:16:45 +11:00
# define NTLM_NEG_NTLM2 0x00080000
# define NTLM_NEG_IDENTIFY 0x00100000
# define NTLM_MBZ5 0x00200000
# define NTLM_NON_NT_SESSION_KEY 0x00400000
# define NTLM_NEG_TARGET_INFO 0x00800000
# define NTLM_MBZ4 0x01000000
# define NTLM_NEG_VERSION 0x02000000
# define NTLM_MBZ3 0x04000000
# define NTLM_MBZ2 0x08000000
# define NTLM_MBZ1 0x10000000
2007-01-10 01:57:32 +00:00
# define NTLM_ENC_128 0x20000000
# define NTLM_NEG_KEYEX 0x40000000
2010-11-11 11:27:33 +11:00
# define NTLM_ENC_56 0x80000000
2007-01-10 01:57:32 +00:00
2008-03-19 10:17:42 +11:00
/**
* Struct for the NTLM target info , the strings is assumed to be in
* UTF8 . When filled in by the library it should be freed with
* heim_ntlm_free_targetinfo ( ) .
*/
2010-11-11 11:27:33 +11:00
2021-12-24 01:52:32 +01:00
/* avflags */
2010-11-11 11:27:33 +11:00
# define NTLM_TI_AV_FLAG_GUEST 0x00000001
2021-12-24 01:52:32 +01:00
# define NTLM_TI_AV_FLAG_MIC 0x00000002
2010-11-11 11:27:33 +11:00
2007-01-10 01:57:32 +00:00
struct ntlm_targetinfo {
2008-03-19 10:17:42 +11:00
char * servername ; /**< */
char * domainname ; /**< */
char * dnsdomainname ; /**< */
char * dnsservername ; /**< */
2010-11-11 11:27:33 +11:00
char * dnstreename ; /**< */
uint32_t avflags ; /**< */
2021-12-24 01:52:32 +01:00
char * targetname ;
struct ntlm_buf channel_bindings ;
uint64_t timestamp ;
2007-01-10 01:57:32 +00:00
} ;
2008-03-19 10:17:42 +11:00
/**
* Struct for the NTLM type1 message info , the strings is assumed to
* be in UTF8 . When filled in by the library it should be freed with
* heim_ntlm_free_type1 ( ) .
*/
2007-01-10 01:57:32 +00:00
struct ntlm_type1 {
2008-03-19 10:17:42 +11:00
uint32_t flags ; /**< */
char * domain ; /**< */
char * hostname ; /**< */
uint32_t os [ 2 ] ; /**< */
2007-01-10 01:57:32 +00:00
} ;
2008-03-19 10:17:42 +11:00
/**
* Struct for the NTLM type2 message info , the strings is assumed to
* be in UTF8 . When filled in by the library it should be freed with
* heim_ntlm_free_type2 ( ) .
*/
2007-01-10 01:57:32 +00:00
struct ntlm_type2 {
2008-03-19 10:17:42 +11:00
uint32_t flags ; /**< */
char * targetname ; /**< */
struct ntlm_buf targetinfo ; /**< */
2010-11-11 11:27:33 +11:00
unsigned char challenge [ 8 ] ; /**< */
2008-03-19 10:17:42 +11:00
uint32_t context [ 2 ] ; /**< */
uint32_t os [ 2 ] ; /**< */
2007-01-10 01:57:32 +00:00
} ;
2008-03-19 10:17:42 +11:00
/**
* Struct for the NTLM type3 message info , the strings is assumed to
* be in UTF8 . When filled in by the library it should be freed with
* heim_ntlm_free_type3 ( ) .
*/
2007-01-10 01:57:32 +00:00
struct ntlm_type3 {
2008-03-19 10:17:42 +11:00
uint32_t flags ; /**< */
char * username ; /**< */
char * targetname ; /**< */
struct ntlm_buf lm ; /**< */
struct ntlm_buf ntlm ; /**< */
struct ntlm_buf sessionkey ; /**< */
char * ws ; /**< */
uint32_t os [ 2 ] ; /**< */
2021-12-24 01:52:32 +01:00
size_t mic_offset ;
uint8_t mic [ 16 ] ;
2007-01-10 01:57:32 +00:00
} ;
2021-12-24 01:52:32 +01:00
extern time_t heim_ntlm_time_skew ;
2010-11-11 11:27:33 +11:00
# include <ntlm_err.h>
2007-01-10 01:57:32 +00:00
# include <heimntlm-protos.h>
# endif /* NTLM_NTLM_H */