summaryrefslogtreecommitdiffstats
path: root/m4
diff options
context:
space:
mode:
authorRich Megginson <rmeggins@redhat.com>2008-11-04 18:23:08 +0000
committerRich Megginson <rmeggins@redhat.com>2008-11-04 18:23:08 +0000
commit42d4235a9cf49b9235f44e2a9965e820b629bd9f (patch)
treeff0a0228b0b1c7d4a196cf9eef139820ecc4aae9 /m4
parent485b3ddd27e4c1ac66b0c5aada1dae793bcc54dc (diff)
downloadds-42d4235a9cf49b9235f44e2a9965e820b629bd9f.tar.gz
ds-42d4235a9cf49b9235f44e2a9965e820b629bd9f.tar.xz
ds-42d4235a9cf49b9235f44e2a9965e820b629bd9f.zip
Resolves: bug 469261
Bug Description: Support server-to-server SASL - part 1 Reviewed by: nkinder, nhosoi, ssorce (Thanks!) Fix Description: I've created two new functions to handle the client side of LDAP in the server - slapi_ldap_init_ext and slapi_ldap_bind. These two functions are designed to work with any connection type (ldap, ldaps, ldap+starttls, and eventually ldapi) and bind type (plain, sasl, client cert). The secure flag has been extended to use a value of 2 to mean use startTLS. One tricky part is that there is no place to store the startTLS flag in init to pass to bind, so we store that in the clientcontrols field which is currently unused. We do that because the semantics of ldap_init are not to do any network traffic, but defer that until the bind operation (or whatever the first actual operation is e.g. start_tls). I plan to replace all of the places in the code that do ldap init and bind with these functions. I started with replication. I extended the transport to add tls for startTLS and the bind method to add sasl/gssapi and sasl/digest-md5. I removed a lot of code from repl5_connection that is now done with just slapi_ldap_init_ext and slapi_ldap_bind. One tricky part of the replication code is that it polls the connection for write available, using some ldap sdk internals. I had to fix that code to work within the public ldap api since nspr and sasl muck with the internals in different incompatible ways. Finally, there is a lot of new kerberos code in the server. The way the server does sasl/gssapi auth with its keytab is similar to the way it does client cert auth with its ssl server cert. One big difference is that the server cannot pass the kerberos identity and credentials through the ldap/sasl/gssapi layers directly. Instead, we have to create a memory credentials cache and set the environment variable to point to it. This allows the sasl/gssapi layer to grab the credentials for use with kerberos. The way the code is written, it should also allow "external" kerberos auth e.g. if someone really wants to do some script which does a periodic kinit to refresh the file based cache, that should also work. I added some kerberos configure options. configure tries to first use krb5-config to get the compiler and linker information. If that fails, it just looks for some standard system libraries. Note that Solaris does not allow direct use of the kerberos api until Solaris 11, so most likely Solaris builds will have to use --without-kerberos (--with-kerberos is on by default). Fixed a bug in kerberos.m4 found by nkinder. ssorce has pointed out a few problems with my kerberos usage that will be addressed in the next patch. Changed the log level in ldap_sasl_get_val - pointed out by nkinder Platforms tested: Fedora 9, Fedora 8 Flag Day: yes Doc impact: oh yes
Diffstat (limited to 'm4')
-rw-r--r--m4/kerberos.m4199
1 files changed, 199 insertions, 0 deletions
diff --git a/m4/kerberos.m4 b/m4/kerberos.m4
new file mode 100644
index 00000000..26234149
--- /dev/null
+++ b/m4/kerberos.m4
@@ -0,0 +1,199 @@
+# BEGIN COPYRIGHT BLOCK
+# Copyright (C) 2008 Red Hat, Inc.
+# All rights reserved.
+#
+# 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 the Free Software Foundation; either version 2
+# of the License, or (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
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+#
+# END COPYRIGHT BLOCK
+# -*- tab-width: 4; -*-
+# Configure paths for Kerberos
+
+dnl ========================================================
+dnl = Kerberos is used directly for server to server SASL/GSSAPI
+dnl = authentication (replication, chaining, etc.)
+dnl = This allows us to authenticate using a keytab without
+dnl = having to call kinit outside the process
+dnl ========================================================
+AC_CHECKING(for kerberos)
+
+if test -z "$with_kerberos" ; then
+ with_kerberos=yes # if not set on cmdline, set default
+fi
+
+AC_MSG_CHECKING(for --with-kerberos)
+AC_ARG_WITH(kerberos,
+ AS_HELP_STRING([--with-kerberos[=PATH]], [Use the kerberos API in the server directly - allows the server to authenticate directly with a keytab - otherwise, SASL/GSSAPI auth depends on underlying SASL libraries and external kinit with a keytab - if PATH is not specified, look for kerberos in the system locations. This will attempt to use krb5-config from the PATH to find the libs and include dirs - you can specify KRB5_CONFIG_BIN to specify a different filename or absolute path. If krb5-config does not work, this will attempt to look in various system directories]),
+ [
+ if test "x$withval" = "xyes"; then
+ AC_MSG_RESULT(yes)
+ elif test "x$withval" = "xno"; then
+ AC_MSG_RESULT(no)
+ with_kerberos=
+ elif test -d "$withval" -a -d "$withval/lib" -a -d "$withval/include" ; then
+ AC_MSG_RESULT([using $withval])
+ kerberos_incdir="$withval/include"
+ kerberos_libdir="$withval/lib"
+ else
+ AC_MSG_RESULT(yes)
+ AC_MSG_ERROR([kerberos not found in $withval])
+ fi
+ ],
+ [
+ AC_MSG_RESULT(no)
+ with_kerberos=
+ ]
+)
+
+AC_MSG_CHECKING(for --with-kerberos-inc)
+AC_ARG_WITH(kerberos-inc,
+ AS_HELP_STRING([--with-kerberos-inc=PATH], [Allows you to explicitly set the directory containing the kerberos include files - implies use of kerberos]),
+ [
+ if test -f "$withval"/krb5.h; then
+ AC_MSG_RESULT([using $withval])
+ kerberos_incdir="$withval"
+ with_kerberos=yes # implies use of kerberos
+ else
+ echo
+ AC_MSG_ERROR([$withval/krb5.h not found])
+ fi
+ ],
+ AC_MSG_RESULT(no)
+)
+
+AC_MSG_CHECKING(for --with-kerberos-lib)
+AC_ARG_WITH(kerberos-lib,
+ AS_HELP_STRING([--with-kerberos-lib=PATH], [Allows you to explicitly set the directory containing the kerberos libraries - implies use of kerberos]),
+ [
+ if test -d "$withval"; then
+ AC_MSG_RESULT([using $withval])
+ kerberos_libdir="$withval"
+ with_kerberos=yes # implies use of kerberos
+ else
+ echo
+ AC_MSG_ERROR([$withval not found])
+ fi
+ ],
+ AC_MSG_RESULT(no)
+)
+
+if test -n "$with_kerberos" ; then
+ if test -z "$kerberos_incdir" -o -z "$kerberos_libdir" ; then
+ dnl look for these using the krb5-config script
+ dnl user can define KRB5_CONFIG_BIN to the full path
+ dnl and filename of the script if it cannot or will not
+ dnl be found in PATH
+ if test -z "$KRB5_CONFIG_BIN" ; then
+ AC_PATH_PROG(KRB5_CONFIG_BIN, krb5-config)
+ fi
+ if test -n "$KRB5_CONFIG_BIN" ; then
+ AC_MSG_CHECKING(for kerberos with $KRB5_CONFIG_BIN)
+ if test -z "$kerberos_libdir" ; then
+ kerberos_lib=`$KRB5_CONFIG_BIN --libs krb5`
+ fi
+ if test -z "$kerberos_incdir" ; then
+ kerberos_inc=`$KRB5_CONFIG_BIN --cflags krb5`
+ fi
+ dnl if using system includes, inc will be empty - ok
+ if test -n "$kerberos_lib" ; then
+ AC_MSG_RESULT([using kerberos found with $KRB5_CONFIG_BIN])
+ have_krb5=yes
+ fi
+ fi
+ fi
+fi
+
+if test -n "$with_kerberos" -a -z "$kerberos_lib" ; then
+ # save these in order to set them to use the check macros below
+ # like AC_CHECK_HEADERS, AC_CHECK_LIB, and AC_CHECK_FUNCS
+ save_CPPFLAGS="$CPPFLAGS"
+ if test -n "$kerberos_incdir" ; then
+ CPPFLAGS="-I$kerberos_incdir $CPPFLAGS"
+ fi
+ save_LDFLAGS="$LDFLAGS"
+ if test -n "$kerberos_libdir" ; then
+ LDFLAGS="-L$kerberos_libdir $LDFLAGS"
+ fi
+ krb5_impl=mit
+
+ dnl check for Heimdal Kerberos
+ AC_CHECK_HEADERS(heim_err.h)
+ if test $ac_cv_header_heim_err_h = yes ; then
+ krb5_impl=heimdal
+ fi
+
+ if test "x$krb5_impl" = "xmit"; then
+ AC_CHECK_LIB(k5crypto, main,
+ [krb5crypto=k5crypto],
+ [krb5crypto=crypto])
+
+ AC_CHECK_LIB(krb5, main,
+ [have_krb5=yes
+ kerberos_lib="-lkrb5 -l$krb5crypto -lcom_err"],
+ [have_krb5=no],
+ [-l$krb5crypto -lcom_err])
+
+ elif test "x$krb5_impl" = "xheimdal"; then
+ AC_CHECK_LIB(des, main,
+ [krb5crypto=des],
+ [krb5crypto=crypto])
+
+ AC_CHECK_LIB(krb5, main,
+ [have_krb5=yes
+ kerberos_lib="-lkrb5 -l$krb5crypto -lasn1 -lroken -lcom_err"],
+ [have_krb5=no],
+ [-l$krb5crypto -lasn1 -lroken -lcom_err])
+
+ AC_DEFINE(HAVE_HEIMDAL_KERBEROS, 1,
+ [define if you have HEIMDAL Kerberos])
+
+ else
+ have_krb5=no
+ AC_MSG_WARN([Unrecognized Kerberos5 Implementation])
+ fi
+
+ # reset to original values
+ CPPFLAGS="$save_CPPFLAGS"
+ LDFLAGS="$save_LDFLAGS"
+ if test -n "$kerberos_incdir" ; then
+ kerberos_inc="-I$kerberos_incdir"
+ fi
+ if test -n "$kerberos_libdir" ; then
+ kerberos_lib="-L$kerberos_libdir $kerberos_lib"
+ fi
+fi
+
+dnl at this point kerberos_lib and kerberos_inc should be set
+
+if test -n "$with_kerberos" ; then
+ if test "x$have_krb5" = "xyes" ; then
+ AC_DEFINE(HAVE_KRB5, 1,
+ [define if you have Kerberos V])
+ else
+ AC_MSG_ERROR([Required Kerberos 5 support not available])
+ fi
+
+ dnl look for the wonderfully time saving function krb5_cc_new_unique
+ save_LIBS="$LIBS"
+ LIBS="$kerberos_lib"
+ save_CPPFLAGS="$CPPFLAGS"
+ CPPFLAGS="$kerberos_inc $CPPFLAGS"
+ AC_CHECK_FUNCS([krb5_cc_new_unique])
+ LIBS="$save_LIBS"
+ CPPFLAGS="$save_CPPFLAGS"
+fi
+
+AC_SUBST(kerberos_inc)
+AC_SUBST(kerberos_lib)
+AC_SUBST(kerberos_libdir)