dovecot: When creating mailboxes, set cur/new/tmp directories' g...
dovecot at dovecot.org
dovecot at dovecot.org
Sun Sep 9 06:26:12 EEST 2007
details: http://hg.dovecot.org/dovecot/rev/1c90552923ba
changeset: 6366:1c90552923ba
user: Timo Sirainen <tss at iki.fi>
date: Sun Sep 09 06:26:01 2007 +0300
description:
When creating mailboxes, set cur/new/tmp directories' group to
dovecot-shared file's group.
diffstat:
1 file changed, 8 insertions(+), 2 deletions(-)
src/lib-storage/index/maildir/maildir-storage.c | 10 ++++++++--
diffs (34 lines):
diff -r dee75c83d6f4 -r 1c90552923ba src/lib-storage/index/maildir/maildir-storage.c
--- a/src/lib-storage/index/maildir/maildir-storage.c Sun Sep 09 06:10:48 2007 +0300
+++ b/src/lib-storage/index/maildir/maildir-storage.c Sun Sep 09 06:26:01 2007 +0300
@@ -39,6 +39,7 @@ extern struct mailbox maildir_mailbox;
static MODULE_CONTEXT_DEFINE_INIT(maildir_mailbox_list_module,
&mailbox_list_module_register);
+static const char *maildir_subdirs[] = { "cur", "new", "tmp" };
static int verify_inbox(struct mail_storage *storage);
static int
@@ -550,6 +551,7 @@ static int maildir_create_shared(struct
{
const char *path;
mode_t old_mask;
+ unsigned int i;
int fd;
/* add the execute bit if either read or write bit is set */
@@ -562,8 +564,12 @@ static int maildir_create_shared(struct
umask(old_mask);
return -1;
}
- if (chown(dir, (uid_t)-1, gid) < 0) {
- mail_storage_set_critical(storage, "chown(%s) failed: %m", dir);
+ for (i = 0; i < N_ELEMENTS(maildir_subdirs); i++) {
+ path = t_strconcat(dir, "/", maildir_subdirs[i], NULL);
+ if (chown(path, (uid_t)-1, gid) < 0) {
+ mail_storage_set_critical(storage,
+ "chown(%s) failed: %m", path);
+ }
}
path = t_strconcat(dir, "/dovecot-shared", NULL);
More information about the dovecot-cvs
mailing list