Adding "conf.d" configuration dir support.
authorFlorent Clairambault <florent@clairambault.fr>
Thu, 26 Dec 2013 22:05:17 +0000 (23:05 +0100)
committerFlorent Clairambault <florent@clairambault.fr>
Thu, 26 Dec 2013 22:05:17 +0000 (23:05 +0100)
Any file matching the pattern /etc/tinc/$NETWORK/conf.d/$NAME.conf will be parsed after the tinc.conf file.

src/conf.c

index 0fc9d8f46cc559a16fdca1075ffd3db6db987627..e2b64429d8fd3ee1616c59efb0ebbbaa7c3b9e22 100644 (file)
@@ -378,6 +378,30 @@ bool read_server_config(void) {
        xasprintf(&fname, "%s/tinc.conf", confbase);
        x = read_config_file(config_tree, fname);
 
        xasprintf(&fname, "%s/tinc.conf", confbase);
        x = read_config_file(config_tree, fname);
 
+       // We will try to read the conf files in the "conf.d" dir
+       if (x) {
+               char * dname;
+               xasprintf(&dname, "%s/conf.d", confbase);
+               DIR *dir = opendir (dname);
+               // If we can find this dir
+               if (dir) { 
+                       struct dirent *ep;
+                       // We list all the files in it
+                       while (x && (ep = readdir (dir))) {
+                               size_t l = strlen(ep->d_name);
+                               // And we try to read the ones that end with ".conf"
+                               if (l > 5 && !strcmp(".conf", & ep->d_name[ l - 5 ])) {
+                                       free(fname);
+                                       xasprintf(&fname, "%s/%s", dname, ep->d_name);
+                                       logger(LOG_DEBUG, "Reading conf file \"%s\"", fname);
+                                       x = read_config_file(config_tree, fname);
+                               }
+                       }
+                       closedir (dir);
+               }
+               free(dname);
+       }
+
        if(!x) {                                /* System error: complain */
                logger(LOG_ERR, "Failed to read `%s': %s", fname, strerror(errno));
        }
        if(!x) {                                /* System error: complain */
                logger(LOG_ERR, "Failed to read `%s': %s", fname, strerror(errno));
        }