Summary | sieve driver doesn't check header field validity |
Queue | Ingo |
Queue Version | 1.2.1 |
Type | Enhancement |
State | Accepted |
Priority | 1. Low |
Owners | |
Requester | noethen (at) uni-paderborn (dot) de |
Created | 03/20/2009 (6062 days ago) |
Due | |
Updated | 04/04/2009 (6047 days ago) |
Assigned | 03/24/2009 (6058 days ago) |
Resolved | |
Milestone | |
Patch | No |
State ⇒ Accepted
Priority ⇒ 1. Low
colon to the header. Can you write a patch for lib/Script/sieve.php
to check to colons?
desire to.
State ⇒ Feedback
Patch ⇒ No
colon to the header. Can you write a patch for lib/Script/sieve.php
to check to colons?
that some drivers that do raw or regexp matching on full header lines
(for instance, maildrop and procmail) might need the trailing colon to
avoid matching unrelated data on corrupt messages - be sure to check
if the corresponding output drivers in Ingo add those colons.
to RFC 2822 section 2.2?
"A field name MUST be composed of printable US-ASCII characters (i.e.,
characters that have values between 33 and 126, inclusive), except
colon."
validity of the script and returns an error message where
appropriate. If it doesn't do that for your, then your server is
broken period.
without Heiko's patch to some part of the Horde framework I do not see.
The problem remains, generation of invalid scripts. I think Ingo,
being able to generate output for various different filter engines
(sieve only one of them), should normalize these filters - they are
configured by non-technical users, and expecting them to know the
details of Sieve syntax is expecting too much anyways.
Cyrus 2.3.13, Net_Sieve 1.1.6 and Ingo 1.2.x:
Error:
There was an error activating the script. The driver said: {81}script
errors: line 18: header 'from:': not a valid header for an address test
validity of the script and returns an error message where appropriate.
If it doesn't do that for your, then your server is broken period.
Filtering Language") section 2.4.2.2:
'[...]
A header name never contains a colon. The "From" header refers to a
line beginning "From:" (or "From :", etc.). No header will match
the string "From:" due to the trailing colon. [...]'
So Horde should make sure that either (1) the web interface rejects
filters where custom header names contain the colon, or (2) the
component that generates the Sieve script strips that colon.
rather than reading and understanding what is presented?
Why/how this would be a Cyrus bug if (1) Horde/Ingo creates invalid
sieve scripts through improper input validation or output generation
(excess colon) and (2) some glue then silently drops the error message
to the floor?
That makes two bugs in Horde here and zero in Cyrus timsieved - even
if you cannot reproduce the "dropped error message" part (No. 2
above), the other bug remains.
State ⇒ Not A Bug
rules. Do you have the latest Net_Sieve installed?
Is this function server dependent? My debugging showed, that the
script is uploaded to the server and the server returns "ok". When i
access the sieve file by sieveshell command i only get the list of
valid rules, but when i load the script from the server by pear lib i
get a pear error that the script has errors.
"Beim Aktivieren des Skripts ist ein Fehler aufgetreten. Antwort des
Treibers: {65}script errors: line 5: header 'replay-to:': not a valid
header"
State ⇒ Feedback
rules. Do you have the latest Net_Sieve installed?
timsieved will reject (it expects header name matches without colon,
as Heiko already stated). (b) The attempt to upload this invalid Sieve
script fails SILENTLY, without error message, while Cyrus continues
with the previous edition of the script. (c) the user interface in
however presents the new filter.
The fix should be two-fold: (a) fix Ingo so it does not create invalid
rules in the first place (stripping the trailing colon should be in
order for user-specified header filters, otherwise it should
complain), (b) - suggested by Heiko above - make sure to display the
error if the Sieve script cannot be uploaded to the server.
Priority ⇒ 1. Low
State ⇒ Unconfirmed
Patch ⇒ Yes
Milestone ⇒
Summary ⇒ Driver Timsieve saves invalid sieve file without displaying error message
Type ⇒ Bug
Queue ⇒ Ingo
when the user adds a invalid rule - for ex. over custom header
"replay-to:" where the colon is wrong, the user gets no feedback. The
script is saved to the server (the server ignores the wrong filter
rule) and the user doesn't know why the rule doesn't work.
Here is my patched function - as in fact we include the
"INGO-Sieve-Script" from a main sieve script, so i disabled the
activation - only the script is uploaded/installed.
/**
* Sets a script running on the backend.
*
* @param string $script The sieve script.
*
* @return mixed True on success, PEAR_Error on error.
*/
function setScriptActive($script)
{
$res = $this->_connect();
if (is_a($res, 'PEAR_Error')) {
return $res;
}
if (!strlen($script)) {
return $this->_sieve->setActive('');
}
$res = $this->_sieve->haveSpace($this->_params['scriptname'],
strlen($script));
if (is_a($res, 'PEAR_ERROR')) {
return $res;
}
// IMT PATCHED
/*
return $this->_sieve->installScript($this->_params['scriptname'],
$script, true);
*/
$return = $this->_sieve->installScript($this->_params['scriptname'],
$script, false);
// Check if the uploaded script is valid - server doesn't
return error when script is invalid, so here i fetch the script again
and check for errors.
$tmp = $this->_sieve->getScript($this->_params['scriptname']);
if (is_a($tmp, 'PEAR_ERROR'))
return $tmp;
return $return;
}