From e94fa076cbe6335a9d5e498967e1ed4098750eb3 Mon Sep 17 00:00:00 2001 From: Mark Spencer <markster@digium.com> Date: Sun, 5 Sep 2004 18:31:50 +0000 Subject: [PATCH] Fix some small voicemail password bugs (bug #2373) git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@3727 65c4cc65-6c06-0410-ace0-fbb531ad65f3 --- apps/app_voicemail.c | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/apps/app_voicemail.c b/apps/app_voicemail.c index 4684e6fedd..7a80aa82f8 100755 --- a/apps/app_voicemail.c +++ b/apps/app_voicemail.c @@ -589,6 +589,7 @@ static void vm_change_password(struct ast_vm_user *vmu, char *newpassword) char tmpin[AST_CONFIG_MAX_PATH]; char tmpout[AST_CONFIG_MAX_PATH]; char *user, *pass, *rest, *trim, *tempcontext; + struct stat statbuf; tempcontext = NULL; snprintf(tmpin, sizeof(tmpin), "%s/voicemail.conf", ast_config_AST_CONFIG_DIR); snprintf(tmpout, sizeof(tmpout), "%s/voicemail.conf.new", ast_config_AST_CONFIG_DIR); @@ -663,7 +664,7 @@ static void vm_change_password(struct ast_vm_user *vmu, char *newpassword) /* Compare user, pass AND context */ if (user && *user && !strcmp(user, vmu->mailbox) && - pass && *pass && !strcmp(pass, vmu->password) && + pass && !strcmp(pass, vmu->password) && currcontext && *currcontext && !strcmp(currcontext, vmu->context)) { /* This is the line */ if (rest) { @@ -680,6 +681,9 @@ static void vm_change_password(struct ast_vm_user *vmu, char *newpassword) fclose(configin); fclose(configout); + stat((char *)tmpin, &statbuf); + chmod((char *)tmpout, statbuf.st_mode); + chown((char *)tmpout, statbuf.st_uid, statbuf.st_gid); unlink((char *)tmpin); rename((char *)tmpout,(char *)tmpin); reset_user_pw(vmu->context, vmu->mailbox, newpassword); -- GitLab