1996-05-04 07:50:46 +00:00
# ifndef _INCLUDES_H
# define _INCLUDES_H
/*
2002-01-30 06:08:46 +00:00
Unix SMB / CIFS implementation .
1996-05-04 07:50:46 +00:00
Machine customisation and include handling
1998-01-22 13:27:43 +00:00
Copyright ( C ) Andrew Tridgell 1994 - 1998
2002-01-09 05:27:59 +00:00
Copyright ( C ) 2002 by Martin Pool < mbp @ samba . org >
1996-05-04 07:50:46 +00:00
This program is free software ; you can redistribute it and / or modify
it under the terms of the GNU General Public License as published by
2007-07-09 19:25:36 +00:00
the Free Software Foundation ; either version 3 of the License , or
1996-05-04 07:50:46 +00:00
( at your option ) any later version .
This program 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 General Public License for more details .
You should have received a copy of the GNU General Public License
2007-07-10 00:52:41 +00:00
along with this program . If not , see < http : //www.gnu.org/licenses/>.
1996-05-04 07:50:46 +00:00
*/
2006-04-13 12:03:12 +00:00
/* work around broken krb5.h on sles9 */
# ifdef SIZEOF_LONG
# undef SIZEOF_LONG
# endif
2008-09-16 16:30:14 +02:00
# include "../replace/replace.h"
1998-10-07 07:55:14 +00:00
2007-01-03 08:55:22 +00:00
/* make sure we have included the correct config.h */
# ifndef NO_CONFIG_H /* for some tests */
# ifndef CONFIG_H_IS_FROM_SAMBA
# error "make sure you have removed all config.h files from standalone builds!"
# error "the included config.h isn't from samba!"
# endif
# endif /* NO_CONFIG_H */
2006-05-24 14:38:11 +00:00
/* only do the C++ reserved word check when we compile
to include - - with - developer since too many systems
still have comflicts with their header files ( e . g . IRIX 6.4 ) */
# if !defined(__cplusplus) && defined(DEVELOPER)
2005-06-24 20:25:18 +00:00
# define class #error DONT_USE_CPLUSPLUS_RESERVED_NAMES
2006-02-22 11:47:41 +00:00
# define private #error DONT_USE_CPLUSPLUS_RESERVED_NAMES
2005-06-24 20:25:18 +00:00
# define public #error DONT_USE_CPLUSPLUS_RESERVED_NAMES
2005-06-24 21:18:20 +00:00
# define protected #error DONT_USE_CPLUSPLUS_RESERVED_NAMES
2005-06-24 20:25:18 +00:00
# define template #error DONT_USE_CPLUSPLUS_RESERVED_NAMES
# define this #error DONT_USE_CPLUSPLUS_RESERVED_NAMES
# define new #error DONT_USE_CPLUSPLUS_RESERVED_NAMES
# define delete #error DONT_USE_CPLUSPLUS_RESERVED_NAMES
# define friend #error DONT_USE_CPLUSPLUS_RESERVED_NAMES
# endif
1998-07-29 03:08:05 +00:00
# include "local.h"
1996-05-04 07:50:46 +00:00
1998-07-29 03:08:05 +00:00
# ifdef AIX
# define DEFAULT_PRINTING PRINT_AIX
1998-11-17 00:31:39 +00:00
# define PRINTCAP_NAME " / etc / qconfig"
1996-05-04 07:50:46 +00:00
# endif
1998-07-29 03:08:05 +00:00
# ifdef HPUX
# define DEFAULT_PRINTING PRINT_HPUX
1996-05-04 07:50:46 +00:00
# endif
1998-07-29 03:08:05 +00:00
# ifdef QNX
# define DEFAULT_PRINTING PRINT_QNX
1996-05-04 07:50:46 +00:00
# endif
1998-07-29 03:08:05 +00:00
# ifdef SUNOS4
/* on SUNOS4 termios.h conflicts with sys/ioctl.h */
# undef HAVE_TERMIOS_H
1996-05-04 07:50:46 +00:00
# endif
1999-12-13 13:27:58 +00:00
# ifdef RELIANTUNIX
/*
* < unistd . h > has to be included before any other to get
2001-04-04 17:20:57 +00:00
* large file support on Reliant UNIX . Yes , it ' s broken : - ) .
1999-12-13 13:27:58 +00:00
*/
# ifdef HAVE_UNISTD_H
# include <unistd.h>
# endif
# endif /* RELIANTUNIX */
2006-09-18 22:49:20 +00:00
# include "system/capability.h"
# include "system/dir.h"
# include "system/filesys.h"
# include "system/glob.h"
# include "system/iconv.h"
# include "system/locale.h"
# include "system/network.h"
# include "system/passwd.h"
# include "system/readline.h"
# include "system/select.h"
# include "system/shmem.h"
# include "system/syslog.h"
# include "system/terminal.h"
# include "system/time.h"
# include "system/wait.h"
1998-11-23 23:07:38 +00:00
# if defined(HAVE_RPC_RPC_H)
1999-12-13 13:27:58 +00:00
/*
* Check for AUTH_ERROR define conflict with rpc / rpc . h in prot . h .
*/
# if defined(HAVE_SYS_SECURITY_H) && defined(HAVE_RPC_AUTH_ERROR_CONFLICT)
# undef AUTH_ERROR
# endif
2004-09-07 23:30:27 +00:00
/*
* HP - UX 11. X has TCP_NODELAY and TCP_MAXSEG defined in < netinet / tcp . h > which
* was included above . However < rpc / rpc . h > includes < sys / xti . h > which defines
* them again without checking if they already exsist . This generates
* two " Redefinition of macro " warnings for every single . c file that is
* compiled .
*/
# if defined(HPUX) && defined(TCP_NODELAY)
# undef TCP_NODELAY
# endif
# if defined(HPUX) && defined(TCP_MAXSEG)
# undef TCP_MAXSEG
# endif
1998-11-23 23:07:38 +00:00
# include <rpc/rpc.h>
# endif
1998-11-19 04:15:23 +00:00
# if defined(HAVE_YP_GET_DEFAULT_DOMAIN) && defined(HAVE_SETNETGRENT) && defined(HAVE_ENDNETGRENT) && defined(HAVE_GETNETGRENT)
# define HAVE_NETGROUP 1
# endif
1998-11-23 23:07:38 +00:00
# if defined (HAVE_NETGROUP)
2004-08-31 15:11:41 +00:00
# if defined(HAVE_RPCSVC_YP_PROT_H)
2004-09-07 23:30:27 +00:00
/*
* HP - UX 11. X has TCP_NODELAY and TCP_MAXSEG defined in < netinet / tcp . h > which
* was included above . However < rpc / rpc . h > includes < sys / xti . h > which defines
* them again without checking if they already exsist . This generates
* two " Redefinition of macro " warnings for every single . c file that is
* compiled .
*/
# if defined(HPUX) && defined(TCP_NODELAY)
# undef TCP_NODELAY
# endif
# if defined(HPUX) && defined(TCP_MAXSEG)
# undef TCP_MAXSEG
# endif
2004-08-31 15:11:41 +00:00
# include <rpcsvc/yp_prot.h>
# endif
2004-09-16 02:49:01 +00:00
# if defined(HAVE_RPCSVC_YPCLNT_H)
# include <rpcsvc/ypclnt.h>
# endif
1998-11-23 23:07:38 +00:00
# endif /* HAVE_NETGROUP */
2001-11-27 07:09:06 +00:00
# if HAVE_KRB5_H
2001-10-18 10:26:06 +00:00
# include <krb5.h>
2001-11-27 22:37:25 +00:00
# else
# undef HAVE_KRB5
2001-10-18 10:26:06 +00:00
# endif
2001-12-30 05:59:43 +00:00
# if HAVE_LBER_H
# include <lber.h>
2007-06-04 08:01:48 +00:00
# if defined(HPUX) && !defined(_LBER_TYPES_H)
2007-04-02 23:07:06 +00:00
/* Define ber_tag_t and ber_int_t for using
* HP LDAP - UX Integration products ' LDAP libraries .
*/
# ifndef ber_tag_t
2007-04-06 19:38:35 +00:00
typedef unsigned long ber_tag_t ;
typedef int ber_int_t ;
2007-04-02 23:07:06 +00:00
# endif
2007-06-04 08:01:48 +00:00
# endif /* defined(HPUX) && !defined(_LBER_TYPES_H) */
2005-11-22 17:15:28 +00:00
# ifndef LBER_USE_DER
# define LBER_USE_DER 0x01
# endif
2001-12-30 05:59:43 +00:00
# endif
2001-11-25 12:40:23 +00:00
# if HAVE_LDAP_H
2001-11-20 08:54:15 +00:00
# include <ldap.h>
2005-11-22 17:15:28 +00:00
# ifndef LDAP_CONST
# define LDAP_CONST const
# endif
# ifndef LDAP_OPT_SUCCESS
# define LDAP_OPT_SUCCESS 0
# endif
2006-02-26 01:41:02 +00:00
/* Solaris 8 and maybe other LDAP implementations spell this "..._INPROGRESS": */
# if defined(LDAP_SASL_BIND_INPROGRESS) && !defined(LDAP_SASL_BIND_IN_PROGRESS)
# define LDAP_SASL_BIND_IN_PROGRESS LDAP_SASL_BIND_INPROGRESS
# endif
2006-02-26 12:25:34 +00:00
/* Solaris 8 defines SSL_LDAP_PORT, not LDAPS_PORT and it only does so if
LDAP_SSL is defined - but SSL is not working . We just want the
port number ! Let ' s just define LDAPS_PORT correct . */
# if !defined(LDAPS_PORT)
# define LDAPS_PORT 636
# endif
2001-11-27 22:37:25 +00:00
# else
# undef HAVE_LDAP
2001-11-20 08:54:15 +00:00
# endif
2009-02-22 19:46:40 +01:00
# if HAVE_GSSAPI_GSSAPI_H
2001-12-08 11:18:56 +00:00
# include <gssapi/gssapi.h>
2004-11-05 00:57:29 +00:00
# elif HAVE_GSSAPI_GSSAPI_GENERIC_H
2001-12-08 11:18:56 +00:00
# include <gssapi/gssapi_generic.h>
2009-02-22 19:46:40 +01:00
# elif HAVE_GSSAPI_H
# include <gssapi.h>
2001-11-20 08:54:15 +00:00
# endif
2003-01-16 02:58:14 +00:00
# if HAVE_COM_ERR_H
# include <com_err.h>
# endif
2003-08-15 01:29:08 +00:00
# if HAVE_SYS_ATTRIBUTES_H
# include <sys/attributes.h>
# endif
2007-08-10 09:44:13 +00:00
# ifndef ENOATTR
2009-08-06 15:09:01 -07:00
# if defined(ENODATA)
2007-08-10 09:44:13 +00:00
# define ENOATTR ENODATA
2009-08-06 15:09:01 -07:00
# else
# define ENOATTR ENOENT
# endif
2007-08-10 09:44:13 +00:00
# endif
2004-02-20 15:52:14 +00:00
/* mutually exclusive (SuSE 8.2) */
2003-06-05 20:29:55 +00:00
# if HAVE_ATTR_XATTR_H
# include <attr/xattr.h>
2004-02-20 15:50:18 +00:00
# elif HAVE_SYS_XATTR_H
2004-02-19 22:17:54 +00:00
# include <sys/xattr.h>
# endif
2006-02-20 11:57:47 +00:00
# ifdef HAVE_SYS_EA_H
# include <sys/ea.h>
# endif
2005-04-10 04:27:14 +00:00
# ifdef HAVE_SYS_EXTATTR_H
# include <sys/extattr.h>
# endif
# ifdef HAVE_SYS_UIO_H
# include <sys/uio.h>
# endif
2003-06-30 02:11:13 +00:00
# if HAVE_LANGINFO_H
# include <langinfo.h>
# endif
2008-02-01 13:04:10 +01:00
# if HAVE_NETGROUP_H
# include <netgroup.h>
# endif
2006-01-09 15:54:16 +00:00
# if defined(HAVE_AIO_H) && defined(WITH_AIO)
2005-06-27 22:08:58 +00:00
# include <aio.h>
# endif
2009-02-17 16:16:35 -08:00
# ifdef WITH_MADVISE_PROTECTED
# include <sys/mman.h>
# endif
2003-04-16 13:19:51 +00:00
/* Special macros that are no-ops except when run under Valgrind on
* x86 . They ' ve moved a little bit from valgrind 1.0 .4 to 1.9 .4 */
# if HAVE_VALGRIND_MEMCHECK_H
/* memcheck.h includes valgrind.h */
# include <valgrind/memcheck.h>
# elif HAVE_VALGRIND_H
# include <valgrind.h>
# endif
/* If we have --enable-developer and the valgrind header is present,
* then we ' re OK to use it . Set a macro so this logic can be done only
* once . */
2009-02-12 12:29:35 +01:00
# if defined(DEVELOPER)
2006-02-06 06:22:20 +00:00
# if (HAVE_VALGRIND_H || HAVE_VALGRIND_VALGRIND_H)
2003-04-16 13:19:51 +00:00
# define VALGRIND
# endif
2006-02-06 06:22:20 +00:00
# endif
2003-04-16 13:19:51 +00:00
2002-09-25 15:19:00 +00:00
/* we support ADS if we want it and have krb5 and ldap libs */
# if defined(WITH_ADS) && defined(HAVE_KRB5) && defined(HAVE_LDAP)
2001-11-20 08:54:15 +00:00
# define HAVE_ADS
# endif
1999-12-13 13:27:58 +00:00
/*
2001-06-25 02:53:13 +00:00
* Define additional missing types
1999-12-13 13:27:58 +00:00
*/
2008-10-19 09:51:26 +02:00
# if defined(AIX)
2002-07-15 10:35:28 +00:00
typedef sig_atomic_t SIG_ATOMIC_T ;
# else
2008-10-19 09:51:26 +02:00
typedef sig_atomic_t volatile SIG_ATOMIC_T ;
2001-06-25 02:53:13 +00:00
# endif
1999-12-13 13:27:58 +00:00
1998-07-29 03:08:05 +00:00
# ifndef uchar
# define uchar unsigned char
1996-05-04 07:50:46 +00:00
# endif
1998-08-31 20:20:54 +00:00
/*
Samba needs type definitions for int16 , int32 , uint16 and uint32 .
Normally these are signed and unsigned 16 and 32 bit integers , but
they actually only need to be at least 16 and 32 bits
respectively . Thus if your word size is 8 bytes just defining them
as signed and unsigned int will work .
*/
# ifndef uint8
2008-10-14 03:38:34 +02:00
# define uint8 uint8_t
1998-08-31 20:20:54 +00:00
# endif
1998-11-19 04:15:23 +00:00
# if !defined(int16) && !defined(HAVE_INT16_FROM_RPC_RPC_H)
2008-10-14 03:38:34 +02:00
# define int16 int16_t
2006-05-24 14:26:34 +00:00
/* needed to work around compile issue on HP-UX 11.x */
# define _INT16 1
1998-08-31 20:20:54 +00:00
# endif
1998-11-19 04:15:23 +00:00
/*
* Note we duplicate the size tests in the unsigned
* case as int16 may be a typedef from rpc / rpc . h
*/
2008-10-14 03:38:34 +02:00
1998-11-19 04:15:23 +00:00
# if !defined(uint16) && !defined(HAVE_UINT16_FROM_RPC_RPC_H)
2008-10-14 03:38:34 +02:00
# define uint16 uint16_t
1998-08-31 20:20:54 +00:00
# endif
1998-11-19 04:15:23 +00:00
# if !defined(int32) && !defined(HAVE_INT32_FROM_RPC_RPC_H)
2008-10-14 03:38:34 +02:00
# define int32 int32_t
2009-07-01 10:49:35 -07:00
# ifndef _INT32
/* needed to work around compile issue on HP-UX 11.x */
# define _INT32 1
# endif
1997-12-03 05:22:24 +00:00
# endif
1998-11-19 04:15:23 +00:00
/*
* Note we duplicate the size tests in the unsigned
* case as int32 may be a typedef from rpc / rpc . h
*/
# if !defined(uint32) && !defined(HAVE_UINT32_FROM_RPC_RPC_H)
2008-10-14 03:38:34 +02:00
# define uint32 uint32_t
2001-06-26 05:38:24 +00:00
# endif
1996-05-04 07:50:46 +00:00
2006-04-12 14:10:39 +00:00
/*
* check for 8 byte long long
*/
# if !defined(uint64)
2008-10-14 03:38:34 +02:00
# define uint64 uint64_t
2006-04-12 14:10:39 +00:00
# endif
2006-08-22 22:53:08 +00:00
# if !defined(int64)
2008-10-14 03:38:34 +02:00
# define int64 int64_t
2006-08-22 22:53:08 +00:00
# endif
2006-04-12 14:10:39 +00:00
1998-08-31 20:20:54 +00:00
/*
1998-09-03 18:40:31 +00:00
* Types for devices , inodes and offsets .
1998-08-31 20:20:54 +00:00
*/
# ifndef SMB_DEV_T
2002-01-10 00:28:09 +00:00
# if defined(HAVE_EXPLICIT_LARGEFILE_SUPPORT) && defined(HAVE_DEV64_T)
# define SMB_DEV_T dev64_t
# else
# define SMB_DEV_T dev_t
# endif
1998-08-31 20:20:54 +00:00
# endif
2006-01-12 22:17:54 +00:00
# ifndef LARGE_SMB_DEV_T
# if (defined(HAVE_EXPLICIT_LARGEFILE_SUPPORT) && defined(HAVE_DEV64_T)) || (defined(SIZEOF_DEV_T) && (SIZEOF_DEV_T == 8))
# define LARGE_SMB_DEV_T 1
# endif
# endif
# ifdef LARGE_SMB_DEV_T
# define SDEV_T_VAL(p, ofs, v) (SIVAL((p),(ofs),(v)&0xFFFFFFFF), SIVAL((p),(ofs)+4,(v)>>32))
2008-10-14 01:59:36 +02:00
# define DEV_T_VAL(p, ofs) ((SMB_DEV_T)(((uint64_t)(IVAL((p),(ofs))))| (((uint64_t)(IVAL((p),(ofs)+4))) << 32)))
2006-01-12 22:17:54 +00:00
# else
# define SDEV_T_VAL(p, ofs, v) (SIVAL((p),(ofs),v),SIVAL((p),(ofs)+4,0))
# define DEV_T_VAL(p, ofs) ((SMB_DEV_T)(IVAL((p),(ofs))))
# endif
1998-09-04 20:53:58 +00:00
/*
* Setup the correctly sized inode type .
*/
1998-08-31 20:20:54 +00:00
# ifndef SMB_INO_T
1999-12-13 13:27:58 +00:00
# if defined(HAVE_EXPLICIT_LARGEFILE_SUPPORT) && defined(HAVE_INO64_T)
1998-09-04 20:53:58 +00:00
# define SMB_INO_T ino64_t
# else
# define SMB_INO_T ino_t
# endif
# endif
# ifndef LARGE_SMB_INO_T
1999-12-13 13:27:58 +00:00
# if (defined(HAVE_EXPLICIT_LARGEFILE_SUPPORT) && defined(HAVE_INO64_T)) || (defined(SIZEOF_INO_T) && (SIZEOF_INO_T == 8))
1998-09-04 20:53:58 +00:00
# define LARGE_SMB_INO_T 1
# endif
1998-08-31 20:20:54 +00:00
# endif
1998-10-24 08:08:05 +00:00
# ifdef LARGE_SMB_INO_T
2006-01-12 22:17:54 +00:00
# define SINO_T_VAL(p, ofs, v) (SIVAL((p),(ofs),(v)&0xFFFFFFFF), SIVAL((p),(ofs)+4,(v)>>32))
2008-10-14 01:59:36 +02:00
# define INO_T_VAL(p, ofs) ((SMB_INO_T)(((uint64_t)(IVAL(p,ofs)))| (((uint64_t)(IVAL(p,(ofs)+4))) << 32)))
1998-10-24 08:08:05 +00:00
# else
2006-01-12 22:17:54 +00:00
# define SINO_T_VAL(p, ofs, v) (SIVAL(p,ofs,v),SIVAL(p,(ofs)+4,0))
# define INO_T_VAL(p, ofs) ((SMB_INO_T)(IVAL((p),(ofs))))
1998-10-24 08:08:05 +00:00
# endif
1998-09-03 18:40:31 +00:00
# ifndef SMB_OFF_T
1999-12-13 13:27:58 +00:00
# if defined(HAVE_EXPLICIT_LARGEFILE_SUPPORT) && defined(HAVE_OFF64_T)
1998-09-04 00:23:28 +00:00
# define SMB_OFF_T off64_t
# else
# define SMB_OFF_T off_t
# endif
1998-09-03 18:40:31 +00:00
# endif
2004-03-04 18:17:01 +00:00
# define SBIG_UINT(p, ofs, v) (SIVAL(p,ofs,(v)&0xFFFFFFFF), SIVAL(p,(ofs)+4,(v)>>32))
2009-02-12 10:39:17 -05:00
# define BIG_UINT(p, ofs) ((((uint64_t) IVAL(p,(ofs)+4))<<32)|IVAL(p,ofs))
2008-10-14 01:59:36 +02:00
# define IVAL2_TO_SMB_BIG_UINT(buf,off) ( (((uint64_t)(IVAL((buf),(off)))) & ((uint64_t)0xFFFFFFFF)) | \
( ( ( ( uint64_t ) ( IVAL ( ( buf ) , ( off + 4 ) ) ) ) & ( ( uint64_t ) 0xFFFFFFFF ) ) < < 32 ) )
2004-03-04 18:17:01 +00:00
2000-01-13 12:05:40 +00:00
/* this should really be a 64 bit type if possible */
2008-10-14 01:59:36 +02:00
typedef uint64_t br_off ;
2000-01-13 12:05:40 +00:00
1998-09-18 02:30:03 +00:00
# define SMB_OFF_T_BITS (sizeof(SMB_OFF_T)*8)
1998-09-03 18:40:31 +00:00
/*
* Set the define that tells us if we can do 64 bit
* NT SMB calls .
*/
# ifndef LARGE_SMB_OFF_T
1999-12-13 13:27:58 +00:00
# if (defined(HAVE_EXPLICIT_LARGEFILE_SUPPORT) && defined(HAVE_OFF64_T)) || (defined(SIZEOF_OFF_T) && (SIZEOF_OFF_T == 8))
1998-09-04 00:23:28 +00:00
# define LARGE_SMB_OFF_T 1
# endif
1998-09-03 18:40:31 +00:00
# endif
1998-09-18 18:30:42 +00:00
# ifdef LARGE_SMB_OFF_T
# define SOFF_T(p, ofs, v) (SIVAL(p,ofs,(v)&0xFFFFFFFF), SIVAL(p,(ofs)+4,(v)>>32))
2001-04-18 04:33:24 +00:00
# define SOFF_T_R(p, ofs, v) (SIVAL(p,(ofs)+4,(v)&0xFFFFFFFF), SIVAL(p,ofs,(v)>>32))
2008-10-14 01:59:36 +02:00
# define IVAL_TO_SMB_OFF_T(buf,off) ((SMB_OFF_T)(( ((uint64_t)(IVAL((buf),(off)))) & ((uint64_t)0xFFFFFFFF) )))
1998-09-18 18:30:42 +00:00
# else
# define SOFF_T(p, ofs, v) (SIVAL(p,ofs,v),SIVAL(p,(ofs)+4,0))
2001-04-18 04:33:24 +00:00
# define SOFF_T_R(p, ofs, v) (SIVAL(p,(ofs)+4,v),SIVAL(p,ofs,0))
2002-12-03 08:02:41 +00:00
# define IVAL_TO_SMB_OFF_T(buf,off) ((SMB_OFF_T)(( ((uint32)(IVAL((buf),(off)))) & 0xFFFFFFFF )))
1998-09-18 18:30:42 +00:00
# endif
2009-05-26 23:37:14 +02:00
# ifndef HAVE_BLKSIZE_T
/* This is mainly for HP/UX which defines st_blksize as long */
2009-05-27 08:09:23 +02:00
typedef long blksize_t ;
2009-05-26 23:37:14 +02:00
# endif
# ifndef HAVE_BLKCNT_T
/* This is mainly for HP/UX which doesn't have blkcnt_t */
2009-05-27 08:09:23 +02:00
typedef long blkcnt_t ;
2009-05-26 23:37:14 +02:00
# endif
1998-09-01 20:11:54 +00:00
/*
1998-09-03 18:40:31 +00:00
* Type for stat structure .
1998-09-01 20:11:54 +00:00
*/
2009-05-14 15:34:42 +02:00
struct stat_ex {
dev_t st_ex_dev ;
ino_t st_ex_ino ;
mode_t st_ex_mode ;
nlink_t st_ex_nlink ;
uid_t st_ex_uid ;
gid_t st_ex_gid ;
dev_t st_ex_rdev ;
off_t st_ex_size ;
struct timespec st_ex_atime ;
struct timespec st_ex_mtime ;
struct timespec st_ex_ctime ;
struct timespec st_ex_btime ; /* birthtime */
2009-07-08 17:51:35 -07:00
/* Is birthtime real, or was it calculated ? */
bool st_ex_calculated_birthtime ;
2009-05-14 15:34:42 +02:00
blksize_t st_ex_blksize ;
blkcnt_t st_ex_blocks ;
2009-05-26 22:39:50 +02:00
uint32_t st_ex_flags ;
uint32_t st_ex_mask ;
2009-05-14 15:34:42 +02:00
/*
* Add space for VFS internal extensions . The initial user of this
* would be the onefs modules , passing the snapid from the stat calls
* to the file_id_create call . Maybe we ' ll have to expand this later ,
* but the core of Samba should never look at this field .
*/
uint64_t vfs_private ;
} ;
typedef struct stat_ex SMB_STRUCT_STAT ;
1998-09-04 00:23:28 +00:00
1999-12-13 13:27:58 +00:00
/*
* Type for dirent structure .
*/
# ifndef SMB_STRUCT_DIRENT
# if defined(HAVE_EXPLICIT_LARGEFILE_SUPPORT) && defined(HAVE_STRUCT_DIRENT64)
# define SMB_STRUCT_DIRENT struct dirent64
# else
# define SMB_STRUCT_DIRENT struct dirent
# endif
# endif
2005-08-22 18:03:08 +00:00
/*
* Type for DIR structure .
*/
# ifndef SMB_STRUCT_DIR
# if defined(HAVE_EXPLICIT_LARGEFILE_SUPPORT) && defined(HAVE_STRUCT_DIR64)
# define SMB_STRUCT_DIR DIR64
# else
# define SMB_STRUCT_DIR DIR
# endif
# endif
1998-09-04 00:23:28 +00:00
/*
* Defines for 64 bit fcntl locks .
*/
# ifndef SMB_STRUCT_FLOCK
1999-12-13 13:27:58 +00:00
# if defined(HAVE_EXPLICIT_LARGEFILE_SUPPORT) && defined(HAVE_STRUCT_FLOCK64) && defined(HAVE_OFF64_T)
1998-09-04 00:23:28 +00:00
# define SMB_STRUCT_FLOCK struct flock64
# else
# define SMB_STRUCT_FLOCK struct flock
# endif
# endif
# ifndef SMB_F_SETLKW
1999-12-13 13:27:58 +00:00
# if defined(HAVE_EXPLICIT_LARGEFILE_SUPPORT) && defined(HAVE_STRUCT_FLOCK64) && defined(HAVE_OFF64_T)
1998-09-04 00:23:28 +00:00
# define SMB_F_SETLKW F_SETLKW64
# else
# define SMB_F_SETLKW F_SETLKW
# endif
1998-09-01 20:11:54 +00:00
# endif
1998-09-04 00:23:28 +00:00
# ifndef SMB_F_SETLK
1999-12-13 13:27:58 +00:00
# if defined(HAVE_EXPLICIT_LARGEFILE_SUPPORT) && defined(HAVE_STRUCT_FLOCK64) && defined(HAVE_OFF64_T)
1998-09-04 00:23:28 +00:00
# define SMB_F_SETLK F_SETLK64
# else
# define SMB_F_SETLK F_SETLK
# endif
# endif
# ifndef SMB_F_GETLK
1999-12-13 13:27:58 +00:00
# if defined(HAVE_EXPLICIT_LARGEFILE_SUPPORT) && defined(HAVE_STRUCT_FLOCK64) && defined(HAVE_OFF64_T)
1998-09-04 00:23:28 +00:00
# define SMB_F_GETLK F_GETLK64
# else
# define SMB_F_GETLK F_GETLK
# endif
1998-09-03 18:40:31 +00:00
# endif
1998-09-01 20:11:54 +00:00
2005-06-27 22:08:58 +00:00
/*
* Type for aiocb structure .
*/
# ifndef SMB_STRUCT_AIOCB
# if defined(WITH_AIO)
# if defined(HAVE_EXPLICIT_LARGEFILE_SUPPORT) && defined(HAVE_AIOCB64)
# define SMB_STRUCT_AIOCB struct aiocb64
# else
# define SMB_STRUCT_AIOCB struct aiocb
# endif
# else
# define SMB_STRUCT_AIOCB int /* AIO not being used but we still need the define.... */
# endif
# endif
# ifndef HAVE_STRUCT_TIMESPEC
struct timespec {
time_t tv_sec ; /* Seconds. */
long tv_nsec ; /* Nanoseconds. */
} ;
# endif
2009-08-24 20:57:37 -07:00
enum timestamp_set_resolution {
TIMESTAMP_SET_SECONDS = 0 ,
TIMESTAMP_SET_MSEC ,
TIMESTAMP_SET_NT_OR_BETTER
} ;
1998-07-29 05:05:36 +00:00
# ifdef HAVE_BROKEN_GETGROUPS
# define GID_T int
# else
# define GID_T gid_t
# endif
2000-02-15 19:36:47 +00:00
# ifndef NGROUPS_MAX
# define NGROUPS_MAX 32 /* Guess... */
# endif
1998-07-29 03:08:05 +00:00
2007-12-07 12:02:44 -08:00
/* Our own fstrings */
2007-12-07 14:54:38 -08:00
/*
- - - - - - - - - - - - - -
/ \
/ REST \
/ IN \
/ PEACE \
/ \
| The infamous pstring |
| |
| |
| 7 December |
| |
| 2007 |
* | * * * | *
_________ ) / \ \ _ //(\/(/\)/\//\/\///|_)_______
*/
2007-12-07 17:44:42 -08:00
# ifndef FSTRING_LEN
2007-12-07 12:02:44 -08:00
# define FSTRING_LEN 256
typedef char fstring [ FSTRING_LEN ] ;
2007-12-07 17:44:42 -08:00
# endif
2002-03-02 05:35:10 +00:00
2008-10-15 00:35:13 +02:00
/* Samba 3 doesn't use iconv_convenience: */
extern void * cmdline_lp_ctx ;
struct smb_iconv_convenience * lp_iconv_convenience ( void * lp_ctx ) ;
2000-05-09 13:28:19 +00:00
/* Lists, trees, caching, database... */
2008-11-01 03:14:43 +01:00
# include "../lib/util/util.h"
2008-10-12 16:19:15 +02:00
# include "../lib/util/xfile.h"
2008-10-18 14:07:51 +02:00
# include "../lib/util/memory.h"
2008-10-18 18:50:37 +02:00
# include "../lib/util/attr.h"
2001-10-14 12:10:29 +00:00
# include "intl.h"
2008-10-11 21:48:00 +02:00
# include "../lib/util/dlinklist.h"
2006-08-18 16:25:09 +00:00
# include "tdb.h"
2006-10-20 23:46:59 +00:00
# include "util_tdb.h"
2005-06-08 22:10:34 +00:00
2008-09-16 14:36:41 +02:00
# include "../talloc/talloc.h"
2008-10-11 23:57:44 +02:00
2009-01-05 09:06:05 +01:00
# include "event.h"
2009-02-26 12:34:14 +01:00
# include "../lib/util/tevent_unix.h"
# include "../lib/util/tevent_ntstatus.h"
2009-06-27 17:21:19 +02:00
# include "../lib/tsocket/tsocket.h"
2009-01-05 09:06:05 +01:00
2008-10-12 01:46:15 +02:00
# include "../lib/util/data_blob.h"
2008-10-11 23:57:44 +02:00
# include "../lib/util/time.h"
2008-10-22 14:06:08 +02:00
# include "../lib/util/asn1.h"
2001-11-20 08:54:15 +00:00
# include "ads.h"
2006-05-05 19:24:48 +00:00
# include "ads_dns.h"
1999-12-13 13:27:58 +00:00
# include "interfaces.h"
2000-04-25 14:06:57 +00:00
# include "trans2.h"
2008-10-23 15:35:21 +02:00
# include "../libcli/util/error.h"
2002-08-17 17:00:51 +00:00
# include "ntioctl.h"
2009-03-01 22:31:10 +01:00
# include "../lib/util/charset/charset.h"
2001-11-19 02:49:53 +00:00
# include "dynconfig.h"
2001-05-29 07:34:01 +00:00
# include "util_getent.h"
1999-12-13 13:27:58 +00:00
# include "debugparse.h"
2005-01-13 18:20:37 +00:00
# include "privileges.h"
2007-05-21 22:17:13 +00:00
# include "messages.h"
2006-07-17 21:09:02 +00:00
# include "locking.h"
2009-02-08 23:10:34 -08:00
# include "smb_perfcount.h"
2009-03-09 08:42:05 +01:00
# include "smb_signing.h"
1996-05-04 07:50:46 +00:00
# include "smb.h"
1996-06-04 06:42:03 +00:00
# include "nameserv.h"
2002-03-01 02:56:35 +00:00
# include "secrets.h"
2008-10-12 16:17:21 +02:00
# include "../lib/util/byteorder.h"
2003-05-12 18:12:31 +00:00
# include "privileges.h"
2005-09-30 17:13:37 +00:00
# include "rpc_misc.h"
# include "rpc_dce.h"
2003-05-12 18:12:31 +00:00
# include "mapping.h"
# include "passdb.h"
# include "rpc_secdes.h"
2009-03-01 02:13:21 +01:00
# include "../libgpo/gpo.h"
2005-09-30 17:13:37 +00:00
# include "authdata.h"
2000-03-09 21:45:16 +00:00
# include "msdfs.h"
2001-10-19 16:46:34 +00:00
# include "rap.h"
2008-09-24 15:34:30 +02:00
# include "../lib/crypto/md5.h"
2008-11-01 03:14:43 +01:00
# include "../lib/crypto/md4.h"
2008-09-24 16:04:43 +02:00
# include "../lib/crypto/arcfour.h"
2008-09-24 16:46:02 +02:00
# include "../lib/crypto/crc32.h"
2008-09-24 15:44:34 +02:00
# include "../lib/crypto/hmacmd5.h"
2003-01-15 18:57:41 +00:00
# include "ntlmssp.h"
This is my 'Authentication Rewrite' version 1.01, mostly as submitted to
samba-technical a few weeks ago.
The idea here is to standardize the checking of user names and passwords,
thereby ensuring that all authtentications pass the same standards. The
interface currently implemented in as
nt_status = check_password(user_info, server_info)
where user_info contains (mostly) the authentication data, and server_info
contains things like the user-id they got, and their resolved user name.
The current ugliness with the way the structures are created will be killed
the next revision, when they will be created and malloced by creator functions.
This patch also includes the first implementation of NTLMv2 in HEAD, but which
needs some more testing. We also add a hack to allow plaintext passwords to be
compared with smbpasswd, not the system password database.
Finally, this patch probably reintroduces the PAM accounts bug we had in
2.2.0, I'll fix that once this hits the tree. (I've just finished testing
it on a wide variety of platforms, so I want to get this patch in).
(This used to be commit b30b6202f31d339b48d51c0d38174cafd1cfcd42)
2001-08-03 13:09:23 +00:00
# include "auth.h"
2005-09-30 17:13:37 +00:00
# include "ntdomain.h"
# include "reg_objects.h"
2007-06-15 21:38:10 +00:00
# include "reg_db.h"
2005-09-30 17:13:37 +00:00
# include "rpc_perfcount.h"
# include "rpc_perfcount_defs.h"
2007-01-31 11:48:14 +00:00
# include "librpc/gen_ndr/notify.h"
2008-01-19 13:37:40 +01:00
# include "librpc/gen_ndr/xattr.h"
2008-09-04 15:13:22 +02:00
# include "librpc/gen_ndr/messaging.h"
2008-09-23 22:21:52 +02:00
# include "librpc/gen_ndr/ndr_nbt.h"
2008-04-15 17:55:44 +02:00
# include "librpc/rpc/dcerpc.h"
2005-09-30 17:13:37 +00:00
# include "nt_printing.h"
2003-05-12 18:12:31 +00:00
# include "idmap.h"
# include "client.h"
2001-08-22 19:11:55 +00:00
# include "session.h"
2001-10-23 14:16:22 +00:00
# include "popt.h"
2002-04-11 02:20:56 +00:00
# include "mangle.h"
2003-05-06 02:34:59 +00:00
# include "module.h"
2002-09-25 15:19:00 +00:00
# include "nsswitch/winbind_client.h"
2003-07-29 15:00:38 +00:00
# include "spnego.h"
2005-09-30 17:13:37 +00:00
# include "rpc_client.h"
r22775: For the cluster code I've developed a wrapper around tdb to put different
database backends in place dynamically.
The main abstractions are db_context and db_record, it should be mainly
self-describing, see include/dbwrap.h. You open the db just as you would open
a tdb, this time with db_open(). If you want to fetch a record, just do the
db->fetch() call, if you want to do operations on it, you need to get it with
fetch_locked().
I added dbwrap_file.c (not heavily tested lately) as an example for what can
be done with that abstraction, uses a file per key. So if anybody is willing
to shape that up, we might have a chance on reiserfs again.... :-)
This abstraction works fine for brlock.tdb, locking.tdb, connections.tdb and
sessionid.tdb. It should work fine for the others as well, I just did not yet
get around to convert them.
If nobody loudly screams NO, then I will import the code that uses this soon.
Volker
(This used to be commit e9d7484ca246cfca4a1fd23be35edc2783136ebe)
2007-05-10 10:42:13 +00:00
# include "dbwrap.h"
2007-06-10 17:02:09 +00:00
# include "packet.h"
# include "ctdbd_conn.h"
2008-10-23 17:27:30 +02:00
# include "../lib/util/talloc_stack.h"
2007-12-19 15:45:22 +01:00
# include "memcache.h"
2008-02-28 14:41:25 +01:00
# include "async_smb.h"
2009-01-24 10:00:13 +01:00
# include "../lib/async_req/async_sock.h"
2009-08-16 10:44:06 +02:00
# include "talloc_dict.h"
2008-10-23 20:43:11 +02:00
# include "services.h"
2008-11-19 23:44:07 +01:00
# include "eventlog.h"
2009-04-10 14:45:45 -07:00
# include "../lib/util/smb_threads.h"
# include "../lib/util/smb_threads_internal.h"
2009-06-06 12:30:57 +02:00
# include "tldap.h"
2009-06-06 12:32:46 +02:00
# include "tldap_util.h"
2006-02-03 22:19:41 +00:00
2008-03-17 17:29:44 +01:00
# include "lib/smbconf/smbconf.h"
2009-01-21 16:59:09 +01:00
# include "lib/smbconf/smbconf_init.h"
# include "lib/smbconf/smbconf_reg.h"
# include "lib/smbconf/smbconf_txt.h"
2008-03-17 17:29:44 +01:00
1999-12-23 01:57:43 +00:00
/* Defines for wisXXX functions. */
# define UNI_UPPER 0x1
# define UNI_LOWER 0x2
# define UNI_DIGIT 0x4
# define UNI_XDIGIT 0x8
# define UNI_SPACE 0x10
2003-04-02 06:16:15 +00:00
# include "nsswitch/winbind_nss.h"
2000-07-10 06:41:04 +00:00
2002-09-25 15:19:00 +00:00
/* forward declaration from printing.h to get around
header file dependencies */
struct printjob ;
2003-06-05 02:34:30 +00:00
/* forward declarations from smbldap.c */
# include "smbldap.h"
2006-05-05 07:15:45 +00:00
/*
* Reasons for cache flush .
*/
enum flush_reason_enum {
SEEK_FLUSH ,
READ_FLUSH ,
WRITE_FLUSH ,
READRAW_FLUSH ,
OPLOCK_RELEASE_FLUSH ,
CLOSE_FLUSH ,
SYNC_FLUSH ,
SIZECHANGE_FLUSH ,
/* NUM_FLUSH_REASONS must remain the last value in the enumeration. */
NUM_FLUSH_REASONS } ;
2007-01-24 01:48:08 +00:00
# include "nss_info.h"
2008-06-12 12:36:15 +02:00
# include "modules/nfs4_acls.h"
2007-12-21 11:59:56 -06:00
# include "nsswitch/libwbclient/wbclient.h"
2007-01-24 01:48:08 +00:00
2008-11-02 17:29:39 +01:00
/***** prototypes *****/
2003-03-28 02:03:31 +00:00
# ifndef NO_PROTO_H
1997-10-30 15:42:40 +00:00
# include "proto.h"
2003-03-28 02:03:31 +00:00
# endif
2009-03-01 20:06:55 +01:00
# include "libcli/security/secace.h"
# include "libcli/security/secacl.h"
2009-04-21 14:27:25 +02:00
# include "libcli/security/security_descriptor.h"
1997-10-30 15:42:40 +00:00
2008-08-13 15:28:38 +02:00
# if defined(HAVE_POSIX_ACLS)
# include "modules/vfs_posixacl.h"
# endif
2008-08-13 15:31:53 +02:00
# if defined(HAVE_TRU64_ACLS)
# include "modules/vfs_tru64acl.h"
# endif
2008-08-13 15:56:44 +02:00
# if defined(HAVE_SOLARIS_ACLS) || defined(HAVE_UNIXWARE_ACLS)
# include "modules/vfs_solarisacl.h"
# endif
2008-08-13 15:58:06 +02:00
# if defined(HAVE_HPUX_ACLS)
# include "modules/vfs_hpuxacl.h"
# endif
2008-08-13 15:59:14 +02:00
# if defined(HAVE_IRIX_ACLS)
# include "modules/vfs_irixacl.h"
# endif
2006-09-03 21:31:51 +00:00
# ifdef HAVE_LDAP
2006-09-03 21:07:16 +00:00
# include "ads_protos.h"
# endif
2006-05-05 07:15:45 +00:00
/* We need this after proto.h to reference GetTimeOfDay(). */
# include "smbprofile.h"
2000-02-03 04:47:50 +00:00
/* String routines */
2003-03-18 11:22:52 +00:00
# include "srvstr.h"
2000-02-03 04:47:50 +00:00
# include "safe_string.h"
1999-12-23 01:57:43 +00:00
2008-01-10 14:27:52 +01:00
/* prototypes from lib/util_transfer_file.c */
# include "transfer_file.h"
1998-07-29 03:08:05 +00:00
# ifndef DEFAULT_PRINTING
2001-08-23 19:06:20 +00:00
# ifdef HAVE_CUPS
1999-12-13 13:27:58 +00:00
# define DEFAULT_PRINTING PRINT_CUPS
# define PRINTCAP_NAME "cups"
# elif defined(SYSV)
1998-07-29 03:08:05 +00:00
# define DEFAULT_PRINTING PRINT_SYSV
1998-11-17 00:31:39 +00:00
# define PRINTCAP_NAME "lpstat"
1998-07-29 03:08:05 +00:00
# else
# define DEFAULT_PRINTING PRINT_BSD
1998-11-17 00:31:39 +00:00
# define PRINTCAP_NAME " / etc / printcap"
1996-05-04 07:50:46 +00:00
# endif
# endif
1998-11-25 21:17:20 +00:00
# ifndef PRINTCAP_NAME
# define PRINTCAP_NAME " / etc / printcap"
# endif
1998-07-29 03:08:05 +00:00
# ifndef SIGCLD
# define SIGCLD SIGCHLD
1996-05-04 07:50:46 +00:00
# endif
2003-03-28 01:07:05 +00:00
# ifndef SIGRTMIN
2009-06-07 13:58:38 +00:00
# define SIGRTMIN NSIG
2003-03-28 01:07:05 +00:00
# endif
1998-07-29 03:08:05 +00:00
# ifndef MAP_FILE
# define MAP_FILE 0
1996-05-04 07:50:46 +00:00
# endif
1998-07-29 03:08:05 +00:00
# if defined(HAVE_PUTPRPWNAM) && defined(AUTH_CLEARTEXT_SEG_CHARS)
# define OSF1_ENH_SEC 1
1996-05-04 07:50:46 +00:00
# endif
1998-07-29 03:08:05 +00:00
# ifndef ALLOW_CHANGE_PASSWORD
# if (defined(HAVE_TERMIOS_H) && defined(HAVE_DUP2) && defined(HAVE_SETSID))
# define ALLOW_CHANGE_PASSWORD 1
# endif
1996-10-05 02:54:37 +00:00
# endif
1998-07-29 03:08:05 +00:00
/* what is the longest significant password available on your system?
Knowing this speeds up password searches a lot */
# ifndef PASSWORD_LENGTH
# define PASSWORD_LENGTH 8
1996-05-04 07:50:46 +00:00
# endif
1998-07-29 03:08:05 +00:00
# ifndef HAVE_PIPE
# define SYNC_DNS 1
1996-05-04 07:50:46 +00:00
# endif
1998-07-29 03:08:05 +00:00
# if defined(HAVE_CRYPT16) && defined(HAVE_GETAUTHUID)
# define ULTRIX_AUTH 1
# endif
1996-05-04 07:50:46 +00:00
1998-10-07 07:55:14 +00:00
/* yuck, I'd like a better way of doing this */
# define DIRP_SIZE (256 + 32)
1999-12-13 13:27:58 +00:00
/* default socket options. Dave Miller thinks we should default to TCP_NODELAY
given the socket IO pattern that Samba uses */
# ifdef TCP_NODELAY
# define DEFAULT_SOCKET_OPTIONS "TCP_NODELAY"
# else
# define DEFAULT_SOCKET_OPTIONS ""
# endif
2001-12-20 04:01:44 +00:00
/* dmalloc -- free heap debugger (dmalloc.org). This should be near
* the * bottom * of include files so as not to conflict . */
2002-01-09 05:10:47 +00:00
# ifdef ENABLE_DMALLOC
2001-12-20 04:01:44 +00:00
# include <dmalloc.h>
# endif
2000-06-15 09:35:37 +00:00
# if HAVE_KERNEL_SHARE_MODES
# ifndef LOCK_MAND
# define LOCK_MAND 32 /* This is a mandatory flock */
# define LOCK_READ 64 /* ... Which allows concurrent read operations */
# define LOCK_WRITE 128 /* ... Which allows concurrent write operations */
# define LOCK_RW 192 /* ... Which allows concurrent read & write ops */
# endif
# endif
2000-04-25 14:06:57 +00:00
extern int DEBUGLEVEL ;
2000-06-23 06:19:26 +00:00
# define MAX_SEC_CTX_DEPTH 8 /* Maximum number of security contexts */
2000-09-29 04:45:00 +00:00
# ifdef GLIBC_HACK_FCNTL64
/* this is a gross hack. 64 bit locking is completely screwed up on
i386 Linux in glibc 2.1 .95 ( which ships with RedHat 7.0 ) . This hack
" fixes " the problem with the current 2.4 .0 test kernels
*/
# define fcntl fcntl64
# undef F_SETLKW
# undef F_SETLK
# define F_SETLK 13
# define F_SETLKW 14
# endif
2001-07-04 07:15:53 +00:00
2001-07-22 10:50:21 +00:00
/* needed for some systems without iconv. Doesn't really matter
what error code we use */
2001-07-22 07:38:32 +00:00
# ifndef EILSEQ
2001-07-22 10:50:21 +00:00
# define EILSEQ EIO
2001-07-22 07:38:32 +00:00
# endif
2001-04-28 13:49:34 +00:00
/* add varargs prototypes with printf checking */
2005-08-26 03:23:48 +00:00
/*PRINTFLIKE2 */
2001-09-09 02:37:10 +00:00
int fdprintf ( int , const char * , . . . ) PRINTF_ATTRIBUTE ( 2 , 3 ) ;
2005-08-26 03:23:48 +00:00
/*PRINTFLIKE1 */
2001-09-09 02:37:10 +00:00
int d_printf ( const char * , . . . ) PRINTF_ATTRIBUTE ( 1 , 2 ) ;
2005-08-26 03:23:48 +00:00
/*PRINTFLIKE2 */
2001-09-09 02:37:10 +00:00
int d_fprintf ( FILE * f , const char * , . . . ) PRINTF_ATTRIBUTE ( 2 , 3 ) ;
2003-07-23 03:59:57 +00:00
2005-08-26 03:23:48 +00:00
/* PRINTFLIKE2 */
2003-01-03 03:24:23 +00:00
void sys_adminlog ( int priority , const char * format_str , . . . ) PRINTF_ATTRIBUTE ( 2 , 3 ) ;
2005-08-26 03:23:48 +00:00
/* PRINTFLIKE2 */
2003-01-03 03:24:23 +00:00
int fstr_sprintf ( fstring s , const char * fmt , . . . ) PRINTF_ATTRIBUTE ( 2 , 3 ) ;
int d_vfprintf ( FILE * f , const char * format , va_list ap ) PRINTF_ATTRIBUTE ( 2 , 0 ) ;
int smb_xvasprintf ( char * * ptr , const char * format , va_list ap ) PRINTF_ATTRIBUTE ( 2 , 0 ) ;
2007-11-24 17:27:54 +01:00
int asprintf_strupper_m ( char * * strp , const char * fmt , . . . ) PRINTF_ATTRIBUTE ( 2 , 3 ) ;
char * talloc_asprintf_strupper_m ( TALLOC_CTX * t , const char * fmt , . . . ) PRINTF_ATTRIBUTE ( 2 , 3 ) ;
2002-12-30 23:55:53 +00:00
/*
* Veritas File System . Often in addition to native .
* Quotas different .
*/
# if defined(HAVE_SYS_FS_VX_QUOTA_H)
# define VXFS_QUOTA
# endif
2008-01-20 00:44:14 +01:00
# ifndef XATTR_CREATE
# define XATTR_CREATE 0x1 /* set value, fail if attr already exists */
# endif
# ifndef XATTR_REPLACE
# define XATTR_REPLACE 0x2 /* set value, fail if attr does not exist */
# endif
2009-01-15 17:02:41 -08:00
/*
* This should be under the HAVE_KRB5 flag but since they ' re used
* in lp_kerberos_method ( ) , they ned to be always available
*/
# define KERBEROS_VERIFY_SECRETS 0
# define KERBEROS_VERIFY_SYSTEM_KEYTAB 1
# define KERBEROS_VERIFY_DEDICATED_KEYTAB 2
# define KERBEROS_VERIFY_SECRETS_AND_KEYTAB 3
2003-01-19 22:27:32 +00:00
2009-01-15 17:02:41 -08:00
/*
* If you add any entries to the above , please modify the below expressions
* so they remain accurate .
*/
# define USE_KERBEROS_KEYTAB (KERBEROS_VERIFY_SECRETS != lp_kerberos_method())
# define USE_SYSTEM_KEYTAB \
( ( KERBEROS_VERIFY_SECRETS_AND_KEYTAB = = lp_kerberos_method ( ) ) | | \
( KERBEROS_VERIFY_SYSTEM_KEYTAB = = lp_kerberos_method ( ) ) )
# if defined(HAVE_KRB5)
2006-04-24 16:29:55 +00:00
krb5_error_code smb_krb5_parse_name ( krb5_context context ,
const char * name , /* in unix charset */
krb5_principal * principal ) ;
2009-03-18 16:23:27 +11:00
krb5_error_code smb_krb5_unparse_name ( TALLOC_CTX * mem_ctx ,
krb5_context context ,
krb5_const_principal principal ,
char * * unix_name ) ;
2006-04-24 16:29:55 +00:00
2003-08-15 19:29:08 +00:00
# ifndef HAVE_KRB5_SET_REAL_TIME
2003-01-19 22:27:32 +00:00
krb5_error_code krb5_set_real_time ( krb5_context context , int32_t seconds , int32_t microseconds ) ;
# endif
krb5_error_code krb5_set_default_tgs_ktypes ( krb5_context ctx , const krb5_enctype * enc ) ;
2003-01-30 20:36:44 +00:00
# if defined(HAVE_KRB5_AUTH_CON_SETKEY) && !defined(HAVE_KRB5_AUTH_CON_SETUSERUSERKEY)
krb5_error_code krb5_auth_con_setuseruserkey ( krb5_context context , krb5_auth_context auth_context , krb5_keyblock * keyblock ) ;
# endif
2004-06-19 00:56:50 +00:00
# ifndef HAVE_KRB5_FREE_UNPARSED_NAME
void krb5_free_unparsed_name ( krb5_context ctx , char * val ) ;
2004-06-19 00:54:54 +00:00
# endif
2006-10-13 23:43:27 +00:00
/* Stub out initialize_krb5_error_table since it is not present in all
* Kerberos implementations . If it ' s not present , it ' s not necessary to
* call it .
*/
# ifndef HAVE_INITIALIZE_KRB5_ERROR_TABLE
# define initialize_krb5_error_table()
# endif
2003-01-30 04:40:12 +00:00
/* Samba wrapper function for krb5 functionality. */
2007-10-29 15:03:36 -07:00
bool setup_kaddr ( krb5_address * pkaddr , struct sockaddr_storage * paddr ) ;
2008-06-18 12:45:57 +02:00
int create_kerberos_key_from_string ( krb5_context context , krb5_principal host_princ , krb5_data * password , krb5_keyblock * key , krb5_enctype enctype , bool no_salt ) ;
2007-10-18 17:40:25 -07:00
bool get_auth_data_from_tkt ( TALLOC_CTX * mem_ctx , DATA_BLOB * auth_data , krb5_ticket * tkt ) ;
2003-01-30 20:36:44 +00:00
krb5_const_principal get_principal_from_tkt ( krb5_ticket * tkt ) ;
2007-03-28 19:47:59 +00:00
krb5_error_code smb_krb5_locate_kdc ( krb5_context ctx , const krb5_data * realm , struct sockaddr * * addr_pp , int * naddrs , int get_masters ) ;
# if defined(HAVE_KRB5_LOCATE_KDC)
2003-01-30 20:36:44 +00:00
krb5_error_code krb5_locate_kdc ( krb5_context ctx , const krb5_data * realm , struct sockaddr * * addr_pp , int * naddrs , int get_masters ) ;
2007-03-28 19:47:59 +00:00
# endif
2003-02-19 15:48:12 +00:00
krb5_error_code get_kerberos_allowed_etypes ( krb5_context context , krb5_enctype * * enctypes ) ;
2007-10-18 17:40:25 -07:00
bool get_krb5_smb_session_key ( krb5_context context , krb5_auth_context auth_context , DATA_BLOB * session_key , bool remote ) ;
2004-08-11 09:34:30 +00:00
krb5_error_code smb_krb5_kt_free_entry ( krb5_context context , krb5_keytab_entry * kt_entry ) ;
2004-11-01 18:44:15 +00:00
krb5_principal kerberos_fetch_salt_princ_for_host_princ ( krb5_context context , krb5_principal host_princ , int enctype ) ;
2004-11-03 00:29:09 +00:00
void kerberos_set_creds_enctype ( krb5_creds * pcreds , int enctype ) ;
2007-10-18 17:40:25 -07:00
bool kerberos_compatible_enctypes ( krb5_context context , krb5_enctype enctype1 , krb5_enctype enctype2 ) ;
2004-11-03 00:29:09 +00:00
void kerberos_free_data_contents ( krb5_context context , krb5_data * pdata ) ;
2005-10-01 09:43:53 +00:00
NTSTATUS decode_pac_data ( TALLOC_CTX * mem_ctx ,
DATA_BLOB * pac_data_blob ,
2008-02-17 01:59:02 +01:00
krb5_context context ,
2005-10-01 09:43:53 +00:00
krb5_keyblock * service_keyblock ,
krb5_const_principal client_principal ,
time_t tgs_authtime ,
2008-02-17 01:59:02 +01:00
struct PAC_DATA * * pac_data_out ) ;
2005-10-01 09:43:53 +00:00
void smb_krb5_checksum_from_pac_sig ( krb5_checksum * cksum ,
2008-02-17 01:59:02 +01:00
struct PAC_SIGNATURE_DATA * sig ) ;
2005-10-01 09:43:53 +00:00
krb5_error_code smb_krb5_verify_checksum ( krb5_context context ,
2008-02-17 01:59:02 +01:00
const krb5_keyblock * keyblock ,
2005-10-01 09:43:53 +00:00
krb5_keyusage usage ,
krb5_checksum * cksum ,
uint8 * data ,
size_t length ) ;
time_t get_authtime_from_tkt ( krb5_ticket * tkt ) ;
void smb_krb5_free_ap_req ( krb5_context context ,
krb5_ap_req * ap_req ) ;
krb5_error_code smb_krb5_get_keyinfo_from_ap_req ( krb5_context context ,
const krb5_data * inbuf ,
krb5_kvno * kvno ,
krb5_enctype * enctype ) ;
krb5_error_code krb5_rd_req_return_keyblock_from_keytab ( krb5_context context ,
krb5_auth_context * auth_context ,
const krb5_data * inbuf ,
krb5_const_principal server ,
krb5_keytab keytab ,
krb5_flags * ap_req_options ,
krb5_ticket * * ticket ,
krb5_keyblock * * keyblock ) ;
krb5_error_code smb_krb5_parse_name_norealm ( krb5_context context ,
const char * name ,
krb5_principal * principal ) ;
2007-10-18 17:40:25 -07:00
bool smb_krb5_principal_compare_any_realm ( krb5_context context ,
2005-10-01 09:43:53 +00:00
krb5_const_principal princ1 ,
krb5_const_principal princ2 ) ;
int cli_krb5_get_ticket ( const char * principal , time_t time_offset ,
2007-02-08 17:02:39 +00:00
DATA_BLOB * ticket , DATA_BLOB * session_key_krb5 , uint32 extra_ap_opts , const char * ccname , time_t * tgs_expire ) ;
2007-06-22 11:20:37 +00:00
krb5_error_code smb_krb5_renew_ticket ( const char * ccache_string , const char * client_string , const char * service_string , time_t * expire_time ) ;
2006-02-03 22:19:41 +00:00
krb5_error_code kpasswd_err_to_krb5_err ( krb5_error_code res_code ) ;
2006-04-25 12:24:25 +00:00
krb5_error_code smb_krb5_gen_netbios_krb5_address ( smb_krb5_addresses * * kerb_addr ) ;
krb5_error_code smb_krb5_free_addresses ( krb5_context context , smb_krb5_addresses * addr ) ;
2006-03-09 14:51:40 +00:00
NTSTATUS krb5_to_nt_status ( krb5_error_code kerberos_error ) ;
krb5_error_code nt_status_to_krb5 ( NTSTATUS nt_status ) ;
2006-06-15 21:45:10 +00:00
void smb_krb5_free_error ( krb5_context context , krb5_error * krberror ) ;
krb5_error_code handle_krberror_packet ( krb5_context context ,
krb5_data * packet ) ;
2007-03-09 18:51:48 +00:00
void smb_krb5_get_init_creds_opt_free ( krb5_context context ,
krb5_get_init_creds_opt * opt ) ;
krb5_error_code smb_krb5_get_init_creds_opt_alloc ( krb5_context context ,
krb5_get_init_creds_opt * * opt ) ;
2007-03-15 19:18:18 +00:00
krb5_error_code smb_krb5_mk_error ( krb5_context context ,
krb5_error_code error_code ,
const krb5_principal server ,
krb5_data * reply ) ;
2008-08-22 14:58:01 +02:00
krb5_enctype smb_get_enctype_from_kt_entry ( krb5_keytab_entry * kt_entry ) ;
2007-04-23 08:40:54 +00:00
krb5_error_code smb_krb5_enctype_to_string ( krb5_context context ,
krb5_enctype enctype ,
char * * etype_s ) ;
2007-06-29 08:56:35 +00:00
krb5_error_code smb_krb5_open_keytab ( krb5_context context ,
const char * keytab_name ,
2007-10-18 17:40:25 -07:00
bool write_access ,
2007-06-29 08:56:35 +00:00
krb5_keytab * keytab ) ;
2008-06-18 12:48:35 +02:00
krb5_error_code smb_krb5_keytab_name ( TALLOC_CTX * mem_ctx ,
krb5_context context ,
krb5_keytab keytab ,
const char * * keytab_name ) ;
2008-06-30 10:29:15 +02:00
int smb_krb5_kt_add_entry_ext ( krb5_context context ,
krb5_keytab keytab ,
krb5_kvno kvno ,
const char * princ_s ,
krb5_enctype * enctypes ,
krb5_data password ,
2008-06-30 10:32:15 +02:00
bool no_salt ,
bool keep_old_entries ) ;
2008-06-30 10:29:15 +02:00
2003-01-19 22:27:32 +00:00
# endif /* HAVE_KRB5 */
2004-07-14 13:32:30 +00:00
# ifdef HAVE_LDAP
/* function declarations not included in proto.h */
LDAP * ldap_open_with_timeout ( const char * server , int port , unsigned int to ) ;
# endif /* HAVE_LDAP */
2007-06-02 08:30:42 +00:00
# if defined(HAVE_LINUX_READAHEAD) && ! defined(HAVE_READAHEAD_DECL)
ssize_t readahead ( int fd , off64_t offset , size_t count ) ;
# endif
2004-07-14 13:32:30 +00:00
2003-04-14 01:19:58 +00:00
# ifdef TRUE
# undef TRUE
# endif
# define TRUE __ERROR__XX__DONT_USE_TRUE
2000-07-06 06:59:27 +00:00
2003-04-14 01:19:58 +00:00
# ifdef FALSE
# undef FALSE
# endif
# define FALSE __ERROR__XX__DONT_USE_FALSE
2003-10-21 04:08:32 +00:00
/* If we have blacklisted mmap() try to avoid using it accidentally by
undefining the HAVE_MMAP symbol . */
# ifdef MMAP_BLACKLIST
# undef HAVE_MMAP
# endif
2009-02-13 10:36:11 -08:00
# ifndef CONST_DISCARD
2009-02-09 17:48:30 +01:00
# define CONST_DISCARD(type, ptr) ((type) ((void *) (ptr)))
2009-02-13 10:36:11 -08:00
# endif
2009-02-09 17:48:30 +01:00
2008-10-18 18:50:37 +02:00
void smb_panic ( const char * why ) _NORETURN_ ;
void dump_core ( void ) _NORETURN_ ;
void exit_server ( const char * const reason ) _NORETURN_ ;
void exit_server_cleanly ( const char * const reason ) _NORETURN_ ;
void exit_server_fault ( void ) _NORETURN_ ;
2006-04-04 00:27:50 +00:00
2006-09-20 00:15:50 +00:00
# ifdef HAVE_LIBNSCD
# include "libnscd.h"
# endif
2008-02-29 13:35:16 +01:00
# if defined(HAVE_IPV6)
void in6_addr_to_sockaddr_storage ( struct sockaddr_storage * ss ,
struct in6_addr ip ) ;
# endif
2009-08-06 07:38:43 +10:00
/* samba3 doesn't use uwrap yet */
# define uwrap_enabled() 0
2003-04-14 01:19:58 +00:00
# endif /* _INCLUDES_H */