]> arthur.barton.de Git - netatalk.git/blobdiff - etc/uams/Makefile.am
Some updates for the Kerberos 5 UAM. We now use an autoconf macro to
[netatalk.git] / etc / uams / Makefile.am
index eb51620c22ce76f5b05dbe6c4b2f7b43fbb53e1a..336f3821b6cb56603ad95beabbf9378f1e939e39 100644 (file)
 # Makefile.am for etc/uams/
 
-if USE_DHX
-DHX_UAMS_BASE = uams_dhx_passwd.so
-DHX_LINKS = uams_dhx.so
-if USE_PGP
-DHX_UAMS = $(DHX_UAMS_BASE) uams_pgp.so
+SUBDIRS = uams_krb4
+
+#
+# conditionally build some modules
+#
+
+if USE_GSSAPI
+UAMS_GENERIC = uams_guest.la uams_passwd.la uams_gss.la
 else
-DHX_UAMS = $(DHX_UAMS_BASE)
+UAMS_GENERIC = uams_guest.la uams_passwd.la
 endif
+
+if USE_DHX
+UAMS_DHX_GENERIC = uams_randnum.la uams_pgp.la uams_dhx_passwd.la
 endif
 
 if BUILD_PAM
-PAM_UAMS= uams_pam.so
+UAMS_PAM = uams_pam.la
 if USE_DHX
-DHX_PAM_UAMS = uams_dhx_pam.so
+UAMS_DHX_PAM = uams_dhx_pam.la
 endif
 endif
 
+# links
 if USE_PAM_SO
-UAM_CLRTXT_SO=uams_pam.so
-UAM_DHX_SO=uams_dhx_pam.so
+UAMS_CLRTXT_LINK = uams_pam.so
+UAMS_DHX_LINK    = uams_dhx_pam.so
 else
-UAM_CLRTXT_SO=uams_passwd.so
-UAM_DHX_SO=uams_dhx_passwd.so
+UAMS_CLRTXT_LINK = uams_passwd.so
+UAMS_DHX_LINK    = uams_dhx_passwd.so
 endif
 
-uamsdir = @UAMS_PATH@
-uams_DATA = $(DHX_UAMS) $(DHX_PAM_UAMS) $(PAM_UAMS) uams_guest.so \
-       uams_passwd.so \
-       uams_randnum.so
-
-uams_LINKS = $(DHX_LINKS) uams_clrtxt.so
+#
+# SSL and crypto flag setup
+#
 
-EXTRA_DIST = uams_dhx_pam.c uams_dhx_passwd.c uams_pgp.c \
-       uams_guest.c uams_pam.c uams_passwd.c uams_randnum.c
+if HAVE_GCRYPT
+CRYPT_CFLAGS = $(GCRYPT_CFLAGS)
+CRYPT_LIBS = $(GCRYPT_LIBS)
+else
+CRYPT_CFLAGS = $(SSL_CFLAGS)
+CRYPT_LIBS = $(SSL_LIBS)
+endif
 
 #
-# standard library compilation:
+# source files
 #
 
-SUFFIXES = .c .so
-.c.so:
-       $(COMPILE) -DHAVE_CONFIG_H -fPIC -DPIC \
-         -I$(top_srcdir) -fomit-frame-pointer -c $< ; \
-       $(LD) -shared $(LDSHAREDFLAGS) -o $@ $*.o $(LIBS)
+uams_guest_la_SOURCES      = uams_guest.c
+uams_randnum_la_SOURCES    = uams_randnum.c crypt.c crypt.h
+uams_passwd_la_SOURCES     = uams_passwd.c
+uams_pam_la_SOURCES        = uams_pam.c
+uams_pgp_la_SOURCES        = uams_pgp.c
+uams_dhx_passwd_la_SOURCES = uams_dhx_passwd.c crypt.c crypt.h
+uams_dhx_pam_la_SOURCES    = uams_dhx_pam.c crypt.c crypt.h
+uams_gss_la_SOURCES       = uams_gss.c
 
 #
-# create symbolic links:
+# flags
 #
 
-uams_clrtxt.so:
-       $(LN_S) -f $(UAM_CLRTXT_SO) $(DESTDIR)$(UAMS_PATH)/uams_clrtxt.so
-
-uams_dhx.so:
-       $(LN_S) -f $(UAM_DHX_SO) $(DESTDIR)$(UAMS_PATH)/uams_dhx.so
+INCLUDES = -I$(top_srcdir)/include -I$(top_srcdir)/sys @SSL_CFLAGS@
+
+uams_guest_la_CFLAGS      = @CFLAGS@
+uams_randnum_la_CFLAGS    = @CFLAGS@ $(CRYPT_CFLAGS)
+uams_passwd_la_CFLAGS     = @CFLAGS@
+uams_pam_la_CFLAGS        = @CFLAGS@
+uams_pgp_la_CFLAGS        = @CFLAGS@ $(CRYPT_CFLAGS)
+uams_dhx_passwd_la_CFLAGS = @CFLAGS@ @SSL_CFLAGS@
+uams_dhx_pam_la_CFLAGS    = @CFLAGS@ @SSL_CFLAGS@
+uams_gss_la_CFLAGS       = @CFLAGS@ @GSSAPI_CFLAGS@
+
+uams_guest_la_LDFLAGS      = -module -avoid-version
+uams_randnum_la_LDFLAGS    = -module -avoid-version $(CRYPT_LIBS)
+uams_passwd_la_LDFLAGS     = -module -avoid-version
+uams_pam_la_LDFLAGS        = -module -avoid-version -lpam
+uams_pgp_la_LDFLAGS        = -module -avoid-version $(CRYPT_LIBS)
+uams_dhx_passwd_la_LDFLAGS = -module -avoid-version @SSL_LIBS@
+uams_dhx_pam_la_LDFLAGS    = -module -avoid-version @SSL_LIBS@ -lpam
+uams_gss_la_LDFLAGS       = -module -avoid-version @GSSAPI_LIBS@
 
 #
-# install/install-strip:
+# module compilation
 #
 
-install-data-local: $(uams_LINKS)
-
-install-strip:
-       strip $(uams_DATA); \
-       $(MAKE) $(AM_MAKEFLAGS) install
+uamsdir = @UAMS_PATH@
+uams_LTLIBRARIES =             \
+       $(UAMS_GENERIC)         \
+       $(UAMS_PAM)             \
+       $(UAMS_DHX_GENERIC)     \
+       $(UAMS_DHX_PAM)
 
 #
-# cleanup
+# link creation
 #
 
-clean distclean clean-recursive distclean-recursive:
-       $(RM) $(uams_DATA) *.o core
+uams_LINKS =
+
+if USE_DHX
+install-exec-hook:
+       (cd $(DESTDIR)$(uamsdir)                                        && \
+               rm -f uams_clrtxt.so uams_dhx.so                        && \
+               $(LN_S) $(UAMS_CLRTXT_LINK) uams_clrtxt.so              && \
+               $(LN_S) $(UAMS_DHX_LINK) uams_dhx.so                       \
+       )
+else
+install-exec-hook:
+       (cd $(DESTDIR)$(uamsdir)                                        && \
+               rm -f uams_clrtxt.so                                    && \
+               $(LN_S) $(UAMS_CLRTXT_LINK) uams_clrtxt.so                 \
+       )
+endif