Sieve
James servers are able to evaluate and execute Sieve scripts.
Sieve is an extensible mail filtering language. It’s limited expressiveness (no loops or variables, no tests with side effects) allows user created scripts to be run safely on email servers. Sieve is targeted at the final delivery phase (where an incoming email is transferred to a user’s mailbox).
The following Sieve capabilities are supported by Apache James:
To be correctly executed, please note that the Sieve mailet is required to be positionned prior the LocalDelivery mailet.
ManageSieve protocol
WARNING: ManageSieve protocol should be considered experimental.
Consult managesieveserver.xml in GIT to get some examples and hints.
The service is controlled by a configuration block in the managesieveserver.xml. The managesieveserver tag defines the boundaries of the configuration block. It encloses all the relevant configuration for the ManageSieve server. The behavior of the ManageSieve service is controlled by the attributes and children of this tag.
This tag has an optional boolean attribute - enabled - that defines whether the service is active or not. The value defaults to "false" if not present.
The standard children of the managesieveserver tag are:
Property name | explanation |
---|---|
bind |
Configure this to bind to a specific inetaddress. This is an optional integer value. This value is the port on which this ManageSieve server is configured to listen. If the tag or value is absent then the service will bind to all network interfaces for the machine If the tag or value is omitted, the value will default to the standard ManageSieve port (port 4190 is the well-known/IANA registered port for ManageSieve.) |
tls |
Set to true to support STARTTLS or SSL for the Socket.
To use this you need to copy sunjce_provider.jar to /path/james/lib directory. To create a new keystore execute:
|
connectionBacklog |
Number of connection backlog of the server (maximum number of queued connection requests) |
connectiontimeout |
Connection timeout in seconds |
connectionLimit |
Set the maximum simultaneous incoming connections for this service |
connectionLimitPerIP |
Set the maximum simultaneous incoming connections per IP for this service |