diff options
author | Günther Deschner <gd@samba.org> | 2011-02-09 22:43:41 +0100 |
---|---|---|
committer | Günther Deschner <gd@samba.org> | 2011-02-09 23:38:50 +0100 |
commit | d0406ab7f035c7a777b9494712e7b9b52df95a19 (patch) | |
tree | ebbe6d05e980caae1a45be10f90cb83f52b7eda4 /source3 | |
parent | 65bb6b35241a29a514fef3be547398c9cd3c2e09 (diff) | |
download | samba-d0406ab7f035c7a777b9494712e7b9b52df95a19.tar.gz samba-d0406ab7f035c7a777b9494712e7b9b52df95a19.tar.bz2 samba-d0406ab7f035c7a777b9494712e7b9b52df95a19.zip |
s3-waf: make ads support detection a little more robust.
Guenther
Autobuild-User: Günther Deschner <gd@samba.org>
Autobuild-Date: Wed Feb 9 23:38:50 CET 2011 on sn-devel-104
Diffstat (limited to 'source3')
-rw-r--r-- | source3/wscript | 49 |
1 files changed, 44 insertions, 5 deletions
diff --git a/source3/wscript b/source3/wscript index 90e25a3eda..3aa5d2a467 100644 --- a/source3/wscript +++ b/source3/wscript @@ -598,9 +598,6 @@ msg.msg_acctrightslen = sizeof(fd); headers='netdb.h netgroup.h', cflags="-Werror-implicit-function-declaration") - #FIXME: Should just be set when krb5 and ldap requirements are fulfilled - if Options.options.with_ads: - conf.DEFINE('WITH_ADS', '1') # Look for CUPS if Options.options.with_cups: @@ -839,8 +836,6 @@ return krb5_kt_resolve(context, "WRFILE:api", &keytab); headers='krb5.h', lib='krb5', execute=True, msg="Checking whether the WRFILE:-keytab is supported"); - conf.DEFINE('HAVE_KRB5', '1') - else: conf.SET_TARGET_TYPE('krb5', 'EMPTY') conf.SET_TARGET_TYPE('gssapi', 'EMPTY') @@ -848,6 +843,50 @@ return krb5_kt_resolve(context, "WRFILE:api", &keytab); conf.SET_TARGET_TYPE('com_err', 'EMPTY') conf.SET_TARGET_TYPE('k5crypto', 'EMPTY') + if Options.options.with_ads: + use_ads=True + if not conf.CONFIG_SET('HAVE_ENCTYPE_ARCFOUR_HMAC_MD5'): + print "arcfour-hmac-md5 encryption type not found in -lkrb5" + use_ads=False + if not conf.CONFIG_SET('HAVE_KRB5_MK_REQ_EXTENDED'): + print "krb5_mk_req_extended not found in -lkrb5" + use_ads=False + if not conf.CONFIG_SET('HAVE_KRB5_PRINCIPAL2SALT') or \ + not conf.CONFIG_SET('HAVE_KRB5_GET_PW_SALT'): + print "no CREATE_KEY_FUNCTIONS detected" + use_ads=False + if not conf.CONFIG_SET('HAVE_KRB5_GET_PERMITTED_ENCTYPES') or \ + not conf.CONFIG_SET('HAVE_KRB5_GET_DEFAULT_IN_TKT_ETYPES'): + print "no GET_ENCTYPES_FUNCTIONS detected" + use_ads=False + if not conf.CONFIG_SET('HAVE_KRB5_KT_FREE_ENTRY') or \ + not conf.CONFIG_SET('HAVE_KRB5_FREE_KEYTAB_ENTRY_CONTENTS'): + print "no KT_FREE_FUNCTION detected" + use_ads=False + if not conf.CONFIG_SET('HAVE_KRB5_C_VERIFY_CHECKSUM') or \ + not conf.CONFIG_SET('HAVE_KRB5_VERIFY_CHECKSUM'): + print "no KRB5_VERIFY_CHECKSUM_FUNCTION detected" + use_ads=False + if not conf.CONFIG_SET('KRB5_TICKET_HAS_KEYINFO'): + # We only need the following functions if we can't get the enctype + # and kvno out of the ticket directly (ie. on Heimdal). + if not conf.CONFIG_SET('free_AP_REQ'): + print "no KRB5_AP_REQ_FREE_FUNCTION detected" + use_ads=False + if not conf.CONFIG_SET('HAVE_KRB5_DECODE_AP_REQ'): + print "no KRB5_AP_REQ_DECODING_FUNCTION detected" + use_ads=False + if use_ads: + conf.DEFINE('WITH_ADS', '1') + conf.DEFINE('HAVE_KRB5', '1') + conf.DEFINE('HAVE_GSSAPI', '1') + else: + print "krb5 libs don't have all features required for Active Directory support" + conf.undefine('HAVE_KRB5_H') + conf.undefine('HAVE_GSSAPI_H') + conf.undefine('HAVE_GSSAPI_GSSAPI_GENERIC_H') + conf.undefine('HAVE_GSSAPI_GSSAPI_H') + if Options.options.with_utmp: conf.CHECK_FUNCS('pututline pututxline updwtmp updwtmpx getutmpx getutxent') conf.CHECK_STRUCTURE_MEMBER('struct utmp', 'ut_name', headers='utmp.h', |