POSTCONF(1) POSTCONF(1) NAME postconf - Postfix configuration utility SYNOPSIS Managing main.cf: postconf [-dfhHnopvx] [-c config_dir] [-C class,...] [parameter ...] postconf [-epv] [-c config_dir] parameter=value ... postconf -# [-pv] [-c config_dir] parameter ... postconf -X [-pv] [-c config_dir] parameter ... Managing master.cf service entries: postconf -M [-fovx] [-c config_dir] [service[/type] ...] postconf -M [-ev] [-c config_dir] service/type=value ... postconf -M# [-v] [-c config_dir] service/type ... postconf -MX [-v] [-c config_dir] service/type ... Managing master.cf service fields: postconf -F [-fhHovx] [-c config_dir] [service[/type[/field]] ...] postconf -F [-ev] [-c config_dir] service/type/field=value ... Managing master.cf service parameters: postconf -P [-fhHovx] [-c config_dir] [service[/type[/parameter]] ...] postconf -P [-ev] [-c config_dir] service/type/parameter=value ... postconf -PX [-v] [-c config_dir] service/type/parameter ... Managing bounce message templates: postconf -b [-v] [-c config_dir] [template_file] postconf -t [-v] [-c config_dir] [template_file] Managing TLS features: postconf -T mode [-v] [-c config_dir] Managing other configuration: postconf -a|-A|-l|-m [-v] [-c config_dir] DESCRIPTION By default, the postconf(1) command displays the values of main.cf con- figuration parameters, and warns about possible mis-typed parameter names (Postfix 2.9 and later). It can also change main.cf configura- tion parameter values, or display other configuration information about the Postfix mail system. Options: -a List the available SASL server plug-in types. The SASL plug-in type is selected with the smtpd_sasl_type configuration parame- ter by specifying one of the names listed below. cyrus This server plug-in is available when Postfix is built with Cyrus SASL support. dovecot This server plug-in uses the Dovecot authentication server, and is available when Postfix is built with any form of SASL support. This feature is available with Postfix 2.3 and later. -A List the available SASL client plug-in types. The SASL plug-in type is selected with the smtp_sasl_type or lmtp_sasl_type con- figuration parameters by specifying one of the names listed below. cyrus This client plug-in is available when Postfix is built with Cyrus SASL support. This feature is available with Postfix 2.3 and later. -b [template_file] Display the message text that appears at the beginning of deliv- ery status notification (DSN) messages, replacing $name expres- sions with actual values as described in bounce(5). To override the built-in templates, specify a template file name at the end of the postconf(1) command line, or specify a file name in main.cf with the bounce_template_file parameter. To force selection of the built-in templates, specify an empty template file name on the postconf(1) command line (in shell language: ""). This feature is available with Postfix 2.3 and later. -c config_dir The main.cf configuration file is in the named directory instead of the default configuration directory. -C class,... When displaying main.cf parameters, select only parameters from the specified class(es): builtin Parameters with built-in names. service Parameters with service-defined names (the first field of a master.cf entry plus a Postfix-defined suffix). user Parameters with user-defined names. all All the above classes. The default is as if "-C all" is specified. This feature is available with Postfix 2.9 and later. -d Print main.cf default parameter settings instead of actual set- tings. Specify -df to fold long lines for human readability (Postfix 2.9 and later). -e Edit the main.cf configuration file, and update parameter set- tings with the "name=value" pairs on the postconf(1) command line. With -M, edit the master.cf configuration file, and replace one or more service entries with new values as specified with "ser- vice/type=value" on the postconf(1) command line. With -F, edit the master.cf configuration file, and replace one or more service fields with new values as specied with "ser- vice/type/field=value" on the postconf(1) command line. Cur- rently, the "command" field contains the command name and com- mand arguments. this may change in the near future, so that the "command" field contains only the command name, and a new "argu- ments" pseudofield contains the command arguments. With -P, edit the master.cf configuration file, and add or update one or more service parameter settings (-o parame- ter=value settings) with new values as specied with "ser- vice/type/parameter=value" on the postconf(1) command line. In all cases the file is copied to a temporary file then renamed into place. Specify quotes to protect special characters and whitespace on the postconf(1) command line. The -e option is no longer needed with Postfix version 2.8 and later. -f Fold long lines when printing main.cf or master.cf configuration file entries, for human readability. This feature is available with Postfix 2.9 and later. -F Show master.cf per-entry field settings (by default all services and all fields), formatted as "service/type/field=value", one per line. Specify -Ff to fold long lines. Specify one or more "service/type/field" instances on the post- conf(1) command line to limit the output to fields of interest. Trailing parameter name or service type fields that are omitted will be handled as "*" wildcard fields. This feature is available with Postfix 2.11 and later. -h Show parameter or attribute values without the "name = " label that normally precedes the value. -H Show parameter or attribute names without the " = value" that normally follows the name. This feature is available with Postfix 3.1 and later. -l List the names of all supported mailbox locking methods. Post- fix supports the following methods: flock A kernel-based advisory locking method for local files only. This locking method is available on systems with a BSD compatible library. fcntl A kernel-based advisory locking method for local and remote files. dotlock An application-level locking method. An application locks a file named filename by creating a file named file- name.lock. The application is expected to remove its own lock file, as well as stale lock files that were left behind after abnormal program termination. -m List the names of all supported lookup table types. In Postfix configuration files, lookup tables are specified as type:name, where type is one of the types listed below. The table name syn- tax depends on the lookup table type as described in the DATA- BASE_README document. btree A sorted, balanced tree structure. Available on systems with support for Berkeley DB databases. cdb A read-optimized structure with no support for incremen- tal updates. Available on systems with support for CDB databases. cidr A table that associates values with Classless Inter-Domain Routing (CIDR) patterns. This is described in cidr_table(5). dbm An indexed file type based on hashing. Available on sys- tems with support for DBM databases. environ The UNIX process environment array. The lookup key is the variable name. Originally implemented for testing, some- one may find this useful someday. fail A table that reliably fails all requests. The lookup ta- ble name is used for logging. This table exists to sim- plify Postfix error tests. hash An indexed file type based on hashing. Available on sys- tems with support for Berkeley DB databases. inline (read-only) A non-shared, in-memory lookup table. Example: "inline:{ key=value, { key = text with whitespace or comma }}". Key-value pairs are separated by whitespace or comma; whitespace after "{" and before "}" is ignored. Inline tables eliminate the need to create a database file for just a few fixed elements. See also the static: map type. internal A non-shared, in-memory hash table. Its content are lost when a process terminates. lmdb OpenLDAP LMDB database (a memory-mapped, persistent file). Available on systems with support for LMDB data- bases. This is described in lmdb_table(5). ldap (read-only) LDAP database client. This is described in ldap_table(5). memcache Memcache database client. This is described in mem- cache_table(5). mysql (read-only) MySQL database client. Available on systems with support for MySQL databases. This is described in mysql_ta- ble(5). pcre (read-only) A lookup table based on Perl Compatible Regular Expres- sions. The file format is described in pcre_table(5). pgsql (read-only) PostgreSQL database client. This is described in pgsql_table(5). pipemap (read-only) A lookup table that constructs a pipeline of tables. Example: "pipemap:{type_1:name_1, ..., type_n:name_n}". Each "pipemap:" query is given to the first table. Each lookup result becomes the query for the next table in the pipeline, and the last table produces the final result. When any table lookup produces no result, the pipeline produces no result. The first and last characters of the "pipemap:" table name must be "{" and "}". Within these, individual maps are separated with comma or whitespace. proxy Postfix proxymap(8) client for shared access to Postfix databases. The table name syntax is type:name. randmap (read-only) An in-memory table that performs random selection. Exam- ple: "randmap:{result_1, ..., result_n}". Each table query returns a random choice from the specified results. The first and last characters of the "randmap:" table name must be "{" and "}". Within these, individual results are separated with comma or whitespace. To give a specific result more weight, specify it multiple times. regexp (read-only) A lookup table based on regular expressions. The file format is described in regexp_table(5). sdbm An indexed file type based on hashing. Available on sys- tems with support for SDBM databases. socketmap (read-only) Sendmail-style socketmap client. The table name is inet:host:port:name for a TCP/IP server, or unix:path- name:name for a UNIX-domain server. This is described in socketmap_table(5). sqlite (read-only) SQLite database. This is described in sqlite_table(5). static (read-only) A table that always returns its name as lookup result. For example, static:foobar always returns the string foo- bar as lookup result. Specify "static:{ text with white- space }" when the result contains whitespace; this form ignores whitespace after "{" and before "}". See also the inline: map. tcp (read-only) TCP/IP client. The protocol is described in tcp_table(5). texthash (read-only) Produces similar results as hash: files, except that you don't need to run the postmap(1) command before you can use the file, and that it does not detect changes after the file is read. unionmap (read-only) A table that sends each query to multiple lookup tables and that concatenates all found results, separated by comma. The table name syntax is the same as for pipemap. unix (read-only) A limited view of the UNIX authentication database. The following tables are implemented: unix:passwd.byname The table is the UNIX password database. The key is a login name. The result is a password file entry in passwd(5) format. unix:group.byname The table is the UNIX group database. The key is a group name. The result is a group file entry in group(5) format. Other table types may exist depending on how Postfix was built. -M Show master.cf file contents instead of main.cf file contents. Specify -Mf to fold long lines for human readability. Specify zero or more arguments, each with a service-name or ser- vice-name/service-type pair, where service-name is the first field of a master.cf entry and service-type is one of (inet, unix, fifo, or pass). If service-name or service-name/service-type is specified, only the matching master.cf entries will be output. For example, "postconf -Mf smtp" will output all services named "smtp", and "postconf -Mf smtp/inet" will output only the smtp service that listens on the network. Trailing service type fields that are omitted will be handled as "*" wildcard fields. This feature is available with Postfix 2.9 and later. The syntax was changed from "name.type" to "name/type", and "*" wildcard support was added with Postfix 2.11. -n Show only configuration parameters that have explicit name=value settings in main.cf. Specify -nf to fold long lines for human readability (Postfix 2.9 and later). -o name=value Override main.cf parameter settings. This feature is available with Postfix 2.10 and later. -p Show main.cf parameter settings. This is the default. This feature is available with Postfix 2.11 and later. -P Show master.cf service parameter settings (by default all ser- vices and all parameters), formatted as "service/type/parame- ter=value", one per line. Specify -Pf to fold long lines. Specify one or more "service/type/parameter" instances on the postconf(1) command line to limit the output to parameters of interest. Trailing parameter name or service type fields that are omitted will be handled as "*" wildcard fields. This feature is available with Postfix 2.11 and later. -t [template_file] Display the templates for text that appears at the beginning of delivery status notification (DSN) messages, without expanding $name expressions. To override the built-in templates, specify a template file name at the end of the postconf(1) command line, or specify a file name in main.cf with the bounce_template_file parameter. To force selection of the built-in templates, specify an empty template file name on the postconf(1) command line (in shell language: ""). This feature is available with Postfix 2.3 and later. -T mode If Postfix is compiled without TLS support, the -T option pro- duces no output. Otherwise, if an invalid mode is specified, the -T option reports an error and exits with a non-zero status code. The valid modes are: compile-version Output the OpenSSL version that Postfix was compiled with (i.e. the OpenSSL version in a header file). The output format is the same as with the command "openssl version". run-version Output the OpenSSL version that Postfix is linked with at runtime (i.e. the OpenSSL version in a shared library). public-key-algorithms Output the lower-case names of the supported public-key algorithms, one per-line. This feature is available with Postfix 3.1 and later. -v Enable verbose logging for debugging purposes. Multiple -v options make the software increasingly verbose. -x Expand $name in main.cf or master.cf parameter values. The expansion is recursive. This feature is available with Postfix 2.10 and later. -X Edit the main.cf configuration file, and remove the parameters named on the postconf(1) command line. Specify a list of param- eter names, not "name=value" pairs. With -M, edit the master.cf configuration file, and remove one or more service entries as specified with "service/type" on the postconf(1) command line. With -P, edit the master.cf configuration file, and remove one or more service parameter settings (-o parameter=value settings) as specied with "service/type/parameter" on the postconf(1) com- mand line. In all cases the file is copied to a temporary file then renamed into place. Specify quotes to protect special characters on the postconf(1) command line. There is no postconf(1) command to perform the reverse opera- tion. This feature is available with Postfix 2.10 and later. Support for -M and -P was added with Postfix 2.11. -# Edit the main.cf configuration file, and comment out the parame- ters named on the postconf(1) command line, so that those param- eters revert to their default values. Specify a list of parame- ter names, not "name=value" pairs. With -M, edit the master.cf configuration file, and comment out one or more service entries as specified with "service/type" on the postconf(1) command line. In all cases the file is copied to a temporary file then renamed into place. Specify quotes to protect special characters on the postconf(1) command line. There is no postconf(1) command to perform the reverse opera- tion. This feature is available with Postfix 2.6 and later. Support for -M was added with Postfix 2.11. DIAGNOSTICS Problems are reported to the standard error stream. ENVIRONMENT MAIL_CONFIG Directory with Postfix configuration files. CONFIGURATION PARAMETERS The following main.cf parameters are especially relevant to this pro- gram. The text below provides only a parameter summary. See postconf(5) for more details including examples. config_directory (see 'postconf -d' output) The default location of the Postfix main.cf and master.cf con- figuration files. bounce_template_file (empty) Pathname of a configuration file with bounce message templates. FILES /etc/postfix/main.cf, Postfix configuration parameters /etc/postfix/master.cf, Postfix master daemon configuration SEE ALSO bounce(5), bounce template file format master(5), master.cf configuration file syntax postconf(5), main.cf configuration file syntax README FILES DATABASE_README, Postfix lookup table overview 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 Wietse Venema Google, Inc. 111 8th Avenue New York, NY 10011, USA POSTCONF(1)