VIRTUAL(5)                                             VIRTUAL(5)


NAME
       virtual - format of Postfix virtual table

SYNOPSIS
       postmap /etc/postfix/virtual

DESCRIPTION
       The  optional virtual table specifies address redirections
       for local and non-local recipients or domains.  The  redi-
       rections  are  used by the cleanup(8) daemon. The redirec-
       tions are recursive.

       The virtual redirection is applied only to recipient enve-
       lope  addresses,  and  does  not  affect  message headers.
       Think Sendmail rule set S0, if you like. Use  canonical(5)
       mapping  to  rewrite header and envelope addresses in gen-
       eral.

       Normally, the virtual table is specified as  a  text  file
       that  serves  as  input  to  the  postmap(1) command.  The
       result, an indexed file in dbm or db format, is  used  for
       fast  searching  by  the  mail system. Execute the command
       postmap  /etc/postfix/virtual  in  order  to  rebuild  the
       indexed file after changing the text file.

       When  the  table  is provided via other means such as NIS,
       LDAP or SQL, the same lookups are  done  as  for  ordinary
       indexed files.

       Alternatively,  the  table  can  be provided as a regular-
       expression map where patterns are given as regular expres-
       sions.  In  that  case, the lookups are done in a slightly
       different way as described below.

POSTFIX-STYLE VIRTUAL DOMAINS
       With a Postfix-style virtual domain,  the  virtual  domain
       has  its  own  user  name  space. Local (i.e. non-virtual)
       usernames are  not  visible  in  a  Postfix-style  virtual
       domain.  In particular, local aliases(5) and mailing lists
       are not visible as localname@virtual.domain.

       Use a Sendmail-style virtual domain (see below)  if  local
       usernames,  aliases(5)  or mailing lists should be visible
       as localname@virtual.domain.

       Support for a Postfix-style virtual domain looks like:

       /etc/postfix/virtual:
           virtual.domain       anything (right-hand content does not matter)
           postmaster@virtual.domain    postmaster
           user1@virtual.domain address1
           user2@virtual.domain address2, address3

       The  virtual.domain  anything  entry  is  required  for  a



                                                                1





VIRTUAL(5)                                             VIRTUAL(5)


       Postfix-style virtual domain.

       Do  not list a Postfix-style virtual domain in the main.cf
       mydestination configuration parameter.  Such an  entry  is
       required only for a Sendmail-style virtual domain.

       With  a  Postfix-style  virtual  domain,  the Postfix SMTP
       server  accepts  mail  for  known-user@virtual.domain  and
       rejects mail for unknown-user@virtual.domain as undeliver-
       able.

SENDMAIL-STYLE VIRTUAL DOMAINS
       With a Sendmail-style virtual domain,  every  local  (i.e.
       non-virtual) username is visible in the virtual domain. In
       particular, every local alias and mailing list is  visible
       as localname@virtual.domain.

       Use  a  Postfix-style  virtual domain (see above) if local
       usernames, aliases(5) or mailing lists should not be visi-
       ble as localname@virtual.domain.

       Support for a Sendmail-style virtual domain looks like:

       /etc/postfix/main.cf:
           mydestination = $myhostname localhost.$mydomain $mydomain
               virtual.domain

       /etc/postfix/virtual:
           user1@virtual.domain address1
           user2@virtual.domain address2, address3

       The  main.cf  mydestination  entry is required for a Send-
       mail-style virtual domain.

       Do not specify a virtual.domain whatever virtual map entry
       for  a  Sendmail-style  virtual  domain.  Such an entry is
       required only with a Postfix-style virtual domain.

       With a Sendmail-style virtual domain,  the  Postfix  local
       delivery  agent  delivers  mail  for  an unknown user@vir-
       tual.domain to a local (i.e.  non-virtual) user  that  has
       the  same  name;  if no such recipient exists, the Postfix
       local delivery agent bounces the mail to the sender.

TABLE FORMAT
       The format of the virtual table is  as  follows,  mappings
       being tried in the order as listed in this manual page:

       blanks and comments
              Blank  lines  are  ignored,  as are lines beginning
              with `#'.

       leading whitespace
              Lines  that  begin  with  whitespace  continue  the



                                                                2





VIRTUAL(5)                                             VIRTUAL(5)


              previous line.

       pattern result
              When  pattern matches a mail address, replace it by
              the corresponding result.

       With lookups from indexed files such as DB or DBM, or from
       networked  tables  such  as NIS, LDAP or SQL, patterns are
       tried in the order as listed below:

       user@domain address, address, ...
              Mail for  user@domain  is  redirected  to  address.
              This form has the highest precedence.

       user address, address, ...
              Mail  for  user@site  is redirected to address when
              site is equal to $myorigin, when site is listed  in
              $mydestination,   or   when   it   is   listed   in
              $inet_interfaces.

              This functionality overlaps with  functionality  of
              the local alias(5) database. The difference is that
              virtual  mapping  can  be  applied   to   non-local
              addresses.

       @domain address, address, ...
              Mail  for  any  user  in  domain  is  redirected to
              address.  This form has the lowest precedence.

       In all the above forms, when address has the form  @other-
       domain,  the result is the same user in otherdomain.  This
       works for the first address in the expansion only.

ADDRESS EXTENSION
       When the search fails, and the address localpart  contains
       the  optional recipient delimiter (e.g., user+foo@domain),
       the search is repeated for the  unextended  address  (e.g.
       user@domain), and the unmatched address extension is prop-
       agated to the result of expansion. The matching order  is:
       user+foo@domain, user@domain, user+foo, user, and @domain.

REGULAR EXPRESSION TABLES
       This section describes how the table lookups  change  when
       the table is given in the form of regular expressions. For
       a description of regular expression lookup  table  syntax,
       see regexp_table(5) or pcre_table(5).

       Each  pattern  is  a regular expression that is applied to
       the entire address being looked up. Thus, user@domain mail
       addresses  are  not  broken up into their user and @domain
       constituent parts, nor is user+foo broken up into user and
       foo.

       Patterns  are  applied  in  the  order as specified in the



                                                                3





VIRTUAL(5)                                             VIRTUAL(5)


       table, until a pattern is found that  matches  the  search
       string.

       Results  are the same as with normal indexed file lookups,
       with the additional feature that parenthesized  substrings
       from  the pattern can be interpolated as $1, $2 and so on.

BUGS
       The table format does not understand quoting  conventions.

CONFIGURATION PARAMETERS
       The  following  main.cf parameters are especially relevant
       to this topic. See the Postfix  main.cf  file  for  syntax
       details  and  for  default  values. Use the postfix reload
       command after a configuration change.

       virtual_maps
              List of virtual mapping tables.

       Other parameters of interest:

       inet_interfaces
              The network interface addresses  that  this  system
              receives mail on.

       mydestination
              List  of  domains  that  this mail system considers
              local.

       myorigin
              The domain that is appended to locally-posted mail.

       owner_request_special
              Give special treatment to owner-xxx and xxx-request
              addresses.

SEE ALSO
       cleanup(8) canonicalize and enqueue mail
       postmap(1) create mapping table
       pcre_table(5) format of PCRE tables
       regexp_table(5) format of POSIX regular expression tables

LICENSE
       The Secure Mailer license must be  distributed  with  this
       software.

AUTHOR(S)
       Wietse Venema
       IBM T.J. Watson Research
       P.O. Box 704
       Yorktown Heights, NY 10598, USA






                                                                4