Hi again,

Almost there...
I found out that replacing in each cyrus.header file the ACL line "john.doe" by 
"john....@example.net" did the trick ! Now "john....@example.net" is the mailbox owner, and not 
"john.doe" anymore.

Everything works fine, except that now my log file is cluttered with :
Header CRC mismatch for mailbox example.net!user.john.doe

My questions :
- is there a way (other than messing with cyrus.header) to modify a mailbox 
owner ?
- if not, is there a way to rebuild cyrus.index, so it can take into account 
the new cyrus.header's CRC ?

------------------------------

Message: 3
Date: Mon, 14 May 2018 22:00:53 +0100
From: Chentao Credungtao<chentaocredung...@yahoo.com>
To:info-cyrus@lists.andrew.cmu.edu
Subject: how can I check (and change) the owner of a mailbox ?
Message-ID:<235ebac8-d275-292e-8a6a-9f247fe51...@yahoo.com>
Content-Type: text/plain; charset=utf-8; format=flowed

Hi,

How can I check who the mailbox owner is ? How can I change it ? I'd
like to change owner john.doe tojohn....@example.net


Here's why :

I'm currently testing the migration of a single-domain Cyrus IMAP server
to a multi-domain one. I'm doing the migration on the filesystem level,
copying files from the old to the new server.

It works fine, except for the mailbox owner, it seems to be the old one,
without the e-mail domain.


Here is what I did :

- 1/? First I created user/john.doe on domain example.net on the new
server,? using autocreate (so it created
/var/spool/cyrus/mail/domain/e/example.net/j/user/john.doe)

- 2/ The I checked this mailbox's ACLs :
$ cyradm --usercy...@example.net  localhost
localhost> lam user/john.doe
user/john.doe:
 ?john....@example.net  lrswipkxtecdan

- 3/ Then I stopped cyrus

- 4/ Then I copied/var/spool/cyrus/mail/j/john.doe/*? from the old
(single domain) server to
/var/spool/cyrus/mail/domain/e/example.net/j/user/john.doe on the new
(multi-domain) server

- 5/ Then a little reconstruct : su -c "/usr/lib/cyrus/bin/reconstruct
-r -fuser/john....@example.net" cyrus -s /bin/bash

- 6/ Starting cyrus

- 7/ Checking ACLs :
$ cyradm --usercy...@example.net  localhost
Password:
localhost> lam user/john.doe
user/john.doe:
 ? john.doe lrswipkxtecda

- 8/ OK, so now john.doe (and notjohn....@example.net  like before)
seems to be the owner of user/john.doe

- 9/ When I try to log in (with my webmail for example), it doesn't
work. From the logfiles :
May 14 21:40:04 sogod [1596]: [ERROR]
<0x0x5648006b5480[NGImap4Connection]> could not select URL:
imaps://john.doe%40example.net@mail/INBOX/: {RawResponse =
"{ResponseResult = {description = \"Mailbox does not exist\"; result =
no; tagId = 6; }; }"; reason = "Mailbox does not exist"; result = 0; }

- 10/ Back to cyradm, and granting full rights tojohn....@example.net  :
$ cyradm --usercy...@example.net  localhost
Password:
localhost> sam user/john.doe*john....@example.net  lrswipkxtecdan

- 11/ OK, after that webmail works fine.

- 12/ Back to cyradm, where my ACLs now look like :
$ cyradm --usercy...@example.net  localhost
Password:
localhost> lam user/john.doe
user/john.doe:
 ? john.doe lrswipkxtecda
 ?john....@example.net  lrswipkxtecdan

So, I though I don't need the john.doe ACL anymore, and tried to remove it :

localhost> dam user/john.doe john.doe

But I still have "lkxca" ACLs, which are the owner's implicit ACLs :

localhost> lam user/john.doe
john....@example.net  lrswipkxtecdan
john.doe lkxca

So I guess after the migration the owner of the mailbox is john.doe, and
notjohn....@example.net  like before the migration. How can I change
this ? How can I get rid of john.doe's ACLs ?



Thanks,

Chen

----
Cyrus Home Page: http://www.cyrusimap.org/
List Archives/Info: http://lists.andrew.cmu.edu/pipermail/info-cyrus/
To Unsubscribe:
https://lists.andrew.cmu.edu/mailman/listinfo/info-cyrus

Reply via email to