charon_SOURCES = \
charon.c
-INCLUDES = -I$(top_srcdir)/src/libstrongswan -I$(top_srcdir)/src/libcharon
+INCLUDES = \
+ -I$(top_srcdir)/src/libstrongswan \
+ -I$(top_srcdir)/src/libhydra \
+ -I$(top_srcdir)/src/libcharon
+
AM_CFLAGS = \
-DIPSEC_DIR=\"${ipsecdir}\" \
-DIPSEC_PIDDIR=\"${piddir}\"
+
charon_LDADD = \
$(top_builddir)/src/libstrongswan/libstrongswan.la \
$(top_builddir)/src/libhydra/libhydra.la \
#include <pwd.h>
#include <grp.h>
+#include <hydra.h>
#include <daemon.h>
#include <library.h>
struct sigaction action;
bool use_syslog = FALSE;
level_t levels[DBG_MAX];
- int group;
+ int group, status = SS_RC_INITIALIZATION_FAILED;
/* logging for library during initialization, as we have no bus yet */
dbg = dbg_stderr;
exit(SS_RC_DAEMON_INTEGRITY);
}
- if (!libcharon_init())
+ if (!libhydra_init())
{
dbg_stderr(1, "initialization failed - aborting charon");
- libcharon_deinit();
+ libhydra_deinit();
library_deinit();
exit(SS_RC_INITIALIZATION_FAILED);
}
+ if (!libcharon_init())
+ {
+ dbg_stderr(1, "initialization failed - aborting charon");
+ goto deinit;
+ }
+
/* use CTRL loglevel for default */
for (group = 0; group < DBG_MAX; group++)
{
if (!lookup_uid_gid())
{
dbg_stderr(1, "invalid uid/gid - aborting charon");
- libcharon_deinit();
- library_deinit();
- exit(SS_RC_INITIALIZATION_FAILED);
+ goto deinit;
}
/* initialize daemon */
if (!charon->initialize(charon, use_syslog, levels))
{
DBG1(DBG_DMN, "initialization failed - aborting charon");
- libcharon_deinit();
- library_deinit();
- exit(SS_RC_INITIALIZATION_FAILED);
+ goto deinit;
}
if (check_pidfile())
{
DBG1(DBG_DMN, "charon already running (\""PID_FILE"\" exists)");
- libcharon_deinit();
- library_deinit();
- exit(-1);
+ status = -1;
+ goto deinit;
}
if (!drop_capabilities())
{
DBG1(DBG_DMN, "capability dropping failed - aborting charon");
- libcharon_deinit();
- library_deinit();
- exit(SS_RC_INITIALIZATION_FAILED);
+ goto deinit;
}
/* add handler for SEGV and ILL,
run();
/* normal termination, cleanup and exit */
- libcharon_deinit();
- library_deinit();
-
unlink(PID_FILE);
+ status = 0;
- return 0;
+deinit:
+ libcharon_deinit();
+ libhydra_deinit();
+ library_deinit();
+ return status;
}
{
DBG1(DBG_DMN, "integrity tests enabled:");
DBG1(DBG_DMN, "lib 'libstrongswan': passed file and segment integrity tests");
+ DBG1(DBG_DMN, "lib 'libhydra': passed file and segment integrity tests");
DBG1(DBG_DMN, "lib 'libcharon': passed file and segment integrity tests");
DBG1(DBG_DMN, "daemon 'charon': passed file integrity test");
}
_pluto_adns_SOURCES = adns.c adns.h
LIBSTRONGSWANDIR=$(top_builddir)/src/libstrongswan
-LIBHYDRADIR=$(top_builddir)/src/libhydra
LIBFREESWANDIR=$(top_builddir)/src/libfreeswan
+LIBHYDRADIR=$(top_builddir)/src/libhydra
INCLUDES = \
-I${linux_headers} \
-I$(top_srcdir)/src/libstrongswan \
-I$(top_srcdir)/src/libfreeswan \
+-I$(top_srcdir)/src/libhydra \
-I$(top_srcdir)/src/whack
AM_CFLAGS = \
pluto_LDADD = \
$(LIBSTRONGSWANDIR)/libstrongswan.la \
-$(LIBHYDRADIR)/libhydra.la \
$(LIBFREESWANDIR)/libfreeswan.a \
+$(LIBHYDRADIR)/libhydra.la \
-lresolv $(PTHREADLIB) $(DLLIB)
_pluto_adns_LDADD = \
#include <freeswan.h>
+#include <hydra.h>
#include <library.h>
#include <debug.h>
#include <utils/enumerator.h>
library_deinit();
exit(SS_RC_DAEMON_INTEGRITY);
}
+ if (!libhydra_init())
+ {
+ libhydra_deinit();
+ library_deinit();
+ exit(SS_RC_INITIALIZATION_FAILED);
+ }
options = options_create();
/* handle arguments */
{
plog("integrity tests enabled:");
plog("lib 'libstrongswan': passed file and segment integrity tests");
+ plog("lib 'libhydra': passed file and segment integrity tests");
plog("daemon 'pluto': passed file integrity test");
}
free_builder();
delete_lock();
options->destroy(options);
+ libhydra_deinit();
library_deinit();
close_log();
exit(status);