 |
|
MailScanner.conf
NAME
SYNOPSIS
DESCRIPTION
System Settings
Incoming Work Dir Settings
Quarantine and Archive Settings
Process Incoming Mail
Options specific to Sophos Anti-Virus
Virus scanning and vulnerability testing
Options specific to ClamAV Anti-Virus
Removing/Logging dangerous or potentially offensive content
Attachment filename checking
Reports and responses
Changes to message headers
Notifications back to the senders of blocked messages
Changes to subject line
Changes to the message body
Mail archiving and monitoring
Notices to system administrators
Definitions of virus scanners and spam detectors
Spam detection and spam lists (DNS blocklists)
SpamAssassin
What to do with spam
System logging
Advanced SpamAssassin Settings
Advanced Settings
RULESETS
ATTACHMENT FILENAME RULESET
SEE ALSO
NAME
|
MailScanner.conf − Main configuration for
MailScanner
|
SYNOPSIS
DESCRIPTION
|
MailScanner is configured using the file
MailScanner.conf. The location of this file varies from
operating system to operating system:
|
|
FreeBSD: /usr/local/etc/MailScanner
Other: /opt/MailScanner/etc
Blank lines are ignored, as are leading and trailing
spaces. Comments start at a ’#’ character and
extend to the end of the line. All options are expressed in
the form
option = value
Many of the options can also be the filename of a
ruleset, which can be used to control features depending on
the addresses of the message, and/or the IP address where
the message came from. You will find some examples of
rulesets and an explanation of them in the "rules"
directories within the MailScanner installation and in the
section "RULESETS" later in this manpage.
The options are best listed in a few categories. If this
list looks very large then don’t worry, the supplied
MailScanner.conf file (or MailScanner.conf.sample) contains
sensible defaults for all the values. You will probably only
need to change a very few of them to start with.
Starting with version 4.40.10 of MailScanner you can use
shell environment variables such as $HOSTNAME or ${HOSTNAME}
in MailScanner.conf and its relatives.
You should define the following variables:
|
|
Default: /opt/MailScanner/etc/reports/en
Default FreeBSD: /usr/local/share/MailScanner/reports/en
Set the directory containing all the reports in the
required language.
|
|
Default: /opt/MailScanner/etc
Default FreeBSD: /usr/local/etc/MailScanner
Configuration directory containing this file
|
|
Default: /opt/MailScanner/etc/rules
Default FreeBSD: /usr/local/etc/MailScanner/rules
Rulesets directory containing your ".rules"
files
|
|
Default: yoursite
Enter a short identifying name for your organisation
below, this is used to make the X−MailScanner headers
unique for your organisation. Multiple servers within one
site should use an identical value here to avoid adding
multiple redundant headers where mail has passed through
several servers within your organisation.
Note: Some Symantec scanners complain (incorrectly) about
"." characters appearing in the names of
headers.
|
|
Default: Your Organisation Name Here
Enter the full name of your organisation below, this is
used in the signature placed at the bottom of report
messages sent by MailScanner. It can include pretty much any
text you like. You can make the result span several lines by
including "0 sequences in the text. These will be
replaced by line−breaks.
|
|
Default: www.your−organisation.com
Enter the location of your organisation’s web site
below. This is used in the signature placed at the bottom of
report messages sent by MailScanner. It should preferably be
the location of a page that you have written explaining why
you might have rejected the mail and what the recipient
and/or sender should do about it.
|
System Settings
|
Default: 5
MailScanner uses your server efficiently by running
several identical processes at the same time, all processing
mail. This is the number of these processes to run at once.
Turning this figure will optimise the performance of your
system if you process a lot of mail. A good figure to start
with is 5 children per CPU. So if you have 4 CPUs in your
server, start by setting this to 20.
|
|
Default: not to change user
Provided for Exim users (and anyone not running sendmail
as root), this changes the user under which MailScanner
runs.
|
|
Default: not to change group
Provided for Exim users (and anyone not running sendmail
as root), this changes the group under which MailScanner
runs.
|
|
Default: 5
How often (in seconds) should each process check the
incoming mail queue for new messages? If you have a quiet
mail server, you might want to increase this value so it
causes less load on your server, at the cost of slightly
increasing the time taken for an average message to be
processed.
|
|
Default: /var/spool/mqueue.in
Directory in which MailScanner should find e−mail
messages for scanning. This can be any of the following:
|
|
Example: /var/spool/mqueue.in
|
|
2.
|
|
a wildcard giving directory names.
|
|
|
Example: /var/spool/mqueue.in/*
|
|
3.
|
|
the name of a file containing a list of directory names,
which can in turn contain wildcards.
|
|
Example:
/usr/local/etc/MailScanner/mqueue.in.list.conf |
|
Default: /var/spool/mqueue
Directory in which MailScanner should place scanned
e−mail messages. This can also be the filename of a
ruleset.
|
|
Default: /opt/MailScanner/var/incoming
Default FreeBSD: /var/spool/MailScanner/incoming
Directory in which to temporarily store unpacked MIME
messages during scanning process.
|
|
Default: /opt/MailScanner/var/quarantine
Default FreeBSD: /var/spool/MailScanner/quarantine
Set where to store infected messages and attachments (if
they are kept). This can also be the filename of a
ruleset.
|
|
Default: /opt/MailScanner/var/MailScanner.pid
Default FreeBSD: /var/run/MailScanner.pid
Set where to store the process id number so you can stop
MailScanner. In the FreeBSD port this should remain
/var/run/MailScanner.pid in order for the start/stop script
to work.
|
|
Default: 14400
To avoid resource leaks the MailScanner parent process
stops and restarts its child processes from time to time.
Set the amount of seconds each child process is supposed to
live here.
|
|
MailScanner works with sendmail and exim. Since the queue
handling differs a bit, you have to tell MailScanner which
MTA you are using. Valid options are sendmail and exim.
|
|
Default: /usr/lib/sendmail
Default FreeBSD: /usr/sbin/sendmail
Set how to invoke MTA when sending messages MailScanner
has created (e.g. to sender/recipient saying "found a
virus in your message"). This can also be the filename
of a ruleset.
|
|
Default: same value as the Sendmail setting
Sendmail2 is provided for exim users. It is the command
used to attempt delivery of outgoing cleaned/disinfected
messages. This is not usually required for sendmail.
For Exim users this could be: Sendmail2 = /usr/sbin/exim
−C /usr/local/etc/exim/configure.out
|
Incoming Work Dir Settings
|
You should not normally need to touch these settings at
all, unless you are using ClamAV and need to be able to use
the external archive unpackers instead of ClamAV’s
built−in ones.
|
|
Default:
If you want to create the temporary working files so they
are owned by a user other than the "Run As User"
setting, you can change that here. Note: If the "Run As
User" is not "root" then you cannot change
the user but may still be able to change the group, if the
"Run As User" is a member of both of the groups
"Run As Group" and "Incoming Work
Group".
|
|
Default:
If you want to create the temporary working files so they
are owned by a group other than the "Run As User"
setting, you can change that here. Note: If the "Run As
User" is not "root" then you cannot change
the user but may still be able to change the group, if the
"Run As User" is a member of both of the groups
"Run As Group" and "Incoming Work
Group".
|
|
Incoming Work Permissions |
|
Default: 0600
If you want processes running under the same *group* as
MailScanner to be able to read the working files (and list
what is in the directories, of course), set to 0640. If you
want *all* other users to be able to read them, set to 0644.
For a detailed description, if you’re not already
familiar with it, refer to ‘man 2 chmod‘.
Typical use: external helper programs of virus scanners
(notably ClamAV), like unpackers. Use with care, you may
well open security holes.
|
Quarantine and Archive Settings
|
If, for example, you are using a web interface so that
users can manage their quarantined files, you might want to
change the ownership and permissions of the quarantined so
that they can be read and/or deleted by the web server.
Don’t touch this unless you know what you are
doing!
|
|
Default:
If you want to create the quarantine/archive so the files
are owned by a user other than the "Run As User"
setting at the top of this file, you can change that here.
Note: If the "Run As User" is not "root"
then you cannot change the user but may still be able to
change the group, if the "Run As User" is a member
of both of the groups "Run As Group" and
"Quarantine Group".
|
|
Default:
If you want to create the quarantine/archive so the files
are owned by a user other than the "Run As User"
setting at the top of this file, you can change that here.
Note: If the "Run As User" is not "root"
then you cannot change the user but may still be able to
change the group, if the "Run As User" is a member
of both of the groups "Run As Group" and
"Quarantine Group".
|
|
Default: 0600
If you want processes running under the same *group* as
MailScanner to be able to read the quarantined files (and
list what is in the directories, of course), set to 0640. If
you want *all* other users to be able to read them, set to
0644. For a detailed description, if you’re not
already familiar with it, refer to ‘man 2
chmod‘. Typical use: let the webserver have access to
the files so users can download them if they really want to.
Use with care, you may well open security holes.
|
Process Incoming Mail
|
Max Unscanned Bytes Per Scan |
|
Default: 100000000
MailScanner handles messages in batches for efficiency.
Messages are gathered (in strict date order) from the
incoming queue directory, one at a time, until this or one
of the following three limits is reached or the queue is
empty.
This setting limits the total size of messages per batch
for which no scanning is done (i.e. Virus Scanning =
no).
|
|
Max Unsafe Bytes per Scan |
|
Default: 50000000
This setting limits the total size of messages per batch
for which scanning is done (i.e. Virus Scanning = yes).
|
|
Max Unscanned Messages Per Scan |
|
Default: 100
This setting limits the total number of messages per
batch for which no scanning is done (i.e. Virus Scanning =
no).
|
|
Max Unsafe Messages per Scan |
|
Default: 100
This setting limits the total number of messages per
batch for which scanning is done (i.e. Virus Scanning =
yes).
|
|
Default: 1000
If more messages are found in the queue than this, then
switch to an "accelerated" mode of processing
messages. This will cause it to stop scanning messages in
strict date order, but in the order it finds them in the
queue. If your queue is bigger than this size a lot of the
time, then some messages could be greatly delayed. So treat
this option as "in emergency only".
|
|
Maximum Attachments Per Message |
|
Default: 200
The maximum number of attachments allowed in a message
before it is considered to be an error. Some email systems,
if bouncing a message between 2 addresses repeatedly, add
information about each bounce as an attachment, creating a
message with thousands of attachments in just a few minutes.
This can slow down or even stop MailScanner as it uses all
available memory to unpack these thousands of attachments.
This can also be the filename of a ruleset.
|
|
Default: yes
TNEF is primarily used by Microsoft programs such as
Outlook and Outlook Express when mails are formatted/sent in
Rich−Text−Format. Attachments are all put
together in one WINMAIL.DAT file.
Should we use a TNEF decoder (external or Perl module)?
This should be "yes" unless the scanner you are
using (Sophos, McAfee) has the facility built−in.
However, if you set it to "no", then the filenames
within the TNEF attachment will not be checked against the
filename rules.
|
|
Default: no
Rich Text format attachments produced by some versions of
Microsoft Outlook cannot be completely decoded at present.
Setting this option to yes allows compatibility with the
behaviour of earlier versions where these attachments were
still delivered. This would introduce the slight chance of a
virus getting through in the segment of the attachment that
could not be decoded, but the setting may be necessary if
you have a large number of Microsoft Outlook users who are
troubled by the new behaviour.
|
|
Default: /opt/MailScanner/bin/tnef
Default FreeBSD: /usr/local/bin/tnef
Full pathname giving location of the MS−TNEF
expander/decoder program, or the keyword internal which will
force use of the optional Perl Convert::TNEF module instead
of the external program.
|
|
Default: 120
The maximum length of time (in seconds) the TNEF Expander
is allowed to run for diassembling one attachment.
|
|
Default: /usr/bin/file
Where the "file" command is installed. This is
used for checking the content type of files, regardless of
their filename. To disable Filetype checking, set this value
to blank.
|
|
Default: 20
The maximum length of time the "file" command
is allowed to run for one batch of messages (in
seconds).
|
|
Default: /usr/bin/unrar
Where the "unrar" command is installed. If you
haven’t got this command, look at www.rarlab.com. This
is used for unpacking rar archives so that the contents can
be checked for banned filenames and filetypes, and also that
the archive can be tested to see if it is
password−protected. Virus scanning the contents of rar
archives is still left to the virus scanner, with one
exception: If using the clavavmodule virus scanner, this
adds external RAR checking to that scanner which is needed
for archives which are RAR version 3.
|
|
Default: 50
The maximum length of time the "unrar" command
is allowed to run for 1 RAR archive (in seconds)
|
|
Default: no
This is inteded for use with a ruleset to ensure that
none of your users is covertly mailing sites with which you
would not normally communicate (e.g. your competitors). If
this is set to yes (or the ruleset evaluates to yes)
encrypted messages are blocked.
|
|
Block Unencrypted Messages |
|
Default: no
This is intended for use with a ruleset to ensure that
mail is always encrypted before being sent. This could be
used to ensure that mail to your business partners is sent
securely.
|
|
Allow Password−Protected Archives |
|
Default: no
Should archives which contain any
password−protected files be allowed? Leaving this set
to "no" is a good way of protecting against all
the protected zip files used by viruses at the moment. This
can also be the filename of a ruleset.
|
|
Default: 0
The maximum size, in bytes, of any message including the
headers. If this is set to zero, then no size checking is
done. This can also be the filename of a ruleset, so you can
have different settings for different users. You might want
to set this quite small for dialup users so their email
applications don’t time out downloading huge
messages.
|
|
Default: −1
The maximum size, in bytes, of any attachment in a
message. If this is set to zero, effectively no attachments
are allowed. If this is set less than zero, then no size
checking is done. This can also be the filename of a
ruleset, so you can have different settings for different
users. You might want to set this quite small for large
mailing lists so they don’t get deluged by large
attachments.
|
|
Default: 3
The maximum depth to which zip archives will be unpacked
to allow for checking filenames and filetypes within zip
archives. Setting this to 0 will disable
filename/−type checks within zip files while still
allowing to block password protected zip files.
|
|
Default: yes
Find zip archives by filename or by file contents?
Finding them by content is a far more reliable way of
finding them, but it does mean that you cannot tell your
users to avoid zip file checking by renaming the file from
".zip" to "_zip" and tricks like that.
Only set this to no (i.e. check by filename only) if you
don’t want to reliably check the contents of zip
files. Note this does not affect virus checking, but it will
affect all the other checks done on the contents of the zip
file. This can also be the filename of a ruleset.
|
Options specific to Sophos Anti-Virus
|
Allowed Sophos Error Messages |
|
Default:
Anything on the next line that appears in brackets at the
end of a line of output from Sophos will cause the
error/infection to be ignored. Use of this option is
dangerous, and should only be used if you are having trouble
with lots of corrupt PDF files, for example. This option
allows for multiple strings as well. In this case, the
strings should be put in double quotes (") and each
string separated with commas. Examples:
Allowed Sophos Error Messages = corrupt format not
supported
Allowed Sophos Error Messages = "corrupt",
"format not supported"
The first version will match "corrupt format not
supported" only. The second version will match
"corrupt" and "format not
supported".
|
|
Default: /usr/local/Sophos/ide
The directory (or a link to it) containing all the Sophos
*.ide files. This is only used by the "sophossavi"
virus scanner, and is irrelevant for all other scanners.
|
|
Default: /usr/local/Sophos/lib
The directory (or a link to it) containing all the Sophos
*.so libraries.This is only used by the
"sophossavi" virus scanner, and is irrelevant for
all other scanners.
|
|
Monitors For Sophos Updates |
|
Default: /usr/local/Sophos/ide/*ides.zip
SophosSAVI only: monitor each of these files for changes
in size to detect when a Sophos update has happened. The
date of the Sophos Lib Dir is also monitored. This is only
used by the "sophossavi" virus scanner, not the
"sophos" scanner setting.
|
Virus scanning and vulnerability testing
|
Default: yes
Do you want to scan email for viruses? A few people
don’t have virus scanner licence and so want to
disable all the virus scanning.
NOTE: Switching this to no completely disables all
virus−scanning functionality. If you just want to
switch of actual virus scanning, then set "Virus
Scanners = none" instead.
If you want to be able to switch scanning on/off for
different users or different domains, set this to the
filename of a ruleset.
|
|
Default: none
Which Virus Scanning package to use. Possible choices are
sophos, sophossavi, mcafee, command, bitdefender, kaspersky,
kaspersky−4.5, kavdaemonclient, inoculate, inoculan,
nod32, nod32−1.99, f−secure, f−prot,
panda, rav, antivir, clamav, clamavmodule, css, trend,
norman, avg, vexira, symscanengine, generic, none (no virus
scanning at all). This *cannot* be the filename of a
ruleset.
Note for McAfee users: Do NOT use any symlinks with
McAfee at all. It is very strange but McAfee may not detect
all viruses when started from a symlink or scanning a
directory path including symlinks.
Note: If you want to use multiple virus scanners, then
this should be a space−separated list of virus
scanners.
Note: Make sure that you check that the base installation
directory in the 3rd column of virus.scanners.conf matches
the location you have installed each of your virus scanners.
The supplied virus.scanners.conf file assumes the default
installation locations recommended by each of the virus
scanner installation guides.
|
|
Default: 300
The maximum time (in seconds) that the cirus scanner is
allowed to take to scan one batch of messages.
|
|
Deliver Disinfected Files |
|
Default: yes
Should infected attached documents be automatically
disinfected and sent on to the original recipients? Less
than 1% of viruses in the wild can be successfully
disinfected,as macro viruses are now a rare occurrence. So
the default has been changed to "no" as it gives a
significant performance improvement.
|
|
Default: HTML−IFrame All−Viruses
Messages whose virus reports contain any of the words
listed here will be treated as "silent" viruses.
No messages will be sent back to the senders of these
viruses, and the delivery to the recipient of the message
can be controlled by the next option "Still Deliver
Silent Viruses". This is primarily designed for viruses
such as "Klez" and "Bugbear" which put
fake addresses on messages they send, so there is no point
informing the sender of the message, as it won’t
actually be them who sent it anyway. Other words that can be
put in this list are the 5 special keywords
|
|
•
|
|
HTML−IFrame: inserting this will stop senders
being warned about HTML Iframe tags, when they are not
allowed.
|
|
•
|
|
HTML−Codebase: inserting this will stop senders
being warned about HTML Object Codebase tags, when they are
not allowed.
|
|
•
|
|
Zip−Password: inserting this will stop senders
being warned about password−protected zip files when
they are not allowd. This keyword is not needed if you
include All−Viruses.
|
|
•
|
|
All−Viruses: inserting this will stop senders
being warned about any virus, while still allowing you to
warn senders about HTML−based attacks. This includes
Zip−Password so you don’t need to include
both.
|
|
The default of "All−Viruses" means that
no senders of viruses will be notified (as the sender
address is always forged these days anyway), but anyone who
sends a message that is blocked for other reasons will still
be notified. |
|
Still Deliver Silent Viruses |
|
Default: no
If this is set to yes then disinfected messsages that
originally contained one of the "silent" viruses
will still be delivered to the original recipients, even
those addresses were chosen at random by the infected PC and
do not correspond to anything a user intended to send. Set
this to yes so that your users (and your management)
appreciate how much MailScanner is doing to protect them,
but set it to no if they complain a lot about receiving lots
of virus warnings.
|
|
Default: Joke/ OF97/ WM97/ W97M/
Strings listed here will be searched for in the output of
the virus scanners. It works to achieve the opposite effect
of the "Silent Viruses" listed above. If a string
here is found in the output of the virus scanners, then the
message will be treated as if it were not infected with a
"Silent Virus". If a message is detected as both a
silent virus and a non−forging virus, then the
non−forging status will override the silent status. In
simple terms, you should list virus names (or parts of them)
that you know do *not* forge the From address. A good
example of this is a document macro virus or a Joke program.
Another word that can be put in this list is the special
keyword "Zip−.Password". Inserting this will
cause senders to be warned about password−protected
zip files, whey they are not allowed.
|
Options specific to ClamAV Anti-Virus
|
Monitors for ClamAV Updates |
|
Default: /usr/local/share/clamav/*.cvd
ClamAVModule only: monitor each of these files for
changes in size to detect when a ClamAV update has happened.
This is only used by the "clamavmodule" virus
scanner, not the "clamav" scanner setting.
|
|
ClamAVmodule Maximum Recursion Level |
|
Default: 5
ClamAVModule only: The maximum recursion level of
archives. This setting *cannot* be the filename of a
ruleset, only a simple number.
|
|
ClamAVmodule Maximum Files |
|
Default: 100
ClamAVModule only: The maximum number of files per batch.
This setting *cannot* be the filename of a ruleset, only a
simple number.
|
|
ClamAVmodule Maximum File Size |
|
Default: 10000000
ClamAVModule only: The maximum file of each file (Default
= 10MB). This setting *cannot* be the filename of a ruleset,
only a simple number.
|
|
ClamAVmodule Maximum Compression Ratio |
|
Default: 250
ClamAVModule only: The maximum compression ration of
archives. This setting *cannot* be the filename of a
ruleset, only a simple number.
|
Removing/Logging dangerous or potentially offensive content
|
Default: no
Do you want to allow partial messages, which only contain
a fraction of the attachments, not the whole thing? There is
no way that "partial messages" can be scanned for
viruses properly, as only a fragment of the message is ever
processed, never the whole message at once.
Setting this option to yes is very dangerous as it
can let viruses in. But you might want to use a ruleset to
set it for some customers’ outgoing mail, for
example.
|
|
Allow External Message Bodies |
|
Default: no
There is a mechanism, very rarely used, in which the body
of a message is contained on a remote server, which the
user’s email application should download when it
displays the message. Currently, I am only aware of this
feature being supported by a few versions of Netscape, and
the only people who use it are the IETF. There is no way to
guarantee that the fetched file has no viruses in it, as
MailScanner never sees it.
Setting this option to yes is very dangerous as it
can let viruses in from remote "message body
servers".
|
|
Default: yes
Do you want to check for "Phishing" attacks?
These are attacks that look like a genuine email message
from your bank, which contain a link to click on to take you
to the web site where you will be asked to type in personal
information such as your account number or credit card
details. Except it is not the real bank’s web site at
all, it is a very good copy of it run by thieves who want to
steal your personal information or credit card details.
These can be spotted because the real address of the link in
the message is not the same as the text that appears to be
the link. Note: This does cause significant extra load,
particularly on systems receiving lots of spam such as
secondary MX hosts. This *cannot* be the filename of a
ruleset, it must be ’yes’ or
’no’.
|
|
Also Find Numeric Phishing |
|
Default: yes
While detecting "Phishing" attacks, do you also
want to point out links to numeric IP addresses. Genuine
links to totally numeric IP addresses are very rare, so this
option is set to "yes" by default. If a numeric IP
address is found in a link, the same phishing warning
message is used as in the Find Phishing Fraud option above.
This value cannot be the name of a ruleset, only a simple
yes or no.
|
|
Default: %etc−dir%/phishing.safe.sites.conf
There are some companies, such as banks, that insist on
sending out email messages with links in them that are
caught by the "Find Phishing Fraud" test described
above. This is the name of a file which contains a list of
link destinations which should be ignored in the test. This
may, for example, contain the known websites of some banks.
See the file itself for more information. This can only be
the name of the file containing the list, it *cannot* be the
filename of a ruleset.
|
|
Default: no
Do you want to allow HTML <IFrame> tags in email
messages? This is not a good idea as it allows various
Microsoft Outlook security vulnerabilities to go
unprotected, but if you have a load of mailing lists sending
them, then you will want to allow them to keep your users
happy. This can also be the filename of a ruleset, so you
can allow them from known mailing lists but ban them from
everywhere else. Possible Values:
|
|
•
|
|
yes => Allow these tags to be in the message
|
|
•
|
|
no => Ban messages containing these tags
|
|
•
|
|
disarm => Allow these tags, but stop these tags from
working
|
|
You may receive complaints from your users that HTML
mailing lists they subscribe to have been stopped by the
"Allow IFrame Tags" option above. So before you
use the option above, set this option to "yes" and
MailScanner will log the senders all messages which contain
IFrame tags. You can then setup a ruleset for the option
above which will allow IFrame tags in messages sent by well
known (and trusted) mailing lists, while banning them from
everywhere else.
|
|
Default: disarm
Do you want to allow <Form> tags in email messages?
This is a bad idea as these are used as scams to persuade
people to part with credit card information and other
personal data. This can also be the filename of a ruleset.
Possible values:
|
|
•
|
|
yes => Allow these tags to be in the message
|
|
•
|
|
no => Ban messages containing these tags
|
|
•
|
|
disarm => Allow these tags, but stop these tags from
working
|
|
Do you want to allow <Script> tags in email
messages? This is a bad idea as these are used to exploit
vulnerabilities in email applications and web browsers. This
can also be the filename of a ruleset. Possible
values: |
|
•
|
|
yes => Allow these tags to be in the message
|
|
•
|
|
no => Ban messages containing these tags
|
|
•
|
|
disarm => Allow these tags, but stop these tags from
working
|
|
Do you want to allow <Img> tags with very small
images in email messages? This is a bad idea as these are
used as ’web bugs’ to find out if a message has
been read. It is not dangerous, it is just used to make you
give away information. This can also be the filename of a
ruleset. Possible values: |
|
•
|
|
yes => Allow these tags to be in the message
|
|
•
|
|
no => Ban messages containing these tags
|
|
•
|
|
disarm => Allow these tags, but stop these tags from
working
|
|
Allow Object Codebase Tags |
|
Do you want to allow <Object Codebase=...> tags in
email messages? This is a bad idea as it leaves you
unprotected against various Microsoft−specific
security vulnerabilities. But if your users demand it, you
can do it. This can also be the filename of a ruleset.
Possible values: |
|
•
|
|
yes => Allow these tags to be in the message
|
|
•
|
|
no => Ban messages containing these tags
|
|
•
|
|
disarm => Allow these tags, but stop these tags from
working
|
|
Convert Dangerous HTML To Text |
|
This option interacts with the "Allow ... Tags"
options above like this:
Allow...Tags Convert Danger... Action
============ =================
============================
no no Blocked
no yes Blocked
disarm no Specified HTML tags disarmed
disarm yes Specified HTML tags disarmed
yes no Nothing
yes yes All HTML tags stripped
If an "Allow ... Tags = yes" is triggered by a
message, and this "Convert Dangerous HTML To Text"
is set to "yes", then the HTML message will be
converted to plain text. This makes the HTML harmless, while
still allowing your users to see the text content of the
messages. Note that all graphical content will be
removed.
|
|
Default: no
If you have users who are children, or who are offended
by things like pornographic spam email, you can protect them
by converting incoming HTML email messages into plain text.
HTML attachments will not be affected. You could set this to
be a ruleset so you only convert messages addressed to some
of your users, or not convert messages from some known
trusted sources. This can be essential if you have a
"duty of care" for some of your users.
|
|
Default: no
Do you want to allow <Form> tags in email messages?
This is a bad idea as these are used as scams to pursuade
people to part with credit card information and other
personal data. This can also be the filename of a
ruleset.
|
Attachment filename checking
|
Default: %etc−dir%/filename.rules.conf
File in which to store the attachment filename ruleset.
This can be a ruleset allowing different filename rules to
apply to different users or domains. The syntax of this file
is described in section "Attachment Filename
Ruleset".
|
|
Default: %etc−dir%/filetype.rules.conf
Set where to find the attachment filetype ruleset. The
structure of this file is explained elsewhere, but it is
used to accept or reject file attachments based on their
content as determined by the "file" command,
regardless of whether they are infected or not. This can
also point to a ruleset, but the ruleset filename must end
in ".rules" so that MailScanner can determine if
the filename given a ruleset or not!
|
Reports and responses
|
Default: yes
Set this to store infected / dangerous attachments in
directories created under the quarantine directory. Without
this, they will be deleted. Due to laws on privacy and data
protection in your country, you may be forced to set this to
"no".
|
|
Quarantine Silent Viruses |
|
Default: yes
There is no point quarantining most viruses these days,
so if you set this to "no" then no infections
listed in your "Silent Viruses" setting will be
quarantined, even if you have chosen to quarantine
infections in general. This is currently set to
"yes" so the behaviour is the same as it was in in
previous versions. This can also be the filename of a
ruleset.
|
|
Default: no
When an infected message is stored in the quarantine, a
copy of the entire message will be saved, in addition to
copies of the infected attachments.
|
|
Quarantine Whole Messages As Queue Files |
|
Default: no
When an entire message is saved in the quarantine for any
reason, do you want to save it as the raw data files out of
the mail queue (which can be processed with the df2mbox
script, and which is easier to send to its original
recipients), or do you want a conventional message file
consisting of the header followed by the body of the
message. If the previous option is switched off, then this
will only affect archived mail and quarantined spam. If the
previous option is on, then this also affects quarantined
infections.
|
|
Keep Spam And MCP Archive Clean |
|
Default: no
Do you want to stop any virus−infected spam getting
into the spam or MCP archives? If you have a system where
users can release messages from the spam or MCP archives,
then you probably want to stop them being able to release
any infected messages, so set this to yes. It is set to no
by default as it causes a small hit in performance, and many
people don’t allow users to access the spam
quarantine, so don’t need it. This can also be the
filename of a ruleset.
|
|
Default: %reports−dir%/languages.conf
Set where to find all the strings used so they can be
translated into your local language. This can also be the
filename of a ruleset so you can produce different languages
for different messages.
|
|
Deleted Bad Filename Message Report |
|
Default:
%reports−dir%/deleted.filename.message.txt
When an attachment is deleted from a message because the
filename failed the filename rules in force for the message,
it is replaced by the contents of this file. A few variable
substitutions can be made in this file, an example of each
of which is contained in the supplied sample file.
|
|
Deleted Virus Message Report |
|
Default:
%reports−dir%/deleted.virus.message.txt
When an attachment is deleted from a message because the
attachment contained a virus or other dangerous content, it
is replaced by the contents of this file. A few variable
substitutions can be made in this file, an example of each
of which is contained in the supplied sample file.
|
|
Stored Bad Filename Message Report |
|
Default:
%reports−dir%/stored.filename.message.txt
When an attachment is deleted and stored from a message
(and the attachment has been stored in the quarantine)
because the filename failed the filename rules in force for
the message, it is replaced by the contents of this file. A
few variable substitutions can be made in this file, an
example of each of which is contained in the supplied sample
file.
|
|
Deleted Bad Content Message Report |
|
Default:
/%reports−dir%/deleted.content.message.txt
This report is sent when a message is deleted because it
contained bad or dangerous content. A few variable
substitutions can be made in this file, an example of each
of which is contained in the supplied sample file.
|
|
Stored Bad Content Message Report |
|
Default:
%reports−dir%/stored.content.message.txt
This report is sent when a message is stored because it
contained bad or dangerous content. A few variable
substitutions can be made in this file, an example of each
of which is contained in the supplied sample file.
|
|
Default: %reports−dir%/disinfected.report.txt
When, for example, a Microsoft Word macro virus has been
safely removed from a document, leaving the original
document intact, it is delivered on to the original
recipient. The contents of this text file will be put in the
body of the new message, explaining to the user what has
happened.
|
|
Default: %reports−dir%/inline.sig.html
If the "Sign Clean Messages" option is set,
then the contents of this file will be appended to the end
of the body of every message that is scanned by MailScanner.
You can use this to inform your users that MailScanner has
scanned it, and you can also add any disclaimers you feel
should be on mail travelling through your servers. This
option corresponds to the contents that is appended to HTML
messages.
|
|
Default: %reports−dir%/inline.sig.txt
If the "Sign Clean Messages" option is set,
then the contents of this file will be appended to the end
of the body of every message that is scanned by MailScanner.
You can use this to inform your users that MailScanner has
scanned it, and you can also add any disclaimers you feel
should be on mail travelling through your servers. This
option corresponds to the contents that is appended to text
messages.
|
|
Default: %reports−dir%/sender.error.report.txt
When a message could not be processed completely for some
reason, such as bad message structure or unreadable
winmail.dat TNEF attachments, this message is sent back to
the sender. Read the example file supplied for a
demonstration of what variables can be used inside the
file.
|
|
Sender Bad Filename Report |
|
Default:
%reports−dir%/sender.filename.report.txt
When an attachment is trapped by the filename rules, this
message is sent back to the sender.
|
|
Default: %reports−dir%/sender.virus.report.txt
When an attachment is removed because of a virus, this
message is sent back to the sender.
|
|
Default: yes
When this option is set, the full directory in which the
virus was found will be removed from report messages sent to
users. This makes the infection reports a lot easier to
understand.
|
|
Include Scanner Name in Reports |
|
Default: yes
Include the name of the virus scanner in each of the
scanner reports. This also includes the translation of
"MailScanner" in each of the report lines
resulting from one of MailScanner’s own checks such as
filename, filetype or dangerous HTML content. To change the
name "MailScanner", look in
reports/...../languages.conf.
Very useful if you use several virus scanners, but a bad
idea if you don’t want to let your customers know
which scanners you use.
|
Changes to message headers
|
Default: X−MailScanner:
Extra header that should be added to all scanned messages
to show they have been scanned. You might want to add an
abbreviation of your site name to this, so that you can find
headers that are added by your MailScanner server.
|
|
Default: X−MailScanner−SpamCheck:
Name of the header to add to mail detected as spam. The
text of the header is a list of the causes that think the
message is spam.
|
|
Default: X−MailScanner−SpamScore:
If the option "Spam Score" is set, this is the
name of the header that is used to contain the list of
characters.
|
|
Default: X−MailScanner−Information:
Name of the header to add to all messages, to be used for
simply providing a URL or contact information for anyone
receiving mail that has gone through MailScanner. If you do
not want this header, simply set it blank.
|
|
Default: yes
Do you want to add the Envelope−From: header? This
is very useful for tracking where spam came from as it
contains the envelope sender address. This can also be the
filename of a ruleset.
|
|
Default: no
Do you want to add the Envelope−To: header? This
can be useful for tracking span destinations, but should be
used with care due to possible privacy concerns with the use
of Bcc: headers by users. This can also be the filename of a
ruleset.
|
|
Default:
X−%org−name%−MailScanner−From:
This is the name of the Envelope From header controlled
by the option above. This can also be the filename of a
ruleset.
|
|
Default:
X−%org−name%−MailScanner−To:
This is the name of the Envelope To header controlled by
the option above. This can also be the filename of a
ruleset.
|
|
Default: yes
If this is set to yes then you get the normal fully
detailed spam report in spam messages. If this is set to no
then you simply get a "spam" or "not
spam" report. The exact text inserted can be configured
in the languages.conf file for your language.
|
|
Include Scores In SpamAssassin Report |
|
Default: yes
Do you want to include the numerical scores in the
detailed SpamAssassin report, or just list the names of the
scores?
|
|
Default: s
If the option "Spam Score" is set, this is the
character that will be repeated in the "Spam Score
Header", one letter for each point in the SpamAssassin
score.
|
|
SpamScore Number Instead Of Stars |
|
Default: no
If this option is set to yes, you will get a
spam−score header saying just the value of the spam
score, instead of the row of characters representing the
score. This can also be the filename of a ruleset.
|
|
Minimum Stars If on Spam List |
|
Default: 0
This sets the minimum number of "Spam Score
Characters" which will appear if a message triggered
the "Spam List" setting but received a very low
SpamAssassin score. This means that people who only filter
on the "Spam Stars" will still be able to catch
messages which receive a very low SpamAssassin score. Set
this value to 0 to disable it. This can also be the filename
of a ruleset.
|
|
Default: Found to be clean
This is the text that is added to the "Mail
Header" when a message is found to be clean and free of
viruses and other dangerous content.
|
|
Default: Found to be infected
This is the text that is added to the "Mail
Header" when a message is found to be infected with a
virus or other dangerous content.
|
|
Default: Disinfected
This is the text that is added to the "Mail
Header" of a message that is created by MailScanner to
contain disinfected documents containing macro viruses that
could be completely removed, leaving the original document
intact.
|
|
Default: Please contact the ISP for more information
This is the text that is added to the "Information
Header" of a message that has passed through
MailScanner at all. It could be used to provide a URL or
contact address for recipients if they have any queries
about the messages they have received. If the setting
"Information Header" is blank, this message will
not be added to the Mail Header.
|
|
Default: append
When a message passes through more than one MailScanner
server on your site, they will each try to add their own
headers. This option controls what should happen when trying
to add a MailScanner header that already exists in the
message. Valid options are append (append the new data to
the existing header), add (add a new header) and replace
(replace the old data with the new data).
|
|
Default: the MailScanner
This is the name of the MailScanner server that is put in
messages to users. If you have more than one MailScanner
server on your site, you will want to change this on each
server so that you can tell them apart.
|
|
Sign Messages Already Processed |
|
Default: no
If a message has already been processed by another
MailScanner server on your site, then the "Inline
HTML/Text Signature" is not added to the message again
if this option is set. Without it, you will get one
signature added for every MailScanner server that processes
the message.
|
|
Default: no
If this option is set, then the "Inline HTML/Text
Signature" will be added to the end of every clean
message processed by MailScanner. You can use this to inform
the recipient that the message has been checked, and also to
add any legal disclaimer or copyright statement you want to
add to every message. Using a ruleset for this option, you
could very simply set it so that only messages leaving your
site are signed, for example.
|
|
Default: yes
If this option is set, then the "Inline HTML/Text
Warning" is added to the start of every message that is
found to be infected or has had attachments removed for any
reason. This can be used to guide the recipients to read the
infection reports contained in the replacement
attachments.
|
|
Default: yes
If this option is set, then any message which is not
scanned by MailScanner gets the "Mail Header"
added to it with the string contained in the "Unscanned
Header Value" option. This can be used to advertise
your MailScanner service to customers/clients who are
currently not using it.
|
|
Default: Not scanned: please contact your Internet
E−Mail Service Provider for details
This supplies the text that is placed in the "Mail
Header" of messages that have not been scanned, if the
option "Mark Unscanned Messages" is set. It is a
useful place to advertise your MailScanner service to new
customers/clients.
|
|
Default:
If any of these headers are included in a a message, they
will be deleted. This is very useful for removing
return−receipt requests and any headers which mean
special things to your email client application, such as #
X−Mozilla−Status. Each header should end in a
":", but MailScanner will add it if you forget.
Headers should be separated by commas or spaces. This can
also be the filename of a ruleset.
|
|
Default: yes
Once a message has had all viruses and dangerous content
removed from it, it will then be delivered to the original
recipients if this option is set. If you want the behaviour
from previous versions of MailScanner that had the
"Deliver From Local Domains" keyword, then you
should set this to be a ruleset that only returns
"yes" for messages destined for inside your site,
and "no" for messages going out of your site.
|
Notifications back to the senders of blocked messages
|
Default: yes
Do you want to notify the people who sent you messages
containing viruses or badly−named filenames? The
default value has been changed to "no" as most
viruses now fake sender addresses and therefore should be on
the "Silent Viruses" list. This can also be the
filename of a ruleset.
|
|
Notify Senders Of Blocked Filenames Or
Filetypes |
|
Default: yes
*If* "Notify Senders" is set to yes, do you
want to notify people who sent you messages containing
attachments that are blocked due to their filename or file
contents? This can also be the filename of a ruleset.
|
|
Notify Senders Of Other Blocked Content |
|
Default: yes
*If* "Notify Senders" is set to yes, do you
want to notify people who sent you messages containing other
blocked content, such as partial messages or messages with
external bodies? This can also be the filename of a
ruleset.
|
|
Notify Senders Of Viruses |
|
Default: no
*If* "Notify Senders" is set to yes, do you
want to notify people who sent you messages containing
viruses? This can also be the filename of a ruleset.
|
|
Never Notify Senders Of Precedence |
|
Default: list bulk
If you supply a space−separated list of message
"precedence" settings, then senders of those
messages will not be warned about anything you rejected.
This is particularly suitable for mailing lists, so that any
MailScanner responses do not get sent to the entire
list.
|
Changes to subject line
|
Default: no # end
If this is set to "start" or "end"
then the "Scanned Subject Text" is inserted at the
start or the end of the Subject: line. This only happens if
the Subject: line has not already been modified for any
other reason.
|
|
Default: {Scanned}
This is the text inserted at the start or the end of the
Subject: line if the "Scanned Modify Subject"
option above is in effect.
|
|
Default: yes
If this is set, then the "Subject:" line of a
message that was infected with a virus will have the
"Virus Subject Text" text inserted at the
start.
|
|
Default: {Virus?}
This is the text inserted at the start of the
"Subject:" line if the "Virus Modify
Subject" option is set.
|
|
Default: yes
If this is set, then the "Subject:" line of a
message that had an attachment with a dangerous filename
will have the "Filename Subject Text" text
inserted at the start.
|
|
Default: {Virus?}
This is the text inserted at the start of the
"Subject:" line if the "Filename Modify
Subject" option is set.
|
|
Default: yes
If this is set, then the "Subject:" line of a
message that triggered a content check without anything else
wrong in the message will have the "Content Subject
Text" text inserted at the start.
|
|
Default: {Filename?}
This is the text inserted at the start of the
"Subject:" line if the "Content Modify
Subject" option is set.
|
|
Default: yes
If HTML tags in the message were "disarmed" by
using the HTML "Allow" options above with the
"disarm" settings, do you want to modify the
subject line? This can also be the filename of a
ruleset.
|
|
Default: {Disarmed}
This is the text to add to the start of the subject if
the "Disarmed Modify Subject" option is set. This
can also be the filename of a ruleset.
|
|
Default: yes
If this is set, then the "Subject:" line of a
message that was determined to be spam will have the
"Spam Subject Text" text inserted at the
start.
|
|
Default: {Spam?}
This is the text to add to the start of the subject if
the "Spam Modify Subject" option is set. The exact
string "_SCORE_" will be replaced by the numeric
SpamAssassin score. This can also be the filename of a
ruleset.
|
|
High Scroing Spam Modify Subject |
|
Default: yes
If this is set, then the "Subject:" line of a
message that was determined to be spam, and had a
SpamAssassin score greater than the "High SpamAssassin
Score" will have the "High Scoring Spam Subject
Text" text inserted at the start.
|
|
High Scoring Spam Subject Text |
|
Default: {Spam?}
This is just like the "Spam Subject Text"
option above, except that it applies then the score from
SpamAssassin is higher than the "High SpamAssassin
Score" value. The exact string "_SCORE_" will
be replaced by the numeric SpamAssassin score. This can also
be the filename of a ruleset.
|
Changes to the message body
|
Default: yes
When an infected or dangerous attachment is replaced with
a text message containing the infection report, should the
replacement be an attachment (yes) or should it be included
inline in the main text of the message (no).
|
|
Attachment Warning Filename |
|
Default:
%org−name%−Attachment−Warning.txt
What an infected or dangerous attachment is replaced with
a text message containing the infection report, this is the
filename of the attachment that appears in the message.
|
|
Attachment Encoding Charset |
|
Default: ISO−8859−1
This is the name of the encoding character set used for
the contents of "VirusWarning.txt"
attachments.
|
Mail archiving and monitoring
|
Default:
Space−separated list of any combination of |
|
1. email addresses to which mail should be
forwarded,
|
|
2. directory names where you want mail to be stored,
|
|
3. file names to which mail will be appended.
|
|
The files (option 3) are using the "mbox"
format suitable for most Unix mail systems. These files must
already exist since MailScanner will not create them!
If you give this option a ruleset, you can control
exactly whose mail is archived or forwarded. If you do this,
beware of the legal implications as this could be deemed to
be illegal interception unless the police have asked you to
do this.
Any of the items above can contain the magic string
_DATE_ in them which will be replaced with the current date
in yyyymmdd format. This will make archive−rolling and
maintenance much easier, as you can guarantee that
yesterday’s mail archive will not be in active use
today.
|
Notices to system administrators
|
Default: yes
Should system administrators listed in the "Notices
To" option be notified of every infection found?
|
|
Notices Include Full Headers |
|
Default: no
If this option is set, then the system administrator
notices will include the full headers of every infected
message. If this option is set to "no" then only a
restricted set of headers is included in the notices.
|
|
Hide Incoming Work Dir in Notices |
|
Default: no
When this option is set, the full directory in which the
virus was found will be removed from report messages sent to
administrators. This makes the infection reports a lot
easier to understand. It is also very useful if your notices
go to your customer sites.
|
|
Default: −− \nMailScanner\nEmail Virus
Scanner\nwww.mailscanner.info
This string is added to the bottom of all system
administrator notices, and is intended to be the signature
of your MailScanner system. To insert
"line−breaks" or "newline"
characters, use the sequence 0
|
|
Default: MailScanner
The visible part of the email address used in the
"From:" line of the notices. The
<user@domain> part of the email address is set to the
"Local Postmaster" setting.
|
|
Default: postmaster
This option provides a list of the addresses to which
virus notices should be sent. You may want to set this to be
a ruleset, providing different notification addresses for
different domains that you administer.
|
|
Default: postmaster
When virus warnings are sent to any users, this is the
email address used as the "From:" header in the
messages.
|
Definitions of virus scanners and spam detectors
|
Default: %etc−dir%/spam.lists.conf
This file contains all the definitions of the "Spam
Lists" (also known as RBL’s or DNSBL’s)
which can be used to try to detect spam based on where each
message came from. Many more spam lists can be added to this
file, but it contains the most popular ones to get you
started.
|
|
Virus Scanner Definitions |
|
Default: %etc−dir%/virus.scanners.conf
This file contains the locations of all the commands that
are run for each virus scanner. Check this file before
starting MailScanner to make sure it will run the correct
command or wrapper script.
|
Spam detection and spam lists (DNS blocklists)
|
Default: yes
If this option is set, messages will be checked to see if
they are spam.
|
|
Default: ORDB−RBL Infinite−Monkeys
This provides a space−separated list of "Spam
Lists" (or RBL’s or DNSBL’s) which are
checked for each message. These lists are based on the
numeric IP address of the server that sent the message to
your MailScanner server. Every list used here must be
defined in the "Spam List Definitions" file
mentioned above.
|
|
Default:
This provides a space−separated list of "Spam
Lists" (or RBL’s or DNSBL’s) which are
checked for each message. These lists are based on the
domain name of the sender address of each message. Every
list used here must be defined in the "Spam List
Definitions" file mentioned above.
|
|
Default: 1
If a message appears in at least this number of
"Spam Lists" (as defined above), then the message
will be treated as spam and so the "Spam Actions"
will happen, unless the message reaches the levels for
"High Scoring Spam". By default this is set to 1
to mimic the previous behaviour, which means that appearing
in any "Spam Lists" will cause the message to be
treated as spam. This can also be the filename of a
ruleset.
|
|
Spam Lists To Reach High Score |
|
Default: 5
If a message appears in at least this number of
"Spam Lists" (as defined above), then the message
will be treated as "High Scoring Spam" and so the
"High Scoring Spam Actions" will happen. You
probably want to set this to 2 if you are actually using
this feature. 5 is high enough that it will never happen
unless you use lots of "Spam Lists". This can also
be the filename of a ruleset.
|
|
Default: 10
This is the number of seconds to wait for each "Spam
List" lookup to complete. If the lookup takes longer
than this, it is killed and ignored.
|
|
Default: 7
If a "Spam List" lookup times out for this many
consecutive checks without ever succeeding, then the
particular "Spam List" entry will not be used any
more, as it appears to be unreachable. When MailScanner
restarts itself after a few hours, MailScanner will try to
use the entry again, in case service has resumed
properly.
|
|
Spam List Timeouts History |
|
Default: 10
The total number of Spam List attempts during which
"Max Spam List Timeouts" will cause the spam list
fo be marked as "unavailable". See the previous
comment for more information. The default values of 5 and 10
mean that 5 timeouts in any sequence of 10 attempts will
cause the list to be marked as "unavailable" until
the next periodic restart (see "Restart
Every").
|
|
Default: %rules−dir%/spam.whitelist.rules
This option would normally be a ruleset. Any messages for
which the ruleset result is "yes" will never be
marked as spam. This is used to create a spam
"whitelist" of addresses which are never spam. You
will probably want to include your own site (or your own
site’s IP addresses) in this ruleset.
|
|
Default: no
This option would normally be a ruleset. Any messages for
which the ruleset result is "yes" will always be
marked as spam. This is used to create a spam
"blacklist" of addresses of known spammers.
|
|
Definite Spam Is High Scoring |
|
Default: no
Setting this to yes means that spam found in the
blacklist is treated as "High Scoring Spam" in the
"Spam Actions" section below. Setting it to no
means that it will be treated as "normal" spam.
This can also be the filename of a ruleset.
|
|
Ignore Spam Whitelist If Recipients
Exceed |
|
Default: 20
Spammers have learnt that they can get their message
through by sending a message with lots of recipients, one of
which chooses to whitelist everything coming to them,
including the spammer. So if a message arrives with more
than this number of recipients, ignore the "Is
Definitely Not Spam" whitelist.
|
SpamAssassin
|
Default: no
Do you want to detect spam using the very good
SpamAssassin package? You must have installed SpamAssassin
before using this option, otherwise MailScanner will not
start properly.
NOTE for FreeBSD port user: The SpamAssassin port is not
automatically installed with the MailScanner port. You can
find it at
/usr/ports/mail/p5−Mail−SpamAssassin.
|
|
Default: 90000
SpamAssassin is quite slow when processing very large
messages. To work round this problem, this option provides a
maximum size for messages that are processed with
SpamAssassin. Most real spam is usually less than about
50,000 bytes per message.
|
|
Required Spam Assassin Score |
|
Default: 6
This gives the minimum SpamAssassin score value above
which messages are spam. This replaces SpamAssassin’s
own "required_hits" value, so that it can be a
ruleset and set to different values for different
users/domains.
|
|
Default: 20
Messages with a SpamAssassin score greater than this
value are labelled as being "High Scoring Spam",
and a different set of "Spam Actions" are applied
to messages scoring at least this value.
|
|
SpamAssassin Auto Whitelist |
|
Default: no
SpamAssassin has a feature which measures the ratio of
spam to non−spam originating from different addresses,
and will automatically add addresses to its own internal
"whitelist" if most of the messages from an
address is not spam. This option enables this feature of
SpamAssassin. Please read their documentation for more
information.
|
|
Default: %etc−dir%/spam.assassin.prefs.conf
SpamAssassin uses a "user preferences" file
which can be used to set the values of various SpamAssassin
options. This is the name of that file. Its most useful
feature is that the RBL/DNSBL/"Spam List" checks
done by SpamAssassin can be disabled as MailScanner already
does them and there is little to be gained by doing these
checks twice for every message.
|
|
Default: 30
This option sets the maximum number of seconds to wait
for SpamAssassin to process a message. This is a useful
protection against occasional bugs in SpamAssassin that can
cause it to take hours to process a single message.
|
|
Default: 20
If several consecutive calls to SpamAssassin time out,
then MailScanner decides that there is something stopping
SpamAssassin from working properly. It will therefore be
disabled for the next few hours until MailScanner restarts
itself, at which point it will be tried again.
|
|
SpamAssassin Timeouts History |
|
Default: 30
The total number of SpamAssassin attempts during which
"Max SpamAssassin Timeouts" will cause
SpamAssassin to be marked as "unavailable". See
the previous comment for more information. The default
values of 10 and 20 mean that 10 timeouts in any sequence of
20 attempts will trigger the behaviour described above,
until the next periodic restart (see "Restart
Every").
|
|
Check SpamAssassin If On Spam List |
|
Default: yes
If a message has already triggered any of the "Spam
List" checks, the SpamAssassin check will be skipped if
this option is set to "no". This can help reduce
the load on your server if SpamAssassin checks take a long
time for some reason.
|
|
Always Include SpamAssasin Report |
|
Default: no
If this option is set, then the "Spam Header"
will be included in the header of every message, so its
presence cannot be used to filter out spam by your
users’ e−mail applications.
|
|
Default: yes
If a message is spam, and this option is set, then a
header will be added to the message containing 1 character
for each point in the SpamAssassin score. This allows users
to choose for themselves the SpamAssassin scores at which
they want to do different things with the message, such as
file it or delete it.
|
|
Default: 0
If you are using the Bayesian statistics engine on a busy
server, you may well need to force a Bayesian database
rebuild and expiry at regular intervals. This is measures in
seconds. 24 hours = 86400 seconds. To disable this feature
set this to 0.
|
|
Wait During Bayes Rebuild |
|
Default: no
# The Bayesian database rebuild and expiry may take a 2
or 3 minutes # to complete. During this time you can either
wait, or simply # disable SpamAssassin checks until it has
completed. WaitDuringBayesRebuild = no
|
What to do with spam
|
Default: deliver
This can be any combination of 1 or more of the following
keywords, and these actions are applied to any message which
is spam.
|
|
•
|
|
deliver − the message is delivered to the
recipient as normal
|
|
•
|
|
delete − the message is deleted
|
|
•
|
|
store − the message is stored in the
quarantine
|
|
•
|
|
forward − an email address is supplied, to which
the message is forwarded
|
|
•
|
|
notify − Send the recipients a short notification
that spam addressed to them was not delivered. They can then
take action to request retrieval of the orginal message if
they think it was not spam.
|
|
•
|
|
striphtml − convert all in−line HTML content
in the message to be stripped to plain text, which removes
all images and scripts and so can be used to protect your
users from offensive spam. Note that using this action on
its own does not imply that the message will be delivered,
you will need to specify "deliver" or
"forward" to actually deliver the message.
|
|
•
|
|
attachment − Convert the original message into an
attachment of the message. This means the user has to take
an extra step to open the spam, and stops "web
bugs" very effectively.
|
|
•
|
|
bounce − bounce the spam message. This option
should not be used and must be enabled with the "Enable
Spam Bounce" option first.
|
|
•
|
|
header "name: value" − Add the header
"name: value" to the message. name must not
contain any spaces.
|
|
High Scoring Spam Actions |
|
This is the same as the "Spam Actions" option
above, but it gives the actions to apply to any message
whose SpamAssassin score is above the "High
Scoring" threshold described above.
|
|
Default: deliver
This is the same as the "Spam Actions" option
above, except that it applies to messages that are NOT spam.
The bounce option does not make much sense here so do not
use it.
|
|
Default: %reports−dir%/sender.spam.report.txt
When the "bounce" spam action is applied to a
message that triggered both a "Spam List" check
and SpamAssassin, this file gives the text to put in that
message.
|
|
Default:
%reports−dir%/sender.spam.rbl.report.txt
When the "bounce" spam action is applied to a
message that triggered a "Spam List" check, this
file gives the text to put in that message.
|
|
Sender SpamAssassin Report |
|
Default:
%reports−dir%/sender.spam.sa.report.txt
When the "bounce" spam action is applied to a
message that triggered SpamAssassin, this file gives the
text to put in that message.
|
|
Default: %reports−dir%/inline.spam.warning.txt
If you use the ’attachment’ Spam Action or
High Scoring Spam Action then this is the location of inline
spam report that is inserted at the top of the message.
|
|
Default:
%reports−dir%/recipient.spam.report.txt
If you use the ’notify’ Spam Action or High
Scoring Spam Action then this is the location of the
notification message that is sent to the original recipients
of the message.
|
|
Default: %rules−dir%/bounce.rules
You can use this ruleset to enable the "bounce"
Spam Action. You must *only* enable this for mail from sites
with which you have agreed to bounce possible spam. Use it
on low−scoring spam only (<10) and only to your
regular customers for use in the rare case that a message is
mis−tagged as spam when it shouldn’t have been.
Beware that many sites will automatically delete the bounce
messages created by using this option unless you have agreed
this with them in advance.
|
System logging
|
Default: mail
This is the name of the "facility" used by
syslogd to log MailScanner’s messages. If this
doesn’t mean anything to you, then either leave it
alone or else read the "syslogd" man page.
|
|
Default: no
Do you want to log the processing speed for each section
of the code for a batch? This can be very useful for
diagnosing speed problems, particularly in spam
checking.
|
|
Default: no
If this option is set, then every spam message will be
logged to syslog. If you get a lot of spam, or your server
load is high, you will want to leave this option switched
off. But if you are having trouble with spam detection,
setting this to "yes" temporarily can provide
useful debugging output.
|
|
Default: no
Do you want all non−spam to be logged? Useful if
you want to see all the SpamAssassin reports of mail that
was marked as non−spam. Note: It will generate a lot
of log traffic.
|
|
Default: no
If this option is set, then every attachment filename
that passes the "filename rules" checks will be
logged to syslog. Normally this is of no interest. But if
you are having trouble getting your filename rules correct,
setting, this can provide useful debugging output.
|
|
Default: no
Log all the filenames that are allowed by the Filetype
Rules, or just the filetypes that are denied? This can also
be the filename of a ruleset.
|
|
Default: no
Log all occurrences of "Silent Viruses" as
defined above? This can only be a simple yes/no value, not a
ruleset.
|
|
Default: no
Log all occurrences of HTML tags found in messages, that can
be blocked. This will help you build up your whitelist of
message sources for which particular HTML tags should be
allowed, such as mail from newsletters and daily cartoon
strips. This can also be the filename of a ruleset.
|
Advanced SpamAssassin Settings
|
If you are using Postfix you may well need to use some of
the settings below, as the home directory for the
"postfix" user cannot be written to by the
"postfix" user. You may also need to use these if
you have installed SpamAssassin somewhere other than the
default location.
|
|
SpamAssassin User State Dir |
|
Default:
The per−user files (bayes, auto−whitelist,
user_prefs) are looked for here and in ~/.spamassassin/.
Note the files are mutable. If this is unset then no extra
places are searched for. NOTE: SpamAssassin is always called
from MailScanner as the same user, and that is the "Run
As" user specified in MailScanner.conf. So you can only
have 1 set of "per−user" files, it’s
just that you might possibly need to modify this location.
You should not normally need to set this at all. If using
Postfix, you probably want to set this to
/var/spool/MailScanner/spamassassin and do
|
|
mkdir /var/spool/MailScanner/spamassassin
chown postfix.postfix
/var/spool/MailScanner/spamassassin |
|
SpamAssassin Install Prefix |
|
Default:
This setting is useful if SpamAssassin is installed in an
unusual place, e.g. /opt/MailScanner. The install prefix is
used to find some fallback directories if neither of the
following two settings work. If this is set then it adds to
the list of places that are searched; otherwise it has no
effect.
|
|
SpamAssassin Local Rules Dir |
|
Default:
This tells MailScanner where to look for the
site−local rules. If this is set it adds to the list
of places that are searched. MailScanner will always look at
the following places (even if this option is not set):
|
|
•
|
|
prefix/etc/spamassassin
|
|
|
•
|
|
prefix/etc/mail/spamassassin
|
|
|
•
|
|
/usr/local/etc/spamassassin
|
|
|
•
|
|
/etc/spamassassin
|
|
|
•
|
|
/etc/mail/spamassassin
|
|
|
•
|
|
maybe others as well
|
|
|
SpamAssassin Default Rules Dir |
|
This tells MailScanner where to look for the default
rules. If this is set it adds to the list of places that are
searched. MailScanner will always look at the following
places (even if this option is not set): |
|
•
|
|
prefix/share/spamassassin
|
|
|
•
|
|
/usr/local/share/spamassassin
|
|
|
•
|
|
/usr/share/spamassassin
|
|
|
•
|
|
maybe others as well
|
|
Advanced Settings
|
Default: %d
When putting the value of the spam score of a message
into the headers, how do you want to format it. If you
don’t know how to use sprintf() or printf() in C,
please *do not modify* this value. This can also be the
filename of a ruleset. A few examples for you:
|
|
%d
|
|
==> 12
|
|
|
%5.2f
|
|
==> 12.34
|
|
|
%05.1f
|
|
==> 012.3
|
|
|
Debug
|
|
|
|
|
Not for use by normal users. Setting this option to
"yes" will put MailScanner into debugging mode, in
which it creates slightly more output and will not become a
daemon.
|
|
Default: no
Do you want to debug SpamAssassin from within
MailScanner?
|
|
Default: no
Set Run In Foreground to "yes" if you want
MailScanner to operate normally in foreground (and not as a
background daemon). Use this if you are controlling the
execution of MailScanner with a tool like DJB’s
’supervise’ (see
http://cr.yp.to/daemontools.html).
|
|
Default:
If you are using an LDAP server to read the
configuration, these are the details required for the LDAP
connection. The connection is anonymous. Example:
localhost
|
|
Default:
If you are using an LDAP server to read the
configuration, these are the details required for the LDAP
connection. The connection is anonymous. Example: o=fsl
|
|
Default:
If you are using an LDAP server to read the
configuration, these are the details required for the LDAP
connection. The connection is anonymous. Example:
default
|
|
Default: no
The value of the option is actually never used, but it is
evaluated at the end of processing a batch of messages. It
is designed to be used in conjunction with a Custom
Function. The Custom Function should then be written to have
a "side effect" of doing something useful such as
logging lots of information about the batch of messages to a
file or an SQL database.
|
|
Default: yes
When attempting delivery of any messages (when the
"Delivery Method = batch") the sendmail/Exim
command will be run in the background so that MailScanner
does not have to wait for the delivery attempt to complete.
There are very few good reasons for setting this to
"no".
|
|
Default: /tmp
This is the directory in which lock files are placed to
stop the virus scanners used while they are in the middle of
updating themselves with new virus definitions. If you
change this at all, you will need to edit the
"autoupdate" scripts for all your virus
scanners.
|
|
Default:
/opt/MailScanner/lib/MailScanner/CustomFunctions
Default FreeBSD:
/usr/local/lib/MailScanner/MailScanner/CustomFunctions
Where to put the code for your "Custom
Functions". No code in this directory should be
over−written by the installation or upgrade process.
All files starting with "." or ending with
".rpmnew" will be ignored, all other files will be
compiled and may be used with Custom Functions.
|
|
Do not set this option to anything unless you know
exactly what you are doing. For sendmail and Exim,
MailScanner will choose the correct value by default. This
affects how mail queue files are locked, and your mail will
be totally screwed up if you set this option to anything
other than the correct value for your MTA. So leave it alone
and let MailScanner choose the correct value for you.
|
|
Default: supported
Minimum acceptable code stability status −−
if we come across code that’s not at least as stable
as this, we barf. This is currently only used to check that
you don’t end up using untested virus scanner support
code without realising it. Don’t even *think* about
setting this to anything other than "beta" or
"supported" on a system that receives real mail
until you have tested it yourself and are happy that it is
all working as you expect it to. Don’t set it to
anything other than "supported" on a system that
could ever receive important mail. Levels used are:
|
|
•
|
|
none − there may not even be any code.
|
|
•
|
|
unsupported − code may be completely untested, a
contributed dirty hack, anything, really.
|
|
•
|
|
alpha − code is pretty well untested. Don’t
assume it will work.
|
|
•
|
|
beta − code is tested a bit. It should work.
|
|
•
|
|
supported − code *should* be reliable.
|
|
Are you using Exim with split spool directories? If you
don’t understand this, the answer is probably
"no". Refer to the Exim documentation for more
information about split spool directories.
|
|
Use Default Rules With Multiple
Recipients |
|
Default: no
When trying to work out the value of configuration
parameters which are using a ruleset, this controls the
behaviour when a rule is checking the "To:"
addresses. If this option is set to "no", then
some rules will use the result they get from the first
matching rule for any of the recipients of a message, so the
exact value cannot be predicted for messages with more than
1 recipient. This value *cannot* be the filename of a
ruleset.
If this option is set to "yes", then the following
happens when checking the ruleset:
|
|
a)
|
|
1 recipient. Same behaviour as normal.
|
|
b)
|
|
Several recipients, but all in the same domain
(domain.com for example). The rules are checked for one that
matches the string "*@domain.com".
|
|
c)
|
|
Several recipients, not all in the same domain. The
rules are checked for one that matches the string
"*@*".
|
RULESETS
|
Ruleset files should all be put in
/opt/MailScanner/etc/rules (FreeBSD:
/usr/local/etc/MailScanner/rules) and their filename should
end in ".rules" wherever possible.
All blank lines are ignored, and comments start with
"#" and continue to the end of the line, like
this: # This line is just a comment
Other than that, every line is a rule and looks like this
example: From: john.doe@domain.com yes
As you can see, each rule has 3 fields:
1. Direction
2. Pattern to match
3. Result value (or values)
1. Direction should be one of the following:
|
|
From:
|
|
Matches when the message is from a matching address
|
|
|
To:
|
|
Matches when the message is to a matching address
|
|
|
Matches when the message is from or to a matching
address
|
|
Matches when the message is from and to a matching
address
|
|
The syntax of these is very loosely defined. Any word
containing "from", any word containing
"to", any word containing "from" and
"to" (in either order), and any word containing
"and" will work just fine. You can put them in
upper or lower case, it doesn’t matter. And any
additional punctuation will be ignored. |
|
This specifies the whether the rule should be matched
against the sender’s address (or IP address), or the
recipient’s address.
|
|
2. The pattern describes what messages should match this
rule. Some examples are:
user@sub.domain.com # Individual address
user@* # 1 user at any domain
*@sub.domain.com # Any user at 1 domain
*@*.domain.com # Any user at any sub−domain of
"domain.com"
*@domain.com # Any user at 1 specific domain
/pattern/ # Any address matching this Perl regular
# expression
192.168. # Any SMTP client IP address in this network
/pattern−with−no−letters/ # Any SMTP
client IP address matching this
# Perl regular expression
/^192.168.1[4567]./ # Any SMTP client IP address in the
networks
# 192.168.14 − 192.168.17
*@* # Default value
default # Default value
You should be able to do just about anything with
that.
3. The result value is what you could have put in the
entry in the main mailscanner.conf file had you not given
the filename of a ruleset instead.
See the file EXAMPLES for a few ideas on how to do things
with this system.
|
ATTACHMENT FILENAME RULESET
|
This is held in the filename pointed to by the
configuration option Filename rules. It contains a set of
rules that are used to judge whether any given file
attachment should be accepted or rejected on the basis of
its filename, regardless of whether it is found to be
virus−infected or not. This can not only be used for
draconian measures such as banning all .exe attachments, but
it can be used with any Perl regular expression to provide
facilities such as detection of attempts at hiding
filenames.
Many Windows e−mail programs (eg. Microsoft
Outlook) hide common file extensions in an attempt to not
baffle the user. The result is that while an attachment
called "Your Document.doc" is helpfully displayed
as "Your Document", a more sinister attachment
just as "Looks Safe.txt.pif" will appear simply as
"Looks Safe.txt". Many users recognise the .txt
filename extension as applying to plain text files, which
they know are safe. So even an experienced user may well
double−click on this attachment thinking it is just
going to start Notepad and display the text file. However,
the file is really an MS−Dos shortcut (.pif file) and
can execute any arbitrary commands the author wanted: all
without any indication to the unwitting user.
The rules are matched in order from the top to the bottom
of the file, and the first rule containing a matching
regular expression is used. Each line of the file is either
blank, a comment (in which case it starts with a
’#’ character) or is a rule made up of 4 fields
separated by one or more TAB characters:
|
|
Accept or reject the attachment if its filename matches
the regular expression
|
|
The rule is executed if the attachment matches this
expression. It may optionally be surrounded in
’/’ characters.
|
|
If the rule matches, this text is placed in the syslog.
If the text is "−", no string is logged.
|
|
If the rule matches, this text is placed in the text
message sent to the user. If the text is
"−", no text is used.
|
|
Please have a look at the filename.rules.conf or
filename.rules.conf.sample file provided with this
distribution/package/port.
|
SEE ALSO
|
|
 |
|
MailScanner would like to thank the following for their support:
|



|


|


|
|
|