radius_snmp.o client.o request_list.o mainconfig.o
INCLUDES = ../include/radiusd.h ../include/radius.h ../include/libradius.h ../include/conf.h ../include/autoconf.h
-CFLAGS += -I../include $(SNMP_INCLUDE)
+CFLAGS += -I../include
+CFLAGS += -DHOSTINFO=\"${HOSTINFO}\"
+CFLAGS += -DRADIUSD_VERSION=\"${RADIUSD_VERSION}\"
+CFLAGS += $(SNMP_INCLUDE)
LDFLAGS += -L../lib
-LIBS += -lradius $(SNMP_LIBS)
MODULE_LIBS = $(STATIC_MODULES)
MODULE_OBJS =
VFLAGS = -DRADIUSD_MAJOR_VERSION=$(RADIUSD_MAJOR_VERSION)
VFLAGS += -DRADIUSD_MINOR_VERSION=$(RADIUSD_MINOR_VERSION)
-BINARIES = radiusd radwho radzap raduse radclient radrelay
+BINARIES = radiusd radwho radzap radclient radrelay
+LT_BIN_FLAGS =
#
# Not using shared libraries, add in ALL known static modules
# at build time.
#
ifneq ($(USE_SHARED_LIBS),yes)
+#
+# For static linking...
+#
+LT_BIN_FLAGS = -static -all-static
+
+SUB_MODULES += rlm_eap_md5 rlm_eap_leap rlm_eap_tls rlm_eap_ttls rlm_eap_sim
+SUB_MODULES += rlm_eap_peap rlm_eap_mschapv2 rlm_eap_gtc
+SUB_MODULES += rlm_sql_db2 rlm_sql_freetds rlm_sql_iodbc rlm_sql_mysql
+SUB_MODULES += rlm_sql_oracle rlm_sql_postgresql rlm_sql_sybase rlm_sql_unixodbc
+ifneq ($(OPENSSL_LIBS),)
+LIBS += -L$(OPENSSL_LIBS) -L../modules/rlm_eap/libeap -leap -lcrypto -lssl -lcrypto -lssl
+endif
+#
MODULE_LIBS += $(shell for x in $(MODULES);do test -f ../modules/$$x/$$x.la && echo -dlpreopen ../modules/$$x/$$x.la;done)
+MODULE_LIBS += $(shell for x in $(SUB_MODULES);do test -f ../modules/*/types/$$x/$$x.la && echo -dlpreopen ../modules/*/types/$$x/$$x.la;done)
+MODULE_LIBS += $(shell for x in $(SUB_MODULES);do test -f ../modules/*/drivers/$$x/$$x.la && echo -dlpreopen ../modules/*/drivers/$$x/$$x.la;done)
MODULE_OBJS += $(shell for x in $(MODULES);do test -f ../modules/$$x/$$x.la && echo ../modules/$$x/$$x.la;done)
+MODULE_OBJS += $(shell for x in $(SUB_MODULES);do test -f ../modules/*/types/$$x/$$x.la && echo ../modules/*/types/$$x/$$x.la;done)
+MODULE_OBJS += $(shell for x in $(SUB_MODULES);do test -f ../modules/*/drivers/$$x/$$x.la && echo ../modules/*/drivers/$$x/$$x.la;done)
endif
+LIBS += -lradius $(SNMP_LIBS)
+
+
all: $(BINARIES)
-radiusd: $(SERVER_OBJS) ../lib/libradius.a $(MODULE_OBJS)
+radiusd: $(SERVER_OBJS) ../lib/libradius.la $(MODULE_OBJS)
$(LIBTOOL) --mode=link $(CC) -export-dynamic -dlopen self \
- $(CFLAGS) $(LDFLAGS) -o $@ \
- $(SERVER_OBJS) $(LIBS) $(LCRYPT) \
- $(PTHREADLIB) $(LIBLTDL) $(MODULE_LIBS)
+ $(LT_BIN_FLAGS) $(CFLAGS) $(LDFLAGS) -o $@ \
+ $(SERVER_OBJS) $(LCRYPT) $(MODULE_LIBS) $(LIBS) \
+ $(PTHREADLIB) $(LIBLTDL) $(LCRYPT)
radiusd.o: radiusd.c $(INCLUDES) ../include/request_list.h ../include/modules.h ../include/modcall.h ../include/modpriv.h
- $(CC) $(CFLAGS) -c radiusd.c
+ $(LIBTOOL) --mode=compile $(CC) $(CFLAGS) -c radiusd.c
acct.o: acct.c $(INCLUDES) ../include/modules.h
- $(CC) $(CFLAGS) -c acct.c
+ $(LIBTOOL) --mode=compile $(CC) $(CFLAGS) -c acct.c
files.o: files.c $(INCLUDES)
- $(CC) $(CFLAGS) -c files.c
+ $(LIBTOOL) --mode=compile $(CC) $(CFLAGS) -c files.c
util.o: util.c $(INCLUDES)
- $(CC) $(CFLAGS) -c util.c
+ $(LIBTOOL) --mode=compile $(CC) $(CFLAGS) -c util.c
nas.o: nas.c $(INCLUDES)
- $(CC) $(CFLAGS) -c nas.c
+ $(LIBTOOL) --mode=compile $(CC) $(CFLAGS) -c nas.c
log.o: log.c $(INCLUDES)
- $(CC) $(CFLAGS) -c log.c
+ $(LIBTOOL) --mode=compile $(CC) $(CFLAGS) -c log.c
conffile.o: conffile.c $(INCLUDES) ../include/modules.h
- $(CC) $(CFLAGS) -c conffile.c
+ $(LIBTOOL) --mode=compile $(CC) $(CFLAGS) -c conffile.c
mainconfig.o: mainconfig.c $(INCLUDES) ../include/modules.h
- $(CC) $(CFLAGS) -c mainconfig.c
+ $(LIBTOOL) --mode=compile $(CC) $(CFLAGS) -c mainconfig.c
timestr.o: timestr.c $(INCLUDES)
- $(CC) $(CFLAGS) -c timestr.c
+ $(LIBTOOL) --mode=compile $(CC) $(CFLAGS) -c timestr.c
modules.o: modules.c $(INCLUDES)
- $(CC) $(CFLAGS) $(VFLAGS) $(INCLTDL) -c modules.c
+ $(LIBTOOL) --mode=compile $(CC) $(CFLAGS) $(VFLAGS) $(INCLTDL) -c modules.c
modcall.o: modcall.c $(INCLUDES)
- $(CC) $(CFLAGS) $(INCLTDL) -c modcall.c
+ $(LIBTOOL) --mode=compile $(CC) $(CFLAGS) $(INCLTDL) -c modcall.c
session.o: session.c $(INCLUDES) ../include/modules.h
- $(CC) $(CFLAGS) -c session.c
+ $(LIBTOOL) --mode=compile $(CC) $(CFLAGS) -c session.c
request_list.o: request_list.c $(INCLUDES)
- $(CC) $(CFLAGS) -c request_list.c
-
-request_tree.o: request_tree.c $(INCLUDES)
- $(CC) $(CFLAGS) -c request_tree.c
+ $(LIBTOOL) --mode=compile $(CC) $(CFLAGS) -c request_list.c
proxy.o: proxy.c $(INCLUDES)
- $(CC) $(CFLAGS) -c proxy.c
+ $(LIBTOOL) --mode=compile $(CC) $(CFLAGS) -c proxy.c
exec.o: exec.c $(INCLUDES)
- $(CC) $(CFLAGS) -c exec.c
+ $(LIBTOOL) --mode=compile $(CC) $(CFLAGS) -c exec.c
auth.o: auth.c $(INCLUDES) ../include/modules.h
- $(CC) $(CFLAGS) -c auth.c
+ $(LIBTOOL) --mode=compile $(CC) $(CFLAGS) -c auth.c
valuepair.o: valuepair.c $(INCLUDES)
- $(CC) $(CFLAGS) -c valuepair.c
+ $(LIBTOOL) --mode=compile $(CC) $(CFLAGS) -c valuepair.c
version.o: version.c $(INCLUDES)
- $(CC) $(CFLAGS) -o version.o -c version.c
+ $(LIBTOOL) --mode=compile $(CC) $(CFLAGS) -o version.o -c version.c
xlat.o: xlat.c $(INCLUDES)
- $(CC) $(CFLAGS) -o xlat.o -c xlat.c
+ $(LIBTOOL) --mode=compile $(CC) $(CFLAGS) -o xlat.o -c xlat.c
threads.o: threads.c $(INCLUDES)
- $(CC) $(CFLAGS) -o threads.o -c threads.c
+ $(LIBTOOL) --mode=compile $(CC) $(CFLAGS) -o threads.o -c threads.c
smux.o: smux.c $(INCLUDES)
- $(CC) $(CFLAGS) -o smux.o -c smux.c
+ $(LIBTOOL) --mode=compile $(CC) $(CFLAGS) -o smux.o -c smux.c
radius_snmp.o: radius_snmp.c $(INCLUDES)
- $(CC) $(CFLAGS) -o radius_snmp.o -c radius_snmp.c
+ $(LIBTOOL) --mode=compile $(CC) $(CFLAGS) -o radius_snmp.o -c radius_snmp.c
-radclient: radclient.o ../lib/libradius.a
- $(CC) $(CFLAGS) $(LDFLAGS) -o radclient radclient.o $(LIBS)
+radclient: radclient.o ../lib/libradius.la
+ $(LIBTOOL) --mode=link $(CC) $(CFLAGS) $(LDFLAGS) -o radclient radclient.o ../lib/libradius.la $(LIBS)
radclient.o: radclient.c $(INCLUDES)
- $(CC) $(CFLAGS) -c radclient.c
+ $(LIBTOOL) --mode=compile $(CC) $(CFLAGS) -c radclient.c
-radrelay: radrelay.o mainconfig.o util.o nas.o client.o log.o conffile.o files.o xlat.o ../lib/libradius.a
- $(CC) $(CFLAGS) $(LDFLAGS) -o radrelay radrelay.o mainconfig.o util.o nas.o client.o log.o conffile.o files.o xlat.o $(LIBS)
+radrelay: radrelay.o mainconfig.o util.o nas.o client.o log.o conffile.o files.o xlat.o ../lib/libradius.la
+ $(LIBTOOL) --mode=link $(CC) $(CFLAGS) $(LDFLAGS) -o radrelay radrelay.o mainconfig.o util.o nas.o client.o log.o conffile.o files.o xlat.o -static ../lib/libradius.la -shared $(LIBS)
radrelay.o: radrelay.c $(INCLUDES)
- $(CC) $(CFLAGS) -c radrelay.c
-
-builddbm: builddbm.o files_b.o log.o
- $(CC) $(LDFLAGS) -o builddbm builddbm.o files_b.o log.o $(LDBM) $(LIBS)
-
-builddbm.o: builddbm.c
- $(CC) $(CFLAGS) -c builddbm.c
+ $(LIBTOOL) --mode=compile $(CC) $(CFLAGS) -c radrelay.c
radwho.o: radwho.c $(INCLUDES)
- $(CC) $(CFLAGS) -c radwho.c
-
-radwho: radwho.o mainconfig.o util.o nas.o client.o log.o conffile.o files.o xlat.o
- $(CC) $(LDFLAGS) -o radwho radwho.o mainconfig.o util.o nas.o client.o log.o conffile.o files.o xlat.o $(LIBS)
+ $(LIBTOOL) --mode=compile $(CC) $(CFLAGS) -c radwho.c
-raduse: raduse.o
- $(CC) $(CFLAGS) $(LDFLAGS) -o raduse raduse.o $(LIBS)
+radwho: radwho.o mainconfig.o util.o nas.o client.o log.o conffile.o files.o xlat.o ../lib/libradius.la
+ $(LIBTOOL) --mode=link $(CC) $(LDFLAGS) -o radwho radwho.o mainconfig.o util.o nas.o client.o log.o conffile.o files.o xlat.o ../lib/libradius.la $(LIBS)
radzap.o: radzap.c $(INCLUDES)
- $(CC) $(CFLAGS) -c radzap.c
+ $(LIBTOOL) --mode=compile $(CC) $(CFLAGS) -c radzap.c
-radzap: radzap.o mainconfig.o util.o nas.o log.o client.o conffile.o files.o xlat.o
- $(CC) $(CFLAGS) $(LDFLAGS) -o radzap radzap.o mainconfig.o util.o nas.o log.o client.o conffile.o files.o xlat.o $(LIBS)
+radzap: radzap.o mainconfig.o util.o nas.o log.o client.o conffile.o files.o xlat.o ../lib/libradius.la
+ $(LIBTOOL) --mode=link $(CC) $(CFLAGS) $(LDFLAGS) -o radzap radzap.o mainconfig.o util.o nas.o log.o client.o conffile.o files.o xlat.o ../lib/libradius.la $(LIBS)
clean:
rm -rf *.o *.so *~ $(BINARIES) .libs
install:
- $(LIBTOOL) --mode=install $(INSTALL) -m 755 $(INSTALLSTRIP) radiusd $(R)$(sbindir)
- $(INSTALL) -m 755 $(INSTALLSTRIP) radwho $(R)$(bindir)
- $(INSTALL) -m 755 $(INSTALLSTRIP) raduse $(R)$(bindir)
- $(INSTALL) -m 755 $(INSTALLSTRIP) radzap $(R)$(bindir)
- $(INSTALL) -m 755 radlast $(R)$(bindir)
- $(INSTALL) -m 755 radclient $(R)$(bindir)
- $(INSTALL) -m 755 radrelay $(R)$(bindir)
- $(INSTALL) -m 755 radtest $(R)$(bindir)
- $(INSTALL) -d -m 755 $(R)$(logdir)
- $(INSTALL) -d -m 755 $(R)$(radacctdir)
- $(INSTALL) -m 755 checkrad.pl $(R)$(sbindir)/checkrad
+ $(LIBTOOL) --mode=install $(INSTALL) -m 755 $(INSTALLSTRIP) radiusd$(EXEEXT) $(R)$(sbindir)
+ $(INSTALL) -m 755 $(INSTALLSTRIP) radwho$(EXEEXT) $(R)$(bindir)
+ $(INSTALL) -m 755 $(INSTALLSTRIP) radzap$(EXEEXT) $(R)$(bindir)
+ $(INSTALL) -m 755 radlast $(R)$(bindir)
+ $(INSTALL) -m 755 radclient$(EXEEXT) $(R)$(bindir)
+ $(INSTALL) -m 755 radrelay$(EXEEXT) $(R)$(bindir)
+ $(INSTALL) -m 755 radtest $(R)$(bindir)
+ $(INSTALL) -m 755 checkrad.pl $(R)$(sbindir)/checkrad