Provided by: vmm_0.7.0-0.2_all
NAME
vmm - command line tool to manage email domains/accounts/aliases
SYNOPSIS
vmm -h|-v|--help|--version vmm subcommand -h|--help vmm subcommand arguments [options]
DESCRIPTION
vmm (a virtual mail manager) is the easy to use command line tool for administrators and postmasters to manage (alias) domains, accounts, aliases and relocated users. It allows you to simply and quickly administer your mail server. It's designed for Dovecot and Postfix with a PostgreSQL backend. Each subcommand has both a long and a short form. The short form is shown enclosed in parentheses. Both forms are case sensitive. Most of the subcommands take one or more arguments.
OPTIONS
The following options are recognized by vmm. -h, --help show a list of available subcommands and exit. -v, --version show vmm's version and copyright information and exit.
ARGUMENTS
address The complete e-mail address (local-part@fqdn) of an user account, alias address or relocated user. destination Is either an e-mail address when used with ALIAS SUBCOMMANDS. Or a fqdn when used with ALIASDOMAIN SUBCOMMANDS. fqdn The fully qualified domain name - without the trailing dot - of a domain or alias domain. messages An integer value which specifies a quota limit in number of messages. 0 (zero) means unlimited - no quota limit for the number of messages. option is the name of a configuration option, prefixed with the section name and a dot. For example: misc.transport All configuration options are described in vmm.cfg(5). service The name of a service, commonly used with Dovecot. Supported services are: imap, pop3, sieve and smtp. storage Specifies a quota limit in bytes. One of the following prefixes can be appended to the integer value: b (bytes), k (kilobytes), M (megabytes) or G (gigabytes). 0 (zero) means unlimited - no quota limit in bytes. transport A transport for Postfix, written as: transport: or transport:nexthop. See transport(5) for more details.
GENERAL SUBCOMMANDS
configget (cg) vmm configget option This subcommand is used to display the actual value of the given configuration option. Example: vmm configget misc.crypt_sha512_rounds misc.crypt_sha512_rounds = 5000 configset (cs) vmm configset option value Use this subcommand to set or update a single configuration option's value. option is the configuration option, value is the option's new value. Note: This subcommand will create a new vmm.cfg without any comments. Your current configuration file will be backed as vmm.cfg.bak. Example: vmm configget domain.transport domain.transport = dovecot: vmm configset domain.transport lmtp:unix:private/dovecot-lmtp vmm cg domain.transport domain.transport = lmtp:unix:private/dovecot-lmtp configure (cf) vmm configure [-s section] Starts the interactive configuration for all configuration sections. In this process the currently set value of each option will be displayed in square brackets. If no value is configured, the default value of each option will be displayed in square brackets. Press the return key, to accept the displayed value. If the optional argument section is given, only the configuration options from the given section will be displayed and will be configurable. The following sections are available: account Account settings bin Paths to external binaries database Database settings domain Domain settings mailbox Mailbox settings misc Miscellaneous settings All configuration options are described in vmm.cfg(5). Note: This subcommand will create a new vmm.cfg without any comments. Your current configuration file will be backed as vmm.cfg.bak. Example: vmm configure -s mailbox Using configuration file: /usr/local/etc/vmm.cfg * Configuration section: `mailbox' Enter new value for option folders [Drafts:Sent:Templates:Trash]: Enter new value for option format [maildir]: mdbox Enter new value for option subscribe [True]: Enter new value for option root [Maildir]: mdbox getuser (gu) vmm getuser uid If only the uid is available, for example from process list, the subcommand getuser will show the user's address. Example: vmm getuser 79876 Account information ------------------- UID............: 79876 GID............: 70704 Address........: a.user@example.com listdomains (ld) vmm listdomains [-p pattern] This subcommand lists all available domains. All domain names will be prefixed either with `[+]', if the domain is a primary domain, or with `[-]', if it is an alias domain name. The output can be limited with an optional pattern. To perform a wild card search, the % character can be used at the start and/or the end of the pattern. Example: vmm listdomains -p %example% Matching domains ---------------- [+] example.com [-] e.g.example.com [-] example.name [+] example.net [+] example.org listaddresses (ll) vmm listaddresses [-p pattern] This command lists all defined addresses. Addresses belonging to alias-domains are prefixed with a '-', addresses of regular domains with a '+'. Additionally, the letters 'u', 'a', and 'r' indicate the type of each address: user, alias and relocated respectively. The output can be limited with an optional pattern. To perform a wild card search, the % character can be used at the start and/or the end of the pattern. If you do not include an '@'-character in your pattern, the command will only match your pattern agains the fqdn of the addresses. A pattern like %user%@%example% will match against any address that contains the term 'user' in its local-part AND 'example' in its fqdn. Example: vmm listaddresses -p example.com vmm listaddresses -p %master@% listaliases (la) vmm listaliases [-p pattern] This command lists all defined aliases. Aliases belonging to alias-domains are prefixed with a '-', addresses of regular domains with a '+'. The output can be limited with an optional pattern. To perform a wild card search, the % character can be used at the start and/or the end of the pattern. If you do not include an '@'-character in your pattern, the command will only match your pattern agains the fqdn of the addresses. A pattern like %user%@%example% will match against any address that contains the term 'user' in its local-part AND 'example' in its fqdn. Example: vmm listaliases -p example.com vmm listaliases -p %master@% listrelocated (lr) vmm listrelocated [-p pattern] This command lists all defined relocated addresses. Relocated entries belonging to alias- domains are prefixed with a '-', addresses of regular domains with a '+'. The output can be limited with an optional pattern. To perform a wild card search, the % character can be used at the start and/or the end of the pattern. If you do not include an '@'-character in your pattern, the command will only match your pattern agains the fqdn of the addresses. A pattern like %user%@%example% will match against any address that contains the term 'user' in its local-part AND 'example' in its fqdn. Example: vmm listrelocated -p example.com vmm listrelocated -p %master@% listusers (lu) vmm listusers [-p pattern] This command lists all user accounts. User accounts belonging to alias-domains are prefixed with a '-', addresses of regular domains with a '+'. The output can be limited with an optional pattern. To perform a wild card search, the % character can be used at the start and/or the end of the pattern. If you do not include an '@'-character in your pattern, the command will only match your pattern agains the fqdn of the addresses. A pattern like %user%@%example% will match against any address that contains the term 'user' in its local-part AND 'example' in its fqdn. Example: vmm listusers -p example.com vmm listusers -p %master@% listpwschemes (lp) vmm listpwschemes This subcommand lists all password schemes which could be used in the vmm.cfg as value of the misc.password_scheme option. The output varies, depending on the used Dovecot version and the system's libc. Additionally a few usable encoding suffixes will be displayed. One of them can be appended to the password scheme. Example: vmm listpwschemes Usable password schemes ----------------------- CLEARTEXT CRAM-MD5 CRYPT DIGEST-MD5 HMAC-MD5 LANMAN LDAP-MD5 MD5 MD5-CRYPT NTLM OTP PLAIN PLAIN-MD4 PLAIN-MD5 RPA SHA SHA1 SHA256 SHA256-CRYPT SHA512 SHA512-CRYPT SKEY SMD5 SSHA SSHA256 SSHA512 Usable encoding suffixes ------------------------ .B64 .BASE64 .HEX
DOMAIN SUBCOMMANDS
domainadd (da) vmm domainadd fqdn [-n note] [-t transport] -n note the note that should be set. -t transport a Postfix transport (transport: or transport:nexthop). Adds the new domain into the database and creates the domain directory. If the optional argument transport is given, it will override the default transport (domain.transport) from vmm.cfg. The specified transport will be the default transport for all new accounts in this domain. Configuration-related behavior: domain.auto_postmaster When that option is set to true (default) vmm will automatically create the postmaster account for the new domain and prompt for postmaster@fqdn's password. account.random_password When the value of that option is also set to true, vmm will automatically create the postmaster account for the new domain and print the generated postmaster password to stdout. Examples: vmm domainadd support.example.com -t smtp:[mx1.example.com]:2025 Creating account for postmaster@support.example.com Enter new password: Retype new password: vmm cs account.random_password true vmm domainadd sales.example.com Creating account for postmaster@sales.example.com Generated password: pLJUQ6Xg_z domaindelete (dd) vmm domaindelete fqdn [--delete-directory] [--force] --delete-directory When this option is given, vmm will delete the directory of the given domain. This overrides the domain.delete_directory setting of vmm.cfg. --force Use this option in oder to force the deletion of the domain, even if there are accounts, aliases, catch-all accounts and/or relocated users. This subcommand deletes the domain specified by fqdn. If there are accounts, aliases and/or relocated users assigned to the given domain, vmm will abort the requested operation and show an error message. If you know, what you are doing, you can specify the optional argument --force. If you really always know what you are doing, edit your vmm.cfg and set the option domain.force_deletion to true. domaininfo (di) vmm domaininfo fqdn [-d details] This subcommand shows some information about the given domain. For a more detailed information about the domain the optional argument details can be specified. A possible details value can be one of the following six keywords: accounts to list the e-mail addresses of all existing user accounts aliasdomains to list all assigned alias domain names aliases to list all available alias e-mail addresses catchall to list all catch-all destinations relocated to list the e-mail addresses of all relocated users full to list all information mentioned above Example: vmm domaininfo sales.example.com Domain information ------------------ Domain Name......: sales.example.com GID..............: 70708 Domain Directory.: /srv/mail/c/70708 Quota Limit/User.: Storage: 500.00 MiB; Messages: 10,000 Active Services..: IMAP SIEVE Transport........: lmtp:unix:private/dovecot-lmtp Alias Domains....: 0 Accounts.........: 1 Aliases..........: 0 Relocated........: 0 Catch-All Dests..: 1 domainquota (dq) vmm domainquota fqdn storage [-m messages] [--force] This subcommand is used to configure a new quota limit for the accounts of the domain - not for the domain itself. The default quota limit for accounts is defined in the vmm.cfg (domain.quota_bytes and domain.quota_messages). The new quota limit will affect only those accounts for which the limit has not been overridden. If you want to restore the default to all accounts, you may pass the optional argument --force. When the argument messages was omitted the default number of messages 0 (zero) will be applied. Example: vmm domainquota example.com 1g --force domainservices (ds) vmm domainservices fqdn (-e service ...| -d service ...) [--force] To define which services could be used by the users of the domain — with the given fqdn — use this subcommand. If you pass them after -e, each supplied service will be enabled/usable. If you pass them after -d, they will become deactivated/unusable. Possible service names are: imap, pop3, sieve and smtp. The new service set will affect only those accounts for which the set has not been overridden. If you want to restore the default to all accounts, you may pass the option --force. domaintransport (dt) vmm domaintransport fqdn transport [--force] A new transport for the indicated domain can be set with this subcommand. The new transport will affect only those accounts for which the transport has not been overridden. If you want to restore the default to all accounts, you may give the option --force. Example: vmm domaintransport support.example.com dovecot: domainnote (do) vmm domainnote fqdn -d|-n note -d delete the domain's note. -n note the note that should be set. With this subcommand, it is possible to attach a note to the specified domain. In order to delete an existing note, pass the -d option. Example: vmm do example.com -n `Belongs to Robert'
ALIAS DOMAIN SUBCOMMANDS
An alias domain is an alias for a domain that was previously added with the subcommand domainadd. All accounts, aliases and relocated users from the domain will be also available in the alias domain. In the following is to be assumed that example.net is an alias for example.com. Postfix will not accept erroneously e-mails for unknown.user@example.net and bounce them back later to the mostly faked sender. Postfix will immediately reject all e-mails addressed to nonexistent users. This behavior is ensured as long as you use the recommended database queries in your $config_directory/pgsql-*.cf configuration files. aliasdomainadd (ada) vmm aliasdomainadd fqdn destination This subcommand adds the new alias domain (fqdn) to the destination domain that should be aliased. Example: vmm aliasdomainadd example.net example.com aliasdomaindelete (add) vmm aliasdomaindelete fqdn Use this subcommand if the alias domain fqdn should be removed. Example: vmm aliasdomaindelete e.g.example.com aliasdomaininfo (adi) vmm aliasdomaininfo fqdn This subcommand shows to which domain the alias domain fqdn is assigned to. Example: vmm adi example.net Alias domain information ------------------------ The alias domain example.net belongs to: * example.com aliasdomainswitch (ads) vmm aliasdomainswitch fqdn destination If the destination of the existing alias domain fqdn should be switched to another destination use this subcommand. Example: vmm aliasdomainswitch example.name example.org
ACCOUNT SUBCOMMANDS
useradd (ua) vmm useradd address [-n note] [-p password] -n note the note that should be set. -p password the new user's password. Use this subcommand to create a new e-mail account for the given address. If the password is not provided, vmm will prompt for it interactively. When no password is provided and account.random_password is set to true, vmm will generate a random password and print it to stdout after the account has been created. Examples: vmm ua d.user@example.com -p "A 5ecR3t P4s5\/\/0rd" vmm useradd e.user@example.com Enter new password: Retype new password: userdelete (ud) vmm userdelete address [--delete-directory] [--force] --delete-directory When this option is present, vmm will also delete the account's home directory. This overrides the account.delete_directory setting of vmm.cfg. --force When this option is given, vmm will delete the account, even if there are aliases with the account's address as their destination. Those aliases will be deleted too. Use this subcommand to delete the account with the given address. If there are one or more aliases with an identical destination address, vmm will abort the requested operation and show an error message. To prevent this, give the optional argument --force. userinfo (ui) vmm userinfo address [-d details] This subcommand displays some information about the account specified by address. If the optional argument details is given some more information will be displayed. Possible values for details are: aliases to list all alias addresses with the destination address du to display the disk usage of the user's mail directory. In order to summarize the disk usage each time this subcommand is executed automatically, set account.disk_usage in your vmm.cfg to true. full to list all information mentioned above Example: vmm ui d.user@example.com Account information ------------------- Address..........: d.user@example.com Name.............: None UID..............: 79881 GID..............: 70704 Home.............: /srv/mail/2/70704/79881 Mail_Location....: mdbox:~/mdbox Quota Storage....: [ 0.00%] 0/500.00 MiB Quota Messages...: [ 0.00%] 0/10,000 Transport........: lmtp:unix:private/dovecot-lmtp SMTP.............: disabled POP3.............: disabled IMAP.............: enabled SIEVE............: enabled username (un) vmm username address -d|-n name -d delete the user's name. -n name a user's real name. The user's real name can be set/updated with this subcommand. In order to delete the value stored for the account, pass the -d option. Example: vmm un d.user@example.com -n "John Doe" userpassword (up) vmm userpassword address ([-p password] [-s scheme] | --hash pwhash]) -p password The user's new password. -s scheme When a scheme was specified, it overrides the misc.password_scheme setting, configured in the vmm.cfg file. --hash pwhash A hashed password, prefixed with {SCHEME}; as generated by doveadm pw. You should enclose the hashed password in single quotes, if it contains one ore more dollar signs ($). The password of an account can be updated with this subcommand. If no password or pwhash was provided, vmm will prompt for a password interactively. Note: When passing a hashed password, vmm checks only if the included SCHEME is supported by your Dovecot installation. No further checks are done. Example: vmm up d.user@example.com -p "A |\/|0r3 5ecur3 P4s5\/\/0rd?" usernote (uo) vmm usernote address -d|-n note -d delete the user's note. -n note the note that should be set. With this subcommand, it is possible to attach a note to the specified account. In order to delete an existing note, pass the -d option. Example: vmm uo d.user@example.com -n `Only needed until end of May 2013' userquota (uq) vmm userquota address storage [-m messages] This subcommand is used to set a new quota limit for the given account. When the argument messages was omitted the default number of messages 0 (zero) will be applied. Instead of storage limit pass the keyword domain to remove the account-specific override, causing the domain's value to be in effect. Example: vmm userquota d.user@example.com 750m userservices (us) vmm userservices address (-e service ...| -d service ...| -r) To grant a user access to the specified services, use this command. If you pass services after -e, each service will be enabled/usable. If you pass them after -d they will be disabled/unusable. in order to restore the domain defaults on the address, pass -r without any more parameters. Example: vmm userservices d.user@example.com -d smtp imap usertransport (ut) vmm usertransport address transport A different transport for an account can be specified with this subcommand. Instead of transport pass 'domain' to remove the account-specific override, causing the domain's value to be in effect. Example: Assumed you want to use Dovecot's dsync(1) to convert a user's mailbox from Maildir format to mdbox format, you can tell Postfix to retry later. vmm ut d.user@example.com "retry:4.0.0 Mailbox being migrated" # convert the mailbox ... then set the transport to Dovecot's lmtp vmm ut d.user@example.com lmtp:unix:private/dovecot-lmtp
ALIAS SUBCOMMANDS
aliasadd (aa) vmm aliasadd address destination ... This subcommand is used to create a new alias address with one or more destination addresses. Within the destination address, the placeholders %n, %d, and %= will be replaced by the local part, the domain, or the email address with '@' replaced by '=' respectively. In combination with alias domains, this enables domain-specific destinations. Examples: vmm aliasadd john.doe@example.com d.user@example.com vmm aa support@example.com d.user@example.com e.user@example.com vmm aa postmaster@example.com postmaster+%d@example.org aliasdelete (ad) vmm aliasdelete address [destination ...] This subcommand is used to delete one or multiple destinations from the alias with the given address. When no destination address was specified the alias with all its destinations will be deleted. Example: vmm ad support@example.com d.user@example.com aliasinfo (ai) vmm aliasinfo address Information about the alias with the given address can be displayed with this subcommand. Example: vmm aliasinfo support@example.com Alias information ----------------- Mail for support@example.com will be redirected to: * e.user@example.com
RELOCATED SUBCOMMANDS
relocatedadd (ra) vmm relocatedadd address newaddress A new relocated user can be created with this subcommand. address is the user's ex-email address, for example b.user@example.com, and newaddress points to the new email address where the user can be reached. Example: vmm relocatedadd b.user@example.com b-user@company.tld relocatedinfo (ri) vmm relocatedinfo address This subcommand shows the new address of the relocated user with the given address. Example: vmm relocatedinfo b.user@example.com Relocated information --------------------- User `b.user@example.com' has moved to `b-user@company.tld' relocateddelete (rd) vmm relocateddelete address Use this subcommand in order to delete the relocated user with the given address. Example: vmm relocateddelete b.user@example.com
CATCH-ALL SUBCOMMANDS
catchalladd (caa) vmm catchalladd fqdn destination ... This subcommand allows to specify destination addresses for a domain, which shall receive mail addressed to unknown local parts within that domain. Those catch-all aliases hence "catch all" mail to any address in the domain (unless a more specific alias, mailbox or relocated entry exists). WARNING: Catch-all addresses can cause mail server flooding because spammers like to deliver mail to all possible combinations of names, e.g. to all addresses between abba@example.org and zztop@example.org. Example: vmm catchalladd example.com user@example.org catchallinfo (cai) vmm catchallinfo fqdn This subcommand displays information about catch-all aliases defined for a domain. Example: vmm catchallinfo example.com Catch-all information --------------------- Mail to unknown local-parts in domain example.com will be sent to: * user@example.org catchalldelete (cad) vmm catchalldelete fqdn [destination ...] With this subcommand, catch-all aliases defined for a domain can be removed, either all of them, or those destinations which were specified explicitly. Example: vmm catchalldelete example.com user@example.com
FILES
/root/vmm.cfg will be used when found. /usr/local/etc/vmm.cfg will be used when the above file doesn't exist. /etc/vmm.cfg will be used when none of the both above mentioned files exists.
SEE ALSO
doveadm-pw(1), dsync(1), transport(5), vmm.cfg(5)
INTERNET RESOURCES
Homepage http://vmm.localdomain.org/ Project site http://sf.net/projects/vmm/ Bug tracker https://bitbucket.org/pvo/vmm/issues
COPYING
vmm and its manual pages were written by Pascal Volk <user+vmm AT localhost.localdomain.org> and are licensed under the terms of the BSD License.