From: Tilghman Lesher Date: Mon, 23 Jul 2007 22:38:06 +0000 (+0000) Subject: It was our stated intention for 1.4 that files created in app_voicemail should X-Git-Tag: 1.4.9~7 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=3630b5e47771e4d11869b20eee11b36a024cf0a8;p=thirdparty%2Fasterisk.git It was our stated intention for 1.4 that files created in app_voicemail should depend upon the umask. Unfortunately, mkstemp() creates files with mode 0600, regardless of the umask. This corrects that deficiency. git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/1.4@76708 65c4cc65-6c06-0410-ace0-fbb531ad65f3 --- diff --git a/apps/app_voicemail.c b/apps/app_voicemail.c index fe44aafa35..506ba23612 100644 --- a/apps/app_voicemail.c +++ b/apps/app_voicemail.c @@ -412,6 +412,8 @@ static char VM_SPOOL_DIR[PATH_MAX]; static char ext_pass_cmd[128]; +int my_umask; + #if ODBC_STORAGE #define tdesc "Comedian Mail (Voicemail System) with ODBC Storage" #elif IMAP_STORAGE @@ -1818,6 +1820,7 @@ static FILE *vm_mkftemp(char *template) { FILE *p = NULL; int pfd = mkstemp(template); + chmod(template, VOICEMAIL_FILE_MODE & ~my_umask); if (pfd > -1) { p = fdopen(pfd, "w+"); if (!p) { @@ -1967,6 +1970,7 @@ static void make_email_file(FILE *p, char *srcemail, struct ast_vm_user *vmu, in create_dirpath(tmpdir, sizeof(tmpdir), vmu->context, vmu->mailbox, "tmp"); snprintf(newtmp, sizeof(newtmp), "%s/XXXXXX", tmpdir); tmpfd = mkstemp(newtmp); + chmod(newtmp, VOICEMAIL_FILE_MODE & ~my_umask); if (option_debug > 2) ast_log(LOG_DEBUG, "newtmp: %s\n", newtmp); if (tmpfd > -1) { @@ -3041,6 +3045,7 @@ static int leave_voicemail(struct ast_channel *chan, char *ext, struct leave_vm_ #endif snprintf(tmptxtfile, sizeof(tmptxtfile), "%s/XXXXXX", tmpdir); txtdes = mkstemp(tmptxtfile); + chmod(tmptxtfile, VOICEMAIL_FILE_MODE & ~my_umask); if (txtdes < 0) { res = ast_streamfile(chan, "vm-mailboxfull", chan->language); if (!res) @@ -7750,6 +7755,8 @@ static int unload_module(void) static int load_module(void) { int res; + my_umask = umask(0); + umask(my_umask); res = ast_register_application(app, vm_exec, synopsis_vm, descrip_vm); res |= ast_register_application(app2, vm_execmain, synopsis_vmain, descrip_vmain); res |= ast_register_application(app3, vm_box_exists, synopsis_vm_box_exists, descrip_vm_box_exists);