[sr-dev] git:5.2:fa777881: cfgt: don't try to create dir if it already exists
Victor Seva
linuxmaniac at torreviejawireless.org
Thu Nov 28 14:56:05 CET 2019
Module: kamailio
Branch: 5.2
Commit: fa7778816de04aea0b23f4cce06fd8af6da598fb
URL: https://github.com/kamailio/kamailio/commit/fa7778816de04aea0b23f4cce06fd8af6da598fb
Author: Victor Seva <linuxmaniac at torreviejawireless.org>
Committer: Victor Seva <linuxmaniac at torreviejawireless.org>
Date: 2019-11-28T14:55:42+01:00
cfgt: don't try to create dir if it already exists
(cherry picked from commit 6918a96cc61fa0b15e09db01bb02e9b9f8c78abf)
---
Modified: src/modules/cfgt/cfgt_int.c
---
Diff: https://github.com/kamailio/kamailio/commit/fa7778816de04aea0b23f4cce06fd8af6da598fb.diff
Patch: https://github.com/kamailio/kamailio/commit/fa7778816de04aea0b23f4cce06fd8af6da598fb.patch
---
diff --git a/src/modules/cfgt/cfgt_int.c b/src/modules/cfgt/cfgt_int.c
index 1c5b938e9c..0e3bfecb5d 100644
--- a/src/modules/cfgt/cfgt_int.c
+++ b/src/modules/cfgt/cfgt_int.c
@@ -322,13 +322,16 @@ void cfgt_save_node(cfgt_node_p node)
FILE *fp;
str dest = STR_NULL;
int dir = 0;
+ struct stat sb;
if(_cfgt_get_filename(node->msgid, node->uuid, &dest, &dir) < 0) {
LM_ERR("can't build filename\n");
return;
}
dest.s[dir] = '\0';
LM_DBG("dir [%s]\n", dest.s);
- if(mkdir(dest.s, S_IRWXO | S_IXGRP | S_IRWXU) < 0) {
+ if (stat(dest.s, &sb) == 0 && S_ISDIR(sb.st_mode)) {
+ LM_DBG("dir [%s] already existing\n", dest.s);
+ } else if(mkdir(dest.s, S_IRWXO | S_IXGRP | S_IRWXU) < 0) {
LM_ERR("failed to make directory: %s\n", strerror(errno));
return;
}
More information about the sr-dev
mailing list