]> git.ipfire.org Git - thirdparty/samba.git/commitdiff
waf:mitkrb5: Fix MIT KRB5 detection if not in default system location
authorAndreas Schneider <asn@samba.org>
Fri, 3 Dec 2021 07:49:24 +0000 (08:49 +0100)
committerAndrew Bartlett <abartlet@samba.org>
Mon, 6 Dec 2021 22:08:32 +0000 (22:08 +0000)
Signed-off-by: Andreas Schneider <asn@samba.org>
Reviewed-by: Andrew Bartlett <abartlet@samba.org>
wscript_configure_system_mitkrb5

index b095f49f635e575dca9c78b8dfbba89afe221a02..1e5d65f72140284d7804d28ed3364b4d12892db8 100644 (file)
@@ -36,31 +36,50 @@ conf.CHECK_HEADERS('com_err.h', lib='com_err')
 
 conf.find_program('krb5-config', path_list=path_krb5_config, var='KRB5_CONFIG')
 if conf.env.KRB5_CONFIG:
-    conf.CHECK_CFG(path=conf.env.KRB5_CONFIG, args="--cflags --libs",
-               package="", uselib_store="KRB5")
-    krb5_define_syslib(conf, "krb5", conf.env['LIB_KRB5'])
-
-    conf.CHECK_CFG(path=conf.env.KRB5_CONFIG, args="--cflags --libs",
-                   package="kadm-server", uselib_store="KADM-SERVER")
-    conf.CHECK_FUNCS_IN('kadm5_init', 'kadm5srv_mit')
-
-    conf.CHECK_CFG(path=conf.env.KRB5_CONFIG, args="--cflags --libs",
-                   package="kdb", uselib_store="KDB5")
-    krb5_define_syslib(conf, "kdb5", conf.env['LIB_KDB5'])
-
-    conf.CHECK_CFG(path=conf.env.KRB5_CONFIG, args="--cflags --libs",
-               package="gssapi", uselib_store="GSSAPI")
-    krb5_define_syslib(conf, "gssapi", conf.env['LIB_GSSAPI'])
-    if 'k5crypto' in conf.env['LIB_GSSAPI']:
-        krb5_define_syslib(conf, "k5crypto", conf.env['LIB_GSSAPI'])
-    if 'gssapi_krb5' in conf.env['LIB_GSSAPI']:
-        krb5_define_syslib(conf, "gssapi_krb5", conf.env['LIB_GSSAPI'])
-
     vendor = conf.cmd_and_log(conf.env.KRB5_CONFIG+['--vendor'])
     conf.env.KRB5_VENDOR = vendor.strip().lower()
     if conf.env.KRB5_VENDOR == 'heimdal':
         raise Errors.WafError('--with-system-mitkrb5 cannot be used with system heimdal')
 
+    if conf.CHECK_CFG(path=conf.env.KRB5_CONFIG, args="--cflags --libs",
+                      package="", uselib_store="KRB5"):
+        if 'krb5' in conf.env['LIB_KRB5']:
+            krb5_define_syslib(conf, "krb5", conf.env['LIB_KRB5'])
+        if 'k5crypto' in conf.env['LIB_KRB5']:
+            krb5_define_syslib(conf, "k5crypto", conf.env['LIB_GSSAPI'])
+    else:
+        raise Errors.WafError('Unable to find required krb5 library!')
+
+    if conf.CHECK_CFG(path=conf.env.KRB5_CONFIG, args="--cflags --libs",
+                      package="gssapi", uselib_store="GSSAPI"):
+        krb5_define_syslib(conf, "gssapi", conf.env['LIB_GSSAPI'])
+        if 'gssapi_krb5' in conf.env['LIB_GSSAPI']:
+            krb5_define_syslib(conf, "gssapi_krb5", conf.env['LIB_GSSAPI'])
+    else:
+        raise Errors.WafError('Unable to find required gssapi library!')
+
+    if conf.CONFIG_SET('AD_DC_BUILD_IS_ENABLED'):
+        if conf.CHECK_CFG(path=conf.env.KRB5_CONFIG, args="--cflags --libs",
+                          package="gssrpc", uselib_store="GSSRPC"):
+            krb5_define_syslib(conf, "gssrpc", conf.env['LIB_GSSRPC'])
+
+        if conf.CHECK_CFG(path=conf.env.KRB5_CONFIG, args="--cflags --libs",
+                          package="kdb", uselib_store="KDB5"):
+            krb5_define_syslib(conf, "kdb5", conf.env['LIB_KDB5'])
+            conf.CHECK_HEADERS('kdb.h', lib='kdb5')
+        else:
+            raise Errors.WafError('Unable to find required kdb5 library!')
+
+        if conf.CHECK_CFG(path=conf.env.KRB5_CONFIG, args="--cflags --libs",
+                          package="kadm-server", uselib_store="KADM5SRV_MIT"):
+            krb5_define_syslib(conf,
+                               "kadm5srv_mit",
+                               conf.env['LIB_KADM5SRV_MIT'])
+            conf.CHECK_FUNCS_IN('kadm5_init', 'kadm5srv_mit')
+        else:
+            raise Errors.WafError('Unable to find required kadm5srv_mit '
+                                  'library!')
+
     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()
@@ -81,8 +100,6 @@ if conf.env.KRB5_CONFIG:
 
     conf.define('USING_SYSTEM_MITKRB5', '"%s"' % krb5_version)
 
-conf.CHECK_HEADERS('kdb.h', lib='kdb5')
-
 conf.CHECK_HEADERS('krb5.h krb5/locate_plugin.h', lib='krb5')
 conf.CHECK_HEADERS('krb5.h krb5/localauth_plugin.h', lib='krb5')
 possible_gssapi_headers="gssapi.h gssapi/gssapi_generic.h gssapi/gssapi.h gssapi/gssapi_ext.h gssapi/gssapi_krb5.h gssapi/gssapi_oid.h"