Store the name of the binary using libcharon to enable specific settings.
authorTobias Brunner <tobias@strongswan.org>
Tue, 24 Apr 2012 09:07:56 +0000 (11:07 +0200)
committerTobias Brunner <tobias@strongswan.org>
Thu, 3 May 2012 11:57:04 +0000 (13:57 +0200)
src/charon-nm/charon-nm.c
src/charon/charon.c
src/conftest/conftest.c
src/libcharon/daemon.c
src/libcharon/daemon.h

index 16b0ed8..2e781c0 100644 (file)
@@ -240,7 +240,7 @@ int main(int argc, char *argv[])
                exit(SS_RC_INITIALIZATION_FAILED);
        }
 
-       if (!libcharon_init())
+       if (!libcharon_init("charon-nm"))
        {
                dbg_syslog(DBG_DMN, 1, "initialization failed - aborting charon-nm");
                goto deinit;
index 9211a63..8475a5f 100644 (file)
@@ -475,7 +475,7 @@ int main(int argc, char *argv[])
                exit(SS_RC_INITIALIZATION_FAILED);
        }
 
-       if (!libcharon_init())
+       if (!libcharon_init("charon"))
        {
                dbg_stderr(DBG_DMN, 1, "initialization failed - aborting charon");
                goto deinit;
index 48bf968..7b5669b 100644 (file)
@@ -422,7 +422,7 @@ int main(int argc, char *argv[])
                library_deinit();
                return SS_RC_INITIALIZATION_FAILED;
        }
-       if (!libcharon_init())
+       if (!libcharon_init("conftest"))
        {
                libcharon_deinit();
                libhydra_deinit();
index c6238eb..2cf8d5e 100644 (file)
@@ -247,7 +247,7 @@ METHOD(daemon_t, initialize, bool,
 /**
  * Create the daemon.
  */
-private_daemon_t *daemon_create()
+private_daemon_t *daemon_create(const char *name)
 {
        private_daemon_t *this;
 
@@ -260,6 +260,7 @@ private_daemon_t *daemon_create()
                        .bus = bus_create(),
                        .file_loggers = linked_list_create(),
                        .sys_loggers = linked_list_create(),
+                       .name = strdup(name ?: "libcharon"),
                },
        );
        charon = &this->public;
@@ -298,9 +299,9 @@ void libcharon_deinit()
 /**
  * Described in header.
  */
-bool libcharon_init()
+bool libcharon_init(const char *name)
 {
-       daemon_create();
+       daemon_create(name);
 
        /* for uncritical pseudo random numbers */
        srandom(time(NULL) + getpid());
index ad9ab4c..5ea3f45 100644 (file)
@@ -264,6 +264,11 @@ struct daemon_t {
        gid_t gid;
 
        /**
+        * Name of the binary that uses the library (used for settings etc.)
+        */
+       const char *name;
+
+       /**
         * Do not drop a given capability after initialization.
         *
         * Some plugins might need additional capabilites. They tell the daemon
@@ -311,9 +316,10 @@ extern daemon_t *charon;
  * This function initializes the bus, listeners can be registered before
  * calling initialize().
  *
+ * @param name name of the binary that uses the library
  * @return             FALSE if integrity check failed
  */
-bool libcharon_init();
+bool libcharon_init(const char *name);
 
 /**
  * Deinitialize libcharon and destroy the "charon" instance of daemon_t.