- prepare 1.4
authorMichael Wallner <mike@php.net>
Sat, 15 Apr 2006 13:06:51 +0000 (13:06 +0000)
committerMichael Wallner <mike@php.net>
Sat, 15 Apr 2006 13:06:51 +0000 (13:06 +0000)
- add server configuration merging function (needed for 2.2?)

configure
configure.in
mod_domaintree.c

index c986c2fd0d4459b4b1fddb0fda5ffa001be59977..f4d2284db52dbaf1f4c740eef96d5bcd4c5cda16 100755 (executable)
--- a/configure
+++ b/configure
@@ -3318,7 +3318,7 @@ fi;
 echo "$as_me:$LINENO: checking for apxs2" >&5
 echo $ECHO_N "checking for apxs2... $ECHO_C" >&6
 APXS2=apxs2
 echo "$as_me:$LINENO: checking for apxs2" >&5
 echo $ECHO_N "checking for apxs2... $ECHO_C" >&6
 APXS2=apxs2
-if test "$with_apxs2" -a -x "$with_apxs"; then
+if test "$with_apxs2" -a -x "$with_apxs2"; then
        APXS2=$with_apxs2
        echo "$as_me:$LINENO: result: $APXS2" >&5
 echo "${ECHO_T}$APXS2" >&6
        APXS2=$with_apxs2
        echo "$as_me:$LINENO: result: $APXS2" >&5
 echo "${ECHO_T}$APXS2" >&6
index 28f3caaa92e7c3e76971c9f0e619454c5c56968f..924fa92e1f5549a9cec23d28f5daa733544a8dc1 100644 (file)
@@ -1,6 +1,6 @@
 
 AC_PREREQ(2.59)
 
 AC_PREREQ(2.59)
-AC_INIT(mod_domaintree, 1.3, mike@iworks.at)
+AC_INIT(mod_domaintree, 1.4, mike@iworks.at)
 
 AC_CONFIG_SRCDIR([mod_domaintree.c])
 AC_CONFIG_HEADER([config.h])
 
 AC_CONFIG_SRCDIR([mod_domaintree.c])
 AC_CONFIG_HEADER([config.h])
@@ -15,7 +15,7 @@ AC_ARG_WITH([apxs2], AC_HELP_STRING([--with-apxs2], [where the apxs2 tool is loc
 
 AC_MSG_CHECKING([for apxs2])
 APXS2=apxs2
 
 AC_MSG_CHECKING([for apxs2])
 APXS2=apxs2
-if test "$with_apxs2" -a -x "$with_apxs"; then
+if test "$with_apxs2" -a -x "$with_apxs2"; then
        APXS2=$with_apxs2
        AC_MSG_RESULT([$APXS2])
 else
        APXS2=$with_apxs2
        AC_MSG_RESULT([$APXS2])
 else
index d33aef4715796883e69c838c042ef659c79392ec..018178ae94cbd939d364a7ac98626af98806885f 100644 (file)
@@ -53,8 +53,8 @@
 #endif
 
 #define MODULE "mod_domaintree"
 #endif
 
 #define MODULE "mod_domaintree"
-#define AUTHOR "<mike@iworks.at"
-#define VERSION "1.3"
+#define AUTHOR "<mike@iworks.at>"
+#define VERSION "1.4"
 
 /* {{{ Includes */
 
 
 /* {{{ Includes */
 
@@ -87,10 +87,12 @@ module AP_MODULE_DECLARE_DATA domaintree_module;
 /* }}} */
 /* {{{ Macros & Types */
 
 /* }}} */
 /* {{{ Macros & Types */
 
-#define MOD_DT_CNF domaintree_conf
-#define MOD_DT_PTR (&domaintree_module)
+#define MDT_CNF domaintree_conf
+#define MDT_PTR (&domaintree_module)
 
 
-#define GET_MOD_DT_CNF(srv) ((MOD_DT_CNF *) ap_get_module_config((srv)->module_config, MOD_DT_PTR))
+#define GET_MDT_CNF(srv) ((MDT_CNF *) ap_get_module_config((srv)->module_config, MDT_PTR))
+
+#define IF_SET_ELSE(a, b) (a != -1) ? (a) : (b)
 
 #define NUL '\0'
 #define EMPTY(str) ((str == NULL) || (*(str) == NUL))
 
 #define NUL '\0'
 #define EMPTY(str) ((str == NULL) || (*(str) == NUL))
@@ -108,12 +110,12 @@ typedef struct {
        apr_table_t     *faketable;
 } aliases_t;
 
        apr_table_t     *faketable;
 } aliases_t;
 
-struct dircache_entry {
+typedef struct {
        char            *host;
        char            *path;
        apr_time_t      lacc;
        apr_pool_t      *pool;
        char            *host;
        char            *path;
        apr_time_t      lacc;
        apr_pool_t      *pool;
-};
+} dircache_entry_t;
 
 typedef struct {
        long                            clim;
 
 typedef struct {
        long                            clim;
@@ -244,7 +246,7 @@ local char *struniqchr(char *string, char uniq)
        return string;
 }
 
        return string;
 }
 
-local char *domaintree_host(apr_pool_t *pool, MOD_DT_CNF *DT, const char *host_name)
+local char *domaintree_host(apr_pool_t *pool, MDT_CNF *DT, const char *host_name)
 {
        size_t len;
        char *port, *host;
 {
        size_t len;
        char *port, *host;
@@ -277,18 +279,18 @@ local char *domaintree_host(apr_pool_t *pool, MOD_DT_CNF *DT, const char *host_n
        return host;
 }
 
        return host;
 }
 
-local char *domaintree_path(apr_pool_t *pool, MOD_DT_CNF *DT, const char *host_name)
+local char *domaintree_path(apr_pool_t *pool, MDT_CNF *DT, const char *host_name)
 {
 {
-       long depth = 0;
+       long depth = 0, maxdepth = IF_SET_ELSE(DT->maxdepth, 20);
        const char *host = host_name;
        char *path = NULL, *host_ptr;
        
        while ((host_ptr = strchr(host, '.'))) {
                
                /* check max depth */
        const char *host = host_name;
        char *path = NULL, *host_ptr;
        
        while ((host_ptr = strchr(host, '.'))) {
                
                /* check max depth */
-               if (++depth > DT->maxdepth) {
+               if (++depth > maxdepth) {
                        DT_LOG_ERR
                        DT_LOG_ERR
-                               "DomainTree: maxdepth exceeded (%ld)", DT->maxdepth
+                               "DomainTree: maxdepth exceeded (%ld)", maxdepth
                        DT_LOG_END
                        return NULL;
                }
                        DT_LOG_END
                        return NULL;
                }
@@ -297,7 +299,7 @@ local char *domaintree_path(apr_pool_t *pool, MOD_DT_CNF *DT, const char *host_n
                if (host_ptr - host) {
                        
                        /* strip WWW */
                if (host_ptr - host) {
                        
                        /* strip WWW */
-                       if (DT->stripwww && (depth == 1) && (!strncmp(host, "www.", sizeof("www")))) {
+                       if ((DT->stripwww > 0) && (depth == 1) && (!strncmp(host, "www.", sizeof("www")))) {
                                DT_LOG_DBG
                                        "DomainTree: strip www"
                                DT_LOG_END
                                DT_LOG_DBG
                                        "DomainTree: strip www"
                                DT_LOG_END
@@ -321,7 +323,7 @@ local char *domaintree_path(apr_pool_t *pool, MOD_DT_CNF *DT, const char *host_n
        return path;
 }
 
        return path;
 }
 
-local void domaintree_fake(apr_pool_t *pool, MOD_DT_CNF *DT, char **path)
+local void domaintree_fake(apr_pool_t *pool, MDT_CNF *DT, char **path)
 {
        int i, more;
        long recurlevel = 0;
 {
        int i, more;
        long recurlevel = 0;
@@ -361,17 +363,17 @@ local void domaintree_fake(apr_pool_t *pool, MOD_DT_CNF *DT, char **path)
                                DT_LOG_END
                        }
                }
                                DT_LOG_END
                        }
                }
-       } while (more && DT->aliases.recursion);
+       } while (more && (DT->aliases.recursion > 0));
        
        *path = apr_pstrdup(pool, struniqchr(*path, '/'));
        
        apr_pool_destroy(local_pool);
 }
 
        
        *path = apr_pstrdup(pool, struniqchr(*path, '/'));
        
        apr_pool_destroy(local_pool);
 }
 
-local char *domaintree_cache_get(MOD_DT_CNF *DT, apr_time_t atime, const char *host)
+local char *domaintree_cache_get(MDT_CNF *DT, apr_time_t atime, const char *host)
 {
        char *path = NULL;
 {
        char *path = NULL;
-       struct dircache_entry *cache_entry;
+       dircache_entry_t *cache_entry;
        
        apr_global_mutex_lock(DT->dircache.lock);
        
        
        apr_global_mutex_lock(DT->dircache.lock);
        
@@ -391,13 +393,13 @@ local char *domaintree_cache_get(MOD_DT_CNF *DT, apr_time_t atime, const char *h
        return path;
 }
 
        return path;
 }
 
-local void domaintree_cache_set(MOD_DT_CNF *DT, apr_time_t atime, const char *host, const char *path)
+local void domaintree_cache_set(MDT_CNF *DT, apr_time_t atime, const char *host, const char *path)
 {
        apr_pool_t *pool;
 {
        apr_pool_t *pool;
-       struct dircache_entry *cache_entry;
+       dircache_entry_t *cache_entry;
        
        apr_pool_create(&pool, DT->dircache.pool);
        
        apr_pool_create(&pool, DT->dircache.pool);
-       cache_entry = apr_palloc(pool, sizeof(struct dircache_entry));
+       cache_entry = apr_palloc(pool, sizeof(dircache_entry_t));
        
        cache_entry->pool = pool;
        cache_entry->lacc = atime;
        
        cache_entry->pool = pool;
        cache_entry->lacc = atime;
@@ -408,16 +410,16 @@ local void domaintree_cache_set(MOD_DT_CNF *DT, apr_time_t atime, const char *ho
        
        if (apr_hash_count(DT->dircache.hmap) >= DT->dircache.clim) {
                apr_hash_index_t *idx;
        
        if (apr_hash_count(DT->dircache.hmap) >= DT->dircache.clim) {
                apr_hash_index_t *idx;
-               struct dircache_entry *purge_this = NULL;
+               dircache_entry_t *purge_this = NULL;
        
                DT_LOG_WRN
                                "DomainTree: reached cache limit (%ld)", DT->dircache.clim
                DT_LOG_END
                
                for (idx = apr_hash_first(DT->dircache.pool, DT->dircache.hmap); idx; idx = apr_hash_next(idx)) {
        
                DT_LOG_WRN
                                "DomainTree: reached cache limit (%ld)", DT->dircache.clim
                DT_LOG_END
                
                for (idx = apr_hash_first(DT->dircache.pool, DT->dircache.hmap); idx; idx = apr_hash_next(idx)) {
-                       struct dircache_entry *current;
+                       dircache_entry_t *current;
                
                
-                       apr_hash_this(idx, NULL, NULL, (void **) &current);
+                       apr_hash_this(idx, NULL, NULL, (void *) &current);
                        if ((!purge_this) || (purge_this->lacc > current->lacc)) {
                                purge_this = current;
                        }
                        if ((!purge_this) || (purge_this->lacc > current->lacc)) {
                                purge_this = current;
                        }
@@ -451,10 +453,10 @@ static STATUS domaintree_hook_post_config(apr_pool_t *pconf, apr_pool_t *plog, a
 
 static STATUS domaintree_hook_translate_name(request_rec *r)
 {
 
 static STATUS domaintree_hook_translate_name(request_rec *r)
 {
-       MOD_DT_CNF *DT = NULL;
+       MDT_CNF *DT = NULL;
        char *host, *path, *docroot;
        
        char *host, *path, *docroot;
        
-       if ((!(DT = GET_MOD_DT_CNF(r->server))) || (!DT->enabled)) {
+       if ((!(DT = GET_MDT_CNF(r->server))) || (DT->enabled < 1)) {
                return DECLINED;
        }
        
                return DECLINED;
        }
        
@@ -468,7 +470,7 @@ static STATUS domaintree_hook_translate_name(request_rec *r)
        }
        
        /* check cache */
        }
        
        /* check cache */
-       if ((!DT->dircache.clim) || (!(path = domaintree_cache_get(DT, r->request_time, host)))) {
+       if ((DT->dircache.clim < 1) || (!(path = domaintree_cache_get(DT, r->request_time, host)))) {
                /* build path */
                if (!(path = domaintree_path(r->pool, DT, host))) {
                        return DECLINED;
                /* build path */
                if (!(path = domaintree_path(r->pool, DT, host))) {
                        return DECLINED;
@@ -489,7 +491,7 @@ static STATUS domaintree_hook_translate_name(request_rec *r)
        docroot = struniqchr(apr_pstrcat(r->pool, DT->prefix, "/", path, "/", DT->suffix, "/", NULL), '/');
        
        /* stat docroot */
        docroot = struniqchr(apr_pstrcat(r->pool, DT->prefix, "/", path, "/", DT->suffix, "/", NULL), '/');
        
        /* stat docroot */
-       if (DT->statroot) {
+       if (DT->statroot > 0) {
                apr_finfo_t sb;
                
                switch (apr_stat(&sb, docroot, APR_FINFO_MIN, r->pool))
                apr_finfo_t sb;
                
                switch (apr_stat(&sb, docroot, APR_FINFO_MIN, r->pool))
@@ -537,23 +539,21 @@ static void domaintree_hooks(apr_pool_t *pool)
 
 static void *domaintree_create_srv(apr_pool_t *p, server_rec *s)
 {
 
 static void *domaintree_create_srv(apr_pool_t *p, server_rec *s)
 {
-       MOD_DT_CNF *DT;
-       
-       DT = (MOD_DT_CNF *) apr_palloc(p, sizeof(MOD_DT_CNF));
+       MDT_CNF *DT= (MDT_CNF *) apr_palloc(p, sizeof(MDT_CNF));
        
        DT->server = s;
        
        DT->server = s;
-       DT->enabled = 0;
-       DT->stripwww = 1;
-       DT->statroot = 0;
-       DT->maxdepth = 20;
+       DT->enabled = -1;
+       DT->stripwww = -1;
+       DT->statroot = -1;
+       DT->maxdepth = -1;
        
        DT->prefix = "/var/www";
        DT->suffix = "public_html";
        
        
        DT->prefix = "/var/www";
        DT->suffix = "public_html";
        
-       DT->aliases.recursion = 0;
+       DT->aliases.recursion = -1;
        DT->aliases.faketable = apr_table_make(p, 0);
        
        DT->aliases.faketable = apr_table_make(p, 0);
        
-       DT->dircache.clim = 0;
+       DT->dircache.clim = -1;
        DT->dircache.hmap = apr_hash_make(p);
        apr_pool_create(&DT->dircache.pool, p);
        apr_global_mutex_create(&DT->dircache.lock, __FILE__, APR_LOCK_DEFAULT, p);
        DT->dircache.hmap = apr_hash_make(p);
        apr_pool_create(&DT->dircache.pool, p);
        apr_global_mutex_create(&DT->dircache.lock, __FILE__, APR_LOCK_DEFAULT, p);
@@ -561,33 +561,53 @@ static void *domaintree_create_srv(apr_pool_t *p, server_rec *s)
        return DT;
 }
 
        return DT;
 }
 
+static void *domaintree_merge_srv(apr_pool_t *p, void *old_cfg_ptr, void *new_cfg_ptr)
+{
+       MDT_CNF *old_cfg = (MDT_CNF *) old_cfg_ptr;
+       MDT_CNF *new_cfg = (MDT_CNF *) new_cfg_ptr;
+       MDT_CNF *mrg_cfg = (MDT_CNF *) domaintree_create_srv(p, new_cfg->server);
+       
+       mrg_cfg->enabled = IF_SET_ELSE(new_cfg->enabled, old_cfg->enabled);
+       mrg_cfg->stripwww = IF_SET_ELSE(new_cfg->stripwww, old_cfg->stripwww);
+       mrg_cfg->statroot = IF_SET_ELSE(new_cfg->statroot, old_cfg->statroot);
+       mrg_cfg->maxdepth = IF_SET_ELSE(new_cfg->maxdepth, old_cfg->maxdepth);
+       
+       mrg_cfg->prefix = EMPTY(new_cfg->prefix) ? EMPTY(old_cfg->prefix) ? "/var/www" : old_cfg->prefix : new_cfg->prefix;
+       mrg_cfg->suffix = EMPTY(new_cfg->suffix) ? EMPTY(old_cfg->suffix) ? "public_html" : old_cfg->suffix : new_cfg->suffix;
+       
+       mrg_cfg->aliases.recursion = IF_SET_ELSE(new_cfg->aliases.recursion, old_cfg->aliases.recursion);
+       mrg_cfg->dircache.clim = IF_SET_ELSE(new_cfg->dircache.clim, old_cfg->dircache.clim);
+       
+       return mrg_cfg;
+}
+
 static const char *domaintree_enable(cmd_parms *cmd, void *conf, int flag)
 {
 static const char *domaintree_enable(cmd_parms *cmd, void *conf, int flag)
 {
-       GET_MOD_DT_CNF(cmd->server)->enabled = flag;
+       GET_MDT_CNF(cmd->server)->enabled = flag;
        return NULL;
 }
 
 static const char *domaintree_stripwww(cmd_parms *cmd, void *conf, int flag)
 {
        return NULL;
 }
 
 static const char *domaintree_stripwww(cmd_parms *cmd, void *conf, int flag)
 {
-       GET_MOD_DT_CNF(cmd->server)->stripwww = flag;
+       GET_MDT_CNF(cmd->server)->stripwww = flag;
        return NULL;
 }
 
 static const char *domaintree_statroot(cmd_parms *cmd, void *conf, int flag)
 {
        return NULL;
 }
 
 static const char *domaintree_statroot(cmd_parms *cmd, void *conf, int flag)
 {
-       GET_MOD_DT_CNF(cmd->server)->statroot = flag;
+       GET_MDT_CNF(cmd->server)->statroot = flag;
        return NULL;
 }
 
 static const char *domaintree_prefix(cmd_parms *cmd, void *conf, const char *prefix)
 {
        return NULL;
 }
 
 static const char *domaintree_prefix(cmd_parms *cmd, void *conf, const char *prefix)
 {
-       GET_MOD_DT_CNF(cmd->server)->prefix = EMPTY(prefix) ? "/" : trim(apr_pstrdup(cmd->pool, prefix), strlen(prefix), '/', TRIM_RIGHT);
+       GET_MDT_CNF(cmd->server)->prefix = EMPTY(prefix) ? "/" : trim(apr_pstrdup(cmd->pool, prefix), strlen(prefix), '/', TRIM_RIGHT);
        return NULL;
 }
 
 static const char *domaintree_suffix(cmd_parms *cmd, void *conf, const char *suffix)
 {
        return NULL;
 }
 
 static const char *domaintree_suffix(cmd_parms *cmd, void *conf, const char *suffix)
 {
-       GET_MOD_DT_CNF(cmd->server)->suffix = EMPTY(suffix) ? "" : trim(apr_pstrdup(cmd->pool, suffix), strlen(suffix), '/', TRIM_BOTH);
+       GET_MDT_CNF(cmd->server)->suffix = EMPTY(suffix) ? "" : trim(apr_pstrdup(cmd->pool, suffix), strlen(suffix), '/', TRIM_BOTH);
        return NULL;
 }
 
        return NULL;
 }
 
@@ -597,7 +617,7 @@ static const char *domaintree_maxdepth(cmd_parms *cmd, void *conf, const char *m
        
        if ((depth = atol(max_depth))) {
                if (depth > 0L) {
        
        if ((depth = atol(max_depth))) {
                if (depth > 0L) {
-                       GET_MOD_DT_CNF(cmd->server)->maxdepth = depth;
+                       GET_MDT_CNF(cmd->server)->maxdepth = depth;
                } else {
                        return "Maximum DomainTree depth cannot be negative.";
                }
                } else {
                        return "Maximum DomainTree depth cannot be negative.";
                }
@@ -612,7 +632,7 @@ static const char *domaintree_aliasrecursion(cmd_parms *cmd, void *conf, const c
        
        if ((recursion = atol(alias_recursion))) {
                if (recursion > 0L) {
        
        if ((recursion = atol(alias_recursion))) {
                if (recursion > 0L) {
-                       GET_MOD_DT_CNF(cmd->server)->aliases.recursion = recursion;
+                       GET_MDT_CNF(cmd->server)->aliases.recursion = recursion;
                } else {
                        return "DomainTree alias recursion cannot be negative.";
                }
                } else {
                        return "DomainTree alias recursion cannot be negative.";
                }
@@ -625,7 +645,7 @@ static const char *domaintree_alias(cmd_parms *cmd, void *conf, const char *fake
 {
        char *f = strtr(apr_pstrdup(cmd->pool, fake), '.', '/'), *r = strtr(apr_pstrdup(cmd->pool, real), '.', '/');
        
 {
        char *f = strtr(apr_pstrdup(cmd->pool, fake), '.', '/'), *r = strtr(apr_pstrdup(cmd->pool, real), '.', '/');
        
-       apr_table_set(GET_MOD_DT_CNF(cmd->server)->aliases.faketable, trim(f, strlen(f), '/', TRIM_BOTH), trim(r, strlen(r), '/', TRIM_BOTH));
+       apr_table_set(GET_MDT_CNF(cmd->server)->aliases.faketable, trim(f, strlen(f), '/', TRIM_BOTH), trim(r, strlen(r), '/', TRIM_BOTH));
        
        return NULL;
 }
        
        return NULL;
 }
@@ -636,7 +656,7 @@ static const char *domaintree_cache(cmd_parms *cmd, void *conf, const char *cach
        
        if ((limit = atol(cache))) {
                if (limit > 0L) {
        
        if ((limit = atol(cache))) {
                if (limit > 0L) {
-                       GET_MOD_DT_CNF(cmd->server)->dircache.clim = limit;
+                       GET_MDT_CNF(cmd->server)->dircache.clim = limit;
                } else {
                        return "DomainTree cache limit cannot be negative.";
                }
                } else {
                        return "DomainTree cache limit cannot be negative.";
                }
@@ -694,7 +714,7 @@ static command_rec domaintree_commands[] = {
                "DomainTreeCache", domaintree_cache, NULL, RSRC_CONF,
                "DomainTree server-wide host to directory cache; specify how many cache entries to allow (default: 0 = turned off)"
        ),
                "DomainTreeCache", domaintree_cache, NULL, RSRC_CONF,
                "DomainTree server-wide host to directory cache; specify how many cache entries to allow (default: 0 = turned off)"
        ),
-
+       
        { NULL }
 };
 
        { NULL }
 };
 
@@ -706,7 +726,7 @@ module AP_MODULE_DECLARE_DATA domaintree_module = {
        NULL,                                   /* create per-dir */
        NULL,                                   /* merge  per-dir */
        domaintree_create_srv,  /* create per-server */
        NULL,                                   /* create per-dir */
        NULL,                                   /* merge  per-dir */
        domaintree_create_srv,  /* create per-server */
-       NULL,                                   /* merge  per-server */
+       domaintree_merge_srv,   /* merge  per-server */
        domaintree_commands,    /* config commands */
        domaintree_hooks                /* hooks */
 };
        domaintree_commands,    /* config commands */
        domaintree_hooks                /* hooks */
 };