cyr_virusscan

Scan for viruses using configured virus scanner or manage infected messages using search criteria.

Synopsis

cyr_virusscan [ -C config-file ] [ -s imap-search-string ] [ -r [ -n] ] [-v] [ mboxpattern1 ... ]

Description

cyr_virusscan can be used to invoke an external virus scanner (currently only ClamAV is supported) to scan specified IMAP mailboxes. If no mboxpattern is given, cyr_virusscan works on all mailboxes.

Alternately, with the -s option, the IMAP SEARCH string will be used as a specification of messages which are assumed to be infected, and will be treated as such. The virus scanner is not invoked. Useful for removing messages without a distinct signature, such as Phish.

A table of infected messages will be output.

To remove infected messages, use the -r flag. Infected messages will be expunged from the user's mailbox.

With the notify flag, -n, notifications will be appended to the inbox of the mailbox owner, containing message digest information for the affected mail. This flag only works in combination with -r. The notification message can by customised by template, for details see Notifications below.

cyr_virusscan can be configured to run periodically by cron(8) via crontab(5) or your preferred method (i.e. /etc/cron.hourly), or by master(8) via the EVENTS{} section in cyrus.conf(5).

cyr_virusscan reads its configuration options out of the imapd.conf(5) file unless specified otherwise by -C.

Note that Cyrus does not ship with any virus scanners: you need to install one separately to make use of it with Cyrus.

Options

-C config-file

Use the specified configuration file config-file rather than the default imapd.conf(5).

-n, --notify

Notify mailbox owner of deleted messages via email. This flag is only operable in combination with -r.

-r, --remove-infected

Remove infected messages.

-s imap-search-string, --search=imap-search-string

Rather than scanning for viruses, messages matching the search criteria will be treated as infected.

-v, --verbose

Produce more verbose output

Notifications

When the -n flag is provided, notifications are sent to mailbox owners when infected messages are removed. One notification is sent per owner, containing a digest of each message that was deleted from any of their mailboxes.

The default notification subject is "Automatically deleted mail", which can be overridden by setting virusscan_notification_subject in imapd.conf(5) to a UTF-8 value.

Each infected message will be described according to the following template:

The following message was deleted from mailbox '%MAILBOX%'
because it was infected with virus '%VIRUS%'

    Message-ID: %MSG_ID%
    Date: %MSG_DATE%
    From: %MSG_FROM%
    Subject: %MSG_SUBJECT%
    IMAP UID: %MSG_UID%

To use a custom template, create a UTF-8 file containing your desired text and using the same %-delimited substitutions as above, and set the virusscan_notification_template option in imapd.conf(5) to its path.

The notification message will be properly MIME-encoded at delivery. Do not pre-encode the template file or the subject!

When cyr_virusscan starts up, if notifications have been requested (with the -n flag), a basic sanity check of the template will be performed prior to initialising the antivirus engine. If it appears that the resultant notifications would be undeliverable for some reason, cyr_virusscan will exit immediately with an error, rather than risk deleting messages without notifying.

Examples

cyr_virusscan

Scan all mailboxes, printing report on the screen. Do not remove infected messages.

Using ClamAV virus scanner
Loaded 5789330 virus signatures.

Mailbox Name                                       Msg UID      Status  Virus Name
----------------------------------------        ----------      ------  --------------------------------------------------
user.betty                                          185395        READ  Heuristics.Phishing.Email.SpoofedDomain
user.betty.Bank stuff                                    9        READ  Html.Phishing.Bank-1172
user.betty.Bank stuff                                   10        READ  Html.Phishing.Bank-1172
user.betty.Bank stuff                                   11        READ  Html.Phishing.Bank-1172

Mailbox Name                                       Msg UID      Status  Virus Name
----------------------------------------        ----------      ------  --------------------------------------------------
user.bovik                                           17426        READ  Email.Trojan.Trojan-1051
cyr_virusscan -r -n user/bovik

Scan mailbox user/bovik, removing infected messages and append notifications to Bovik's inbox.

Mailbox Name                                       Msg UID      Status  Virus Name
----------------------------------------        ----------      ------  --------------------------------------------------
user.bovik                                         17426          READ  Email.Trojan.Trojan-1051

A message like this would end up in bovik's inbox:

The following message was deleted from mailbox 'INBOX'
because it was infected with virus 'Email.Trojan.Trojan-1051'

    Message-ID: <201308131519.r7DFJM9K083763@tselina.kiev.ua>
    Date: Tue, 13 Aug 2013 18:19:22 +0300 (EEST)
    From: "FEDEX Thomas Cooper" <thomas_cooper94@themovieposterpage.com>
    Subject: Problem with the delivery of parcel
    IMAP UID: 17426
cyr_virusscan -r -n -s 'SUBJECT "Fedex"' user/bovik

Search mailbox user/bovik for messages which have Fedex in the subject line, removing them all, and appending notifications to Bovik's inbox.

Mailbox Name                                       Msg UID      Status  Virus Name
----------------------------------------        ----------      ------  --------------------------------------------------
user.bovik                                         17185          READ  Cyrus Administrator Targeted Removal (Phish, etc.)
user.bovik                                         17203          READ  Cyrus Administrator Targeted Removal (Phish, etc.)
user.bovik                                         17338          READ  Cyrus Administrator Targeted Removal (Phish, etc.)
user.bovik                                         17373          READ  Cyrus Administrator Targeted Removal (Phish, etc.)
user.bovik                                         19238          READ  Cyrus Administrator Targeted Removal (Phish, etc.)
user.bovik                                         19268          READ  Cyrus Administrator Targeted Removal (Phish, etc.)

History

Virus scan support was first introduced in Cyrus version 3.0.

Files

/etc/imapd.conf

See Also

imapd.conf(5), master(8), ClamAV