aboutsummaryrefslogtreecommitdiffstats
path: root/config.c
diff options
context:
space:
mode:
authorkpfleming <kpfleming@f38db490-d61c-443f-a65b-d21fe96a405b>2005-10-31 21:08:55 +0000
committerkpfleming <kpfleming@f38db490-d61c-443f-a65b-d21fe96a405b>2005-10-31 21:08:55 +0000
commitdf798b149fdd966523f779822adcc3204560f442 (patch)
tree81e0384dba3a209785f43a6a9bc601fd34a17346 /config.c
parente454aed806fe1d1693ddc44fad059f9cf9ecf727 (diff)
ignore non-regular files during config parsing (issue #5510, different fix)
git-svn-id: http://svn.digium.com/svn/asterisk/trunk@6902 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'config.c')
-rwxr-xr-xconfig.c34
1 files changed, 23 insertions, 11 deletions
diff --git a/config.c b/config.c
index e585cb13e..f279b1640 100755
--- a/config.c
+++ b/config.c
@@ -30,6 +30,7 @@
#include <string.h>
#include <errno.h>
#include <time.h>
+#include <sys/stat.h>
#define AST_INCLUDE_GLOB 1
#ifdef AST_INCLUDE_GLOB
#ifdef __Darwin__
@@ -538,6 +539,7 @@ static struct ast_config *config_text_file_load(const char *database, const char
int comment = 0, nest[MAX_NESTED_COMMENTS];
struct ast_category *cat = NULL;
int count = 0;
+ struct stat statbuf;
cat = ast_config_get_current_category(cfg);
@@ -569,11 +571,26 @@ static struct ast_config *config_text_file_load(const char *database, const char
for (i=0; i<globbuf.gl_pathc; i++) {
ast_copy_string(fn, globbuf.gl_pathv[i], sizeof(fn));
#endif
- if ((option_verbose > 1) && !option_debug) {
- ast_verbose( VERBOSE_PREFIX_2 "Parsing '%s': ", fn);
- fflush(stdout);
- }
- if ((f = fopen(fn, "r"))) {
+ do {
+ if (stat(fn, &statbuf)) {
+ ast_log(LOG_WARNING, "Cannot stat() '%s', ignoring\n", fn);
+ continue;
+ }
+ if (!S_ISREG(statbuf.st_mode)) {
+ ast_log(LOG_WARNING, "'%s' is not a regular file, ignoring\n", fn);
+ continue;
+ }
+ if ((option_verbose > 1) && !option_debug) {
+ ast_verbose(VERBOSE_PREFIX_2 "Parsing '%s': ", fn);
+ fflush(stdout);
+ }
+ if (!(f = fopen(fn, "r"))) {
+ if (option_debug)
+ ast_log(LOG_DEBUG, "No file to parse: %s\n", fn);
+ else if (option_verbose > 1)
+ ast_verbose( "Not found (%s)\n", strerror(errno));
+ continue;
+ }
count++;
if (option_debug)
ast_log(LOG_DEBUG, "Parsing %s\n", fn);
@@ -641,12 +658,7 @@ static struct ast_config *config_text_file_load(const char *database, const char
}
}
fclose(f);
- } else { /* can't open file */
- if (option_debug)
- ast_log(LOG_DEBUG, "No file to parse: %s\n", fn);
- else if (option_verbose > 1)
- ast_verbose( "Not found (%s)\n", strerror(errno));
- }
+ } while(0);
if (comment) {
ast_log(LOG_WARNING,"Unterminated comment detected beginning on line %d\n", nest[comment]);
}