aboutsummaryrefslogtreecommitdiffstats
path: root/src/pluto/xauth.c
diff options
context:
space:
mode:
authorAndreas Steffen <andreas.steffen@strongswan.org>2007-01-05 11:03:09 +0000
committerAndreas Steffen <andreas.steffen@strongswan.org>2007-01-05 11:03:09 +0000
commit09ff4110612a52c2a8d57674c4c249a9d5d81bd6 (patch)
tree2eedf6db464acb57c8e42312a380ccdb45034c77 /src/pluto/xauth.c
parent195307b5742e64774fa2d1062ea3e521bf7dcbfe (diff)
downloadstrongswan-09ff4110612a52c2a8d57674c4c249a9d5d81bd6.tar.bz2
strongswan-09ff4110612a52c2a8d57674c4c249a9d5d81bd6.tar.xz
load xauth module via dlopen()
Diffstat (limited to 'src/pluto/xauth.c')
-rw-r--r--src/pluto/xauth.c45
1 files changed, 43 insertions, 2 deletions
diff --git a/src/pluto/xauth.c b/src/pluto/xauth.c
index e44ac4ec9..1947609bd 100644
--- a/src/pluto/xauth.c
+++ b/src/pluto/xauth.c
@@ -15,22 +15,63 @@
* RCSID $Id: xauth.c,v 1.1 2005/01/06 22:10:15 as Exp $
*/
+#include <dlfcn.h>
+
#include <freeswan.h>
#include "constants.h"
#include "defs.h"
#include "xauth.h"
#include "keys.h"
+#include "log.h"
void
xauth_init(void)
{
- /* TODO: locate and load dynamic XAUTH module */
+#ifdef XAUTH_DEFAULT_LIB
+ xauth_module.handle = dlopen(XAUTH_DEFAULT_LIB, RTLD_NOW);
+
+ if (xauth_module.handle != NULL)
+ {
+ DBG(DBG_CONTROL,
+ DBG_log("xauth module '%s' loading'", XAUTH_DEFAULT_LIB)
+ )
+ xauth_module.get_secret = (bool (*) (const xauth_t*))
+ dlsym(xauth_module.handle, "get_secret");
+ DBG(DBG_CONTROL,
+ if (xauth_module.get_secret != NULL)
+ {
+ DBG_log("xauth module: found get_secret() function");
+ }
+ )
+ xauth_module.verify_secret = (bool (*) (const xauth_t*))
+ dlsym(xauth_module.handle, "verify_secret");
+ DBG(DBG_CONTROL,
+ if (xauth_module.verify_secret != NULL)
+ {
+ DBG_log("xauth module: found verify_secret() function");
+ }
+ )
+ }
+#endif
+ /* any null function pointers will be filled in by default functions */
xauth_defaults();
}
void
xauth_finalize(void)
{
- /* TODO: unload dynamic XAUTH module */
+ if (xauth_module.handle != NULL)
+ {
+ if (dlclose(xauth_module.handle))
+ {
+ plog("failed to unload xauth module");
+ }
+ else
+ {
+ DBG(DBG_CONTROL,
+ DBG_log("xauth module unloaded")
+ )
+ }
+ }
}