autocreate.sieve doesn't work correct. temporary files
ellie timoney
ellie at fastmail.com
Thu Oct 8 19:36:57 EDT 2015
Hi again,
A couple more patches:
>> First I guest we need NOT here (?)
>
> Doh!
acsieve-sievedir.patch corrects this (though it sounds like you've
already made this change yourself -- included for completion though)
>> Oct 7 16:54:10 imapsync cyrus/imap[4062]: autocreate_sieve:
>> Unable to
create /var/spool/sieve/r/root/default.script.bc.NEW. Unknown error
This wouldn't be an "unknown error" if it would bother to tell us what
the error was....
acsieve-syslog.patch fixes this, so the actual error will be logged. It
also fixes a bunch of similar syslog calls through this function that
were doing the same unhelpful thing (i.e. logging an error without
including the error message).
I haven't had a chance to put together a test case for this yet, sorry.
In the meantime hopefully the improved error messages will help us track
this down. Thanks for sending through these reports! :)
Cheers,
ellie
On Fri, Oct 9, 2015, at 08:41 AM, ellie timoney wrote:
>> First I guest we need NOT here (?)
>
> Doh!
>
>> And second creating are failing with follow logs (yes I use 'root'
>> user for testing)
>>
>> Oct 7 16:54:10 imapsync cyrus/imap[4062]: User root, Inbox
>> subfolders, created 4, subscribed 4 Oct 7 16:54:10 imapsync
>> cyrus/imap[4062]: autocreate_sieve: Unable to create
>> /var/spool/sieve/r/root/default.script.bc.NEW. Unknown error Oct 7
>> 16:54:10 imapsync cyrus/imap[4062]: autocreate_sieve: User root,
>> default sieve script creation failed No one files/folders are
>> creating.
>>
>
> That path looks okay, at least. I expected more problems to shake out
> when the paths were fixed, so I'll look into this some more.
>
> - ellie
>
> On Thu, Oct 8, 2015, at 01:04 AM, Artyom Aleksandrov wrote:
>> Hi, thank you for patch. But it does not work. (( First I guest we
>> need NOT here (?)
>>
>> @@ -139,7 +138,7 @@ static int autocreate_sieve(const char *userid,
>> const char *source_script) }
>>
>> /* Check if sievedir is defined in imapd.conf */ - if(!(sieve_dir
>> = config_getstring(IMAPOPT_SIEVEDIR))) { +
>> if(config_getstring(IMAPOPT_SIEVEDIR)) { And second creating are
>> failing with follow logs (yes I use 'root' user for testing)
>>
>> Oct 7 16:54:10 imapsync cyrus/imap[4062]: User root, Inbox
>> subfolders, created 4, subscribed 4 Oct 7 16:54:10 imapsync
>> cyrus/imap[4062]: autocreate_sieve: Unable to create
>> /var/spool/sieve/r/root/default.script.bc.NEW. Unknown error Oct 7
>> 16:54:10 imapsync cyrus/imap[4062]: autocreate_sieve: User root,
>> default sieve script creation failed No one files/folders are
>> creating.
>>
>> On Tue, Oct 6, 2015 at 3:51 AM, ellie timoney
>> <ellie at fastmail.com> wrote:
>>> __
>>> Hi Artyom,
>>>
>>> Yeah wow, this is really gross.
>>>
>>> I'm pretty sure the gibberish in those "??????Default.script.bc"
>>> filenames is just whatever junk was in the (uninitialised)
>>> sieve_script_dir variable.
>>>
>>> I've had a rummage around, and there's a user_sieve_path() function
>>> in imap/user.c that does the heavy lifting of finding a user's sieve
>>> script directory. Looks like sieve_script_dir wanted to be the
>>> result of that. Your fix is on the right track. :)
>>>
>>> I've attached a patch for 2.5.x that fixes these paths using
>>> user_sieve_path(). It also fixes the assumption that the sievedir
>>> value will end in a "/", which it doesn't by default, and shouldn't
>>> need to. Can you try it out and see how it goes? (The patch should
>>> apply cleanly on any version of 2.5, this file has barely changed
>>> since it was created.)
>>>
>>> The rest of the autocreate_sieve() function is pretty awful too --
>>> there's almost certainly more bugs in there, and fixing the paths
>>> might just shake them out. I'd like to tidy this up significantly
>>> (and make some test cases for it), but in the meantime hopefully
>>> this will get you moving forward.
>>>
>>> Cheers,
>>>
>>>
>>> ellie
>>>
>>>
>>> On Tue, Oct 6, 2015, at 12:56 AM, Artyom Aleksandrov wrote:
>>>> Guys I don't understand hot it can work.
>>>>
>>>> I added additional logging and found that sieve_script_dir is not
>>>> defined. After adding this definition the problem gone.
>>>>
>>>>
>>>> 147 /* Check if autocreate_sieve_compiledscript is defined in
>>>> imapd.conf */ 148 if(!(compiled_source_script =
>>>> config_getstring(IMAPOPT_AUTOCREATE_SIEVE_SCRIPT_COMPILED))) { 149
>>>> syslog(LOG_WARNING, "autocreate_sieve:
>>>> autocreate_sieve_compiledscript option is not defined. Compiling
>>>> it"); 150 do_compile = 1; 151 } 152 153 char
>>>> userletter[1]; 154 userletter[0]=userid[0]; 155
>>>> snprintf(sieve_script_dir, MAX_FILENAME,
>>>> "%s%s/%s/",sieve_dir,userletter,userid);
>>>>
>>>>
>>>>
>>>> On Thu, Oct 1, 2015 at 8:49 PM, Artyom Aleksandrov
>>>> <mailing.list at tem4uk.ru> wrote:
>>>>> Is it works? Which version do you use? Could you guest the reason
>>>>> of the problem? How I can troubleshoot it?
>>>>>
>>>>> :/var/lib/cyrus# ls -la
>>>>> total 2176 -rw------- 1 cyrus mail 124 Sep 25 16:04
>>>>> ??????Default.script.bc -rw------- 1 cyrus mail 231 Sep 25
>>>>> 16:04 ??????Default.script.script lrwxrwxrwx 1 cyrus mail 17
>>>>> Sep 25 16:04 ??????defaultbc -> Default.script.bc -rw------- 1
>>>>> cyrus mail 124 Jul 2 12:38 ??N???Default.script.bc -rw-------
>>>>> 1 cyrus mail 231 Jul 2 12:38 ??N???Default.script.script
>>>>> lrwxrwxrwx 1 cyrus mail 17 Jul 2 12:38 ??N???defaultbc ->
>>>>> Default.script.bc -rw------- 1 cyrus mail 124 Sep 22 15:10
>>>>> 0#?>??Default.script.bc -rw------- 1 cyrus mail 231 Sep 22
>>>>> 15:10 0#?>??Default.script.script lrwxrwxrwx 1 cyrus mail 17
>>>>> Sep 22 15:10 0#?>??defaultbc -> Default.script.bc
>>>>>
>>>>>
>>>>> On Thu, Oct 1, 2015 at 7:55 PM, Alvin Starr <alvin at netvel.net>
>>>>> wrote:
>>>>>> I use autocreate.
>>>>>>
>>>>>> So there is at least one.
>>>>>>
>>>>>>
>>>>>> On 10/01/2015 12:18 PM, Artyom Aleksandrov wrote:
>>>>>>> Does anybody use autocreate_sieve?
>>>>>>>
>>>>>>> On Sat, Sep 26, 2015 at 1:30 AM, Artyom
Aleksandrov <mailing.list at tem4uk.ru> wrote:
>>>>>>>>
>>>>>>>> Hello,I want to create default sieve scipt for
all my users but I stuck with strange problem that
looks like the bug. Unfortunately I've never wrote
on C so it's difficult for me to find it.
>>>>>>>>
When Cyrus (2.5.3 or 2.5.6) create default sieve
script it doesn't put file in sieve_dir/?/user
folder. It jist creates tmp files in configdirectory
with names like this
>>>>>>>> -rw------- 1 cyrus
mail 124 Sep 26 00:41 ?&?P??default.script.bc
>>>>>>>>
-rw------- 1 cyrus mail 231 Sep 26 00:41
?&?P??default.script.script
>>>>>>>>
lrwxrwxrwx 1 cyrus mail 17 Sep 26 00:41
?&?P??defaultbc -> default.script.bc
>>>>>>>>
>>>>>>>> There are not checks in this stage so my syslog is
clean of error.
>>>>>>>> Everything seems fine. Sep 26 00:41:34 imapsync
cyrus/imap[26117]: autocreate_sieve: Problem
opening compiled script file: default.script.bc.
Compiling it
>>>>>>>>
Sep 26 00:41:34 imapsync cyrus/imap[26117]:
autocreate_sieve: Compiled sieve script was
successfully saved in default.script.bc
>>>>>>>>
Sep 26 00:41:34 imapsync cyrus/imap[26117]:
autocreate_sieve: User XXXX, default sieve script
creation succeeded
>>>>>>>>
>>>>>>>> My setting: autocreate_sieve_script:
/var/spool/sieve/global/default.script
>>>>>>>>
autocreate_sieve_script_compile: yes
>>>>>>>>
autocreate_sieve_script_compiled: default.script.bc
>>>>>>>>
sievedir: /var/spool/sieve/
>>>>>>>>
Distributive: Ubuntu 14.04.3
>>>>>>>>
>>>>>>>>
>>>>>>>> I'll be glad for any help. )
>>>>>>>>
>>>>>>>> Best regards, Artyom
>>>>>>>
>>>>>>>
>>>>>>>
>>>>>>> ----
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
>>>>>>>
>>>>>>
>>>>>> --
Alvin Starr || voice: (905)513-7688[1] Netvel Inc.
|| Cell: (416)806-0133[2] alvin at netvel.net ||
>>>>>>
>>>>>>
>>>>>>
>>>>>> ----
>>>>>> 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
>>>> ----
>>>> 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
>>>
>>>
>>> ----
>>> 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
>
> ----
> 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
Links:
1. tel:%28905%29513-7688
2. tel:%28416%29806-0133
-------------- next part --------------
An HTML attachment was scrubbed...
URL: http://lists.andrew.cmu.edu/pipermail/info-cyrus/attachments/20151009/2e627f54/attachment-0001.html
-------------- next part --------------
A non-text attachment was scrubbed...
Name: acsieve-sievedir.patch
Type: text/x-patch
Size: 492 bytes
Desc: not available
Url : http://lists.andrew.cmu.edu/pipermail/info-cyrus/attachments/20151009/2e627f54/attachment-0002.bin
-------------- next part --------------
A non-text attachment was scrubbed...
Name: acsieve-syslog.patch
Type: text/x-patch
Size: 4442 bytes
Desc: not available
Url : http://lists.andrew.cmu.edu/pipermail/info-cyrus/attachments/20151009/2e627f54/attachment-0003.bin
More information about the Info-cyrus
mailing list