Skip to content

Commit

Permalink
wscript_configure_system_mitkrb5: reject a system heimdal krb5-config
Browse files Browse the repository at this point in the history
Review with: git show -w

Signed-off-by: Stefan Metzmacher <[email protected]>
Reviewed-by: Andreas Schneider <[email protected]>

Autobuild-User(master): Stefan Metzmacher <[email protected]>
Autobuild-Date(master): Thu Dec  6 16:53:33 CET 2018 on sn-devel-144
  • Loading branch information
metze-samba committed Dec 6, 2018
1 parent bd4bdce commit 2f68c43
Showing 1 changed file with 21 additions and 19 deletions.
40 changes: 21 additions & 19 deletions wscript_configure_system_mitkrb5
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import sys
from waflib import Logs, Options
from waflib import Logs, Options, Errors

# Check for kerberos
have_gssapi=False
Expand Down Expand Up @@ -56,24 +56,26 @@ if conf.env.KRB5_CONFIG:

vendor = conf.cmd_and_log(conf.env.KRB5_CONFIG+['--vendor'])
conf.env.KRB5_VENDOR = vendor.strip().lower()
if conf.env.KRB5_VENDOR != 'heimdal':
conf.define('USING_SYSTEM_KRB5', 1)
del conf.env.HEIMDAL_KRB5_CONFIG
krb5_conf_version = conf.cmd_and_log(conf.env.KRB5_CONFIG+['--version']).strip()

krb5_version = krb5_conf_version.split()[-1]

# drop '-prerelease' suffix
if krb5_version.find('-') > 0:
krb5_version = krb5_version.split("-")[0]

if parse_version(krb5_version) < parse_version(krb5_required_version):
Logs.error('ERROR: The MIT KRB5 build with Samba AD requires at least %s. %s has been found and cannot be used' % (krb5_required_version, krb5_version))
Logs.error('ERROR: If you want to just build Samba FS (File Server) use the option --without-ad-dc which requires version %s' % (krb5_min_required_version))
Logs.error('ERROR: You may try to build with embedded Heimdal Kerberos by not specifying --with-system-mitkrb5')
sys.exit(1)
else:
Logs.info('MIT Kerberos %s detected, MIT krb5 build can proceed' % (krb5_version))
if conf.env.KRB5_VENDOR == 'heimdal':
raise Errors.WafError('--with-system-mitkrb5 cannot be used with system heimdal')

conf.define('USING_SYSTEM_KRB5', 1)
del conf.env.HEIMDAL_KRB5_CONFIG
krb5_conf_version = conf.cmd_and_log(conf.env.KRB5_CONFIG+['--version']).strip()

krb5_version = krb5_conf_version.split()[-1]

# drop '-prerelease' suffix
if krb5_version.find('-') > 0:
krb5_version = krb5_version.split("-")[0]

if parse_version(krb5_version) < parse_version(krb5_required_version):
Logs.error('ERROR: The MIT KRB5 build with Samba AD requires at least %s. %s has been found and cannot be used' % (krb5_required_version, krb5_version))
Logs.error('ERROR: If you want to just build Samba FS (File Server) use the option --without-ad-dc which requires version %s' % (krb5_min_required_version))
Logs.error('ERROR: You may try to build with embedded Heimdal Kerberos by not specifying --with-system-mitkrb5')
sys.exit(1)
else:
Logs.info('MIT Kerberos %s detected, MIT krb5 build can proceed' % (krb5_version))

conf.CHECK_CFG(args="--cflags --libs", package="com_err", uselib_store="com_err")
conf.CHECK_FUNCS_IN('_et_list', 'com_err')
Expand Down

0 comments on commit 2f68c43

Please sign in to comment.