a command syntax reminiscent of
ed(1)
with lines replaced by messages.
It is based on Berkeley Mail 8.1,
is intended to provide the functionality of the POSIX
mailx
command,
and offers extensions
for MIME, IMAP, POP3, SMTP, and S/MIME.
Mailx
provides enhanced
features for interactive use, such as caching and disconnected
operation for IMAP, message threading, scoring, and filtering.
It is also usable as a mail batch language, both for sending
and receiving mail.
The following options are accepted:
- -A name
-
Executes an
account
command (see below)
for name after the startup files have been read.
- -a file
-
Attach the given file to the message.
- -B
-
Make standard input and standard output line-buffered.
- -b address
-
Send blind carbon copies to list.
List should be a comma-separated
list of names.
- -c address
-
Send carbon copies to list of users.
- -D
-
Start in
disconnected
mode; see the description for the
disconnected
variable option.
- -d
-
Enables debugging messages and disables the actual delivery of messages.
Unlike
-v,
this option is intended for
mailx
development only.
- -e
-
Just check if mail is present in the system mailbox.
If yes, return an exit status of zero,
else, a non-zero value.
- -E
-
If an outgoing message does not contain any text
in its first or only message part,
do not send it but discard it silently,
effectively setting the
skipemptybody
variable at program startup.
This is useful for sending messages
from scripts started by
cron(8).
- -f [file]
-
Read in the contents of the user's mbox
(or the specified file)
for processing;
when
mailx
is quit, it writes
undeleted messages back
to this file.
The string file is handled
as described for the
folder
command below.
- -F
-
Save the message to send
in a file named after the local part
of the first recipient's address.
- -H
-
Print header summaries for all messages and exit.
- -h hops
-
Invoke sendmail with the specified hop count.
This option has no effect when SMTP is used for sending mail.
- -i
-
Ignore tty interrupt signals.
This is
particularly useful when using
mailx on noisy phone lines.
- -I
-
Shows the `Newsgroup:' or `Article-Id:' fields
in the header summary.
Only applicable in combination with
-f.
- -n
-
Inhibits reading /etc/mail.rc upon startup.
This option should be activated for
mailx
scripts that are invoked on more than one machine,
because the contents of that file may differ between them.
- -N
-
Inhibits the initial display of message headers when reading mail
or editing a mail folder.
- -q file
-
Start the message with the contents of the specified file.
May be given in send mode only.
- -r address
-
Sets the
From
address. Overrides any
from
variable specified in environment or startup files.
Tilde escapes are disabled.
The -r address options are passed to the mail transfer agent
unless SMTP is used.
This option exists for compatibility only;
it is recommended to set the
from
variable directly instead.
- -R
-
Opens any folders read-only.
- -s subject
-
Specify subject on command line (only the first argument after the
-s
flag is used as a subject; be careful to quote subjects
containing spaces).
- -S variable[=value]
-
Sets the internal option
variable
and, in case of a string option,
assigns
value
to it.
Note, that when setting
from
variable, domain name of host is automatically added if value does not contain any.
If you want to enter
from
address with owner's name, you can use, for example, following format:
-S
"from=System User <DoNotReply>"
- -T name
-
Writes the `Message-Id:' and `Article-Id:' header fields
of each message read in the file
name.
Implies
-I.
Compressed files are handled as described for the
folder
command below.
- -t
-
The message to be sent is expected to contain a message header
with `To:', `Cc:', or `Bcc:' fields giving its recipients.
Recipients specified on the command line are ignored.
- -u user
-
Reads the mailbox of the given user name.
- -v
-
Verbose mode.
The details of
delivery are displayed on the user's terminal.
- -V
-
Print mailx's version and exit.
- -~
-
Enable tilde escapes even if not in interactive mode.
Sending mail
To send a message to one or more people,
mailx can be invoked with arguments
which are the names of people
to whom the mail will be sent.
The user is then expected to type in his message,
followed by an `control-D' at the beginning of a line.
The section below Replying to
or originating mail,
describes some features of mailx
available to help when composing letters.
Reading mail
In normal usage mailx is given no arguments
and checks the user's mail out of the post office,
then prints out a one line header
of each message found.
The current message is initially
the first message (numbered 1)
and can be printed using the print command
which can be abbreviated `p').
The user can move among the messages
much as he moves between lines in
ed(1),
with the commands `+' and `-' moving backwards and forwards,
and simple numbers.
Disposing of mail
After examining a message
the user can delete `d') the message
or reply `r') to it.
Deletion causes the mailx program
to forget about the message.
This is not irreversible;
the message can be undeleted `u')
by giving its number,
or the mailx session can be aborted
by giving the exit `x') command.
Deleted messages will, however,
usually disappear never to be seen again.
Specifying messages
Commands such as print and delete
can be given a list of message numbers
as arguments to apply to a number of messages at once.
Thus `delete 1 2' deletes messages 1 and 2,
while `delete 1-5' deletes messages 1 through 5.
In sorted or threaded mode (see the
sort
and
thread
commands),
`delete 1-5' deletes the messages
that are located between (and including) messages 1 through 5
in the sorted/threaded order,
as shown in the header summary.
The following special message names exist:
- :n
-
All new messages.
- :o
-
All old messages (any not in state read or new).
- :u
-
All unread messages.
- :d
-
All deleted messages (for the
undelete
command).
- :r
-
All read messages.
- :f
-
All `flagged' messages.
- :a
-
All answered messages
(cf. the
markanswered
variable).
- :t
-
All messages marked as draft.
- :k
-
All `killed' messages.
- :j
-
All messages classified as junk.
- .
-
The current message.
- ;
-
The message that was previously the current message.
- ,
-
The parent message of the current message,
that is the message with the Message-ID
given in the `In-Reply-To:' field
or the last entry of the `References:' field
of the current message.
- -
-
The next previous undeleted message,
or the next previous deleted message for the
undelete
command.
In sorted/threaded mode,
the next previous such message in the sorted/threaded order.
- +
-
The next undeleted message,
or the next deleted message for the
undelete
command.
In sorted/threaded mode,
the next such message in the sorted/threaded order.
- ^
-
The first undeleted message,
or the first deleted message
for the
undelete
command.
In sorted/threaded mode,
the first such message in the sorted/threaded order.
- $
-
The last message.
In sorted/threaded mode,
the last message in the sorted/threaded order.
- &x
-
In threaded mode,
selects the message addressed with
x,
where
x
is any other message specification,
and all messages from the thread that begins at it.
Otherwise, it is identical to
x.
If
x
is omitted,
the thread beginning with the current message is selected.
- *
-
All messages.
- `
-
All messages that were included in the message list
for the previous command.
- /string
-
All messages that contain
string
in the subject field (case ignored).
See also the
searchheaders
variable.
If
string
is empty,
the string from the previous specification of that type is used again.
- address
-
All messages from
address.
By default, this is a case-sensitive search
for the complete email address.
If the
allnet
variable is set,
only the local part of the addresses is evaluated for the comparison.
Otherwise if the
showname
variable is set,
a case-sensitive search for the complete real name
of a sender is performed.
The IMAP-style
(from address)
expression can be used instead
if substring matches are desired.
- (criterion)
-
All messages that satisfy the given IMAP-style SEARCH
criterion.
This addressing mode is available with all types of folders;
for folders not located on IMAP servers,
or for servers unable to execute the SEARCH command,
mailx
will perform the search locally.
Strings must be enclosed by double quotes `"' in their entirety
if they contain white space or parentheses;
within the quotes,
only backslash `\' is recognized as an escape character.
All string searches are case-insensitive.
When the description indicates
that the `envelope' representation of an address field is used,
this means that the search string is checked against
both a list constructed as
("real name" "source-route" "local-part" "domain-part")
for each address,
and the addresses without real names
from the respective header field.
Criteria can be nested using parentheses.
- (criterion1 criterion2 ... criterionN)
-
All messages that satisfy all of the given criteria.
- (or criterion1 criterion2)
-
All messages that satisfy either
criterion1
or
criterion2,
or both.
To connect more than two criteria using `or',
(or) specifications have to be nested using additional parentheses,
as with `(or a (or b c))';
`(or a b c)' means ((a or b) and c).
For a simple `or' operation of independent criteria
on the lowest nesting level,
it is possible to achieve similar effects by using
three separate criteria, as with
`(a) (b) (c)'.
- (not criterion)
-
All messages that do not satisfy
criterion.
- (bcc string)
-
All messages that contain
string
in the `envelope' representation of the
Bcc:
field.
- (cc string)
-
All messages that contain
string
in the `envelope' representation of the
Cc:
field.
- (from string)
-
All messages that contain
string
in the `envelope' representation of the
From:
field.
- (subject string)
-
All messages that contain
string
in the
Subject:
field.
- (to string)
-
All messages that contain
string
in the `envelope' representation of the
To:
field.
- (header name string)
-
All messages that contain
string
in the specified
Name:
field.
- (body string)
-
All messages that contain
string
in their body.
- (text string)
-
All messages that contain
string
in their header or body.
- (larger size)
-
All messages that are larger than
size
(in bytes).
- (smaller size)
-
All messages that are smaller than
size
(in bytes).
- (before date)
-
All messages that were received before
date;
date
must be in the form
d[d]-mon-yyyy,
where d[d] is the day of the month
as one or two digits,
mon
is the name of the month---one of
`Jan', `Feb', `Mar',
`Apr', `May', `Jun',
`Jul', `Aug', `Sep',
`Oct', `Nov', or `Dec',
and
yyyy
is the year as four digits;
e.g. "30-Aug-2004".
- (on date)
-
All messages that were received on the specified date.
- (since date)
-
All messages that were received since the specified date.
- (sentbefore date)
-
All messages that were sent on the specified date.
- (senton date)
-
All messages that were sent on the specified date.
- (sentsince date)
-
All messages that were sent since the specified date.
- ()
-
The same criterion as for the previous search.
This specification cannot be used as part of another criterion.
If the previous command line contained more than one independent criterion,
the last of those criteria is used.
A practical method to read a set of messages
is to issue a
from
command with the search criteria first
to check for appropriate messages,
and to read each single message then by typing ``' repeatedly.
Replying to or originating mail
The
reply
command can be used
to set up a response to a message,
sending it back to the person who it was from.
Text the user types in then,
up to an end-of-file,
defines the contents of the message.
While the user is composing a message,
mailx treats lines beginning with the character `~' specially.
For instance, typing `~m' (alone on a line)
will place a copy of the current message into the response
right shifting it by a tabstop
(see
indentprefix
variable, below).
Other escapes will set up subject fields,
add and delete recipients to the message,
attach files to it
and allow the user to escape to an editor
to revise the message
or to a shell to run some commands.
(These options are given in the summary below.)
Ending a mail processing session
The user can end a mailx session
with the quit (`q') command.
Messages which have been examined
go to the user's mbox file
unless they have been deleted
in which case they are discarded.
Unexamined messages go back
to the post office.
(See the -f option above).
Personal and systemwide distribution lists
It is also possible to create
a personal distribution lists so that,
for instance, the user can send mail
to `cohorts' and have it go
to a group of people.
Such lists can be defined by placing a line like
alias cohorts bill ozalp jkf mark kridle@ucbcory
in the file .mailrc in the user's home directory.
The current list of such aliases
can be displayed with the alias command in mailx.
System wide distribution lists can be created
by editing /etc/aliases, see
aliases(5)
and
sendmail(8);
these are kept in a different syntax.
In mail the user sends,
personal aliases will be expanded
in mail sent to others so that
they will be able to reply to the recipients.
System wide aliases are not expanded when the mail is sent,
but any reply returned to the machine
will have the system wide alias expanded
as all mail goes through sendmail.
Recipient address specifications
If the
expandaddr
option is not set (the default), recipient addresses must be names of
local mailboxes or Internet mail addresses.
If the
expandaddr
option is set, the following rules apply:
When an address is used to name a recipient
(in any of To, Cc, or Bcc),
names of local mail folders
and pipes to external commands
can also be specified;
the message text is then written to them.
The rules are: Any name which starts with a
`|'
character specifies a pipe,
the command string following the `|'
is executed and the message is sent to its standard input;
any other name which contains a
`@'
character is treated as a mail address;
any other name which starts with a
`+'
character specifies a folder name;
any other name which contains a
`/'
character
but no
`!'
or
`%'
character before also specifies a folder name;
what remains is treated as a mail address.
Compressed folders are handled as described for the
folder
command below.
Network mail (Internet / ARPA, UUCP, Berknet)
See
mailaddr(7)
for a description of network addresses.
Mailx has a number of options
which can be set in the .mailrc file
to alter its behavior;
thus `set askcc' enables the askcc feature.
(These options are summarized below).
MIME types
For any outgoing attachment,
mailx tries to determine the content type.
It does this by reading MIME type files
whose lines have the following syntax:
type/subtype extension [extension . . .]
where type/subtype are strings describing the file contents,
and extension is the part of a filename starting after the last dot.
Any line not immediately beginning with an ASCII alphabetical character is
ignored by mailx.
If there is a match with the extension of the file to attach,
the given type/subtype pair is used.
Otherwise, or if the filename has no extension,
the content types text/plain or application/octet-stream are used,
the first for text or international text files,
the second for any file that contains formatting characters
other than newlines and horizontal tabulators.
Character sets
Mailx
normally detects the character set of the terminal
using the LC_CTYPE locale setting.
If the locale cannot be used appropriately,
the ttycharset variable should be set
to provide an explicit value.
When reading messages,
their text is converted to the terminal character set if possible.
Unprintable characters and illegal byte sequences are detected
and replaced by Unicode substitute characters or question marks
unless the
print-all-chars
is set at initialization time.
The character set for outgoing messages
is not necessarily the same
as the one used on the terminal.
If an outgoing text message
contains characters not representable in US-ASCII,
the character set being used
must be declared within its header.
Permissible values can be declared
using the sendcharsets variable,
separated by commas;
mailx
tries each of the values in order
and uses the first appropriate one.
If the message contains characters that cannot be represented
in any of the given character sets,
the message will not be sent,
and its text will be saved to the `dead.letter' file.
Messages that contain NUL bytes are not converted.
Outgoing attachments are converted if they are plain text.
If the
sendcharsets
variable contains more than one character set name,
the
~@
tilde escape will ask for the character sets for individual attachments
if it is invoked without arguments.
Best results are usually achieved
when
mailx
is run in a UTF-8 locale
on a UTF-8 capable terminal.
In this setup,
characters from various countries can be displayed,
while it is still possible to use more simple
character sets for sending
to retain maximum compatibility with older mail clients.
Commands
Each command is typed on a line by itself,
and may take arguments following the command word.
The command need not be typed in its entirety -
the first command which matches the typed prefix is used.
For commands which take message lists as arguments,
if no message list is given,
then the next message forward which satisfies
the command's requirements is used.
If there are no messages forward of the current message,
the search proceeds backwards,
and if there are no good messages at all,
mailx types `applicable messages' and aborts the command.
If the command begins with a # sign,
the line is ignored.
The arguments to commands can be quoted, using the following methods:
- •
-
An argument can be enclosed between paired double-quotes
"" or single-quotes ''; any white space, shell
word expansion, or backslash characters within the quotes
are treated literally as part of the argument.
A double-quote will be treated literally within
single-quotes and vice versa. These special properties of
the quote marks occur only when they are paired at the
beginning and end of the argument.
- •
-
A backslash outside of the enclosing quotes is discarded
and the following character is treated literally as part of
the argument.
- •
-
An unquoted backslash at the end of a command line is
discarded and the next line continues the command.
Filenames, where expected, are subjected to the following
transformations, in sequence:
- •
-
If the filename begins with an unquoted plus sign, and
the
folder
variable is defined,
the plus sign will be replaced by the value of the
folder
variable followed by a slash. If the
folder
variable is
unset or is set to null, the filename will be unchanged.
- •
-
Shell word expansions are applied to the filename.
If more than a single pathname results
from this expansion and the command is expecting one
file, an error results.
The following commands are provided:
- -
-
Print out the preceding message.
If given a numeric argument n,
goes to the n'th previous message and prints it.
- ?
-
Prints a brief summary of commands.
- !
-
Executes the shell (see
sh(1)
and
csh(1))
command which follows.
- |
-
A synonym for the pipe command.
- account
-
(ac) Creates, selects or lists
an email account.
An account is formed by a group of commands,
primarily of those to set variables.
With two arguments,
of which the second is a `{',
the first argument gives an account name,
and the following lines create a group of commands for that account
until a line containing a single `}' appears.
With one argument,
the previously created group of commands
for the account name is executed,
and a
folder
command is executed for the system mailbox or inbox
of that account.
Without arguments,
the list of accounts and their contents are printed.
As an example,
account myisp {
set folder=imaps://mylogin@imap.myisp.example
set record=+Sent
set from="myname@myisp.example (My Name)"
set smtp=smtp.myisp.example
}
creates an account named `myisp'
which can later be selected by specifying `account myisp'.
- alias
-
(a) With no arguments,
prints out all currently-defined aliases.
With one argument, prints out that alias.
With more than one argument,
creates a new alias or changes an old one.
- alternates
-
(alt) The alternates command is useful
if the user has accounts on several machines.
It can be used to inform mailx
that the listed addresses all belong to the invoking user.
When he replies to messages,
mailx will not send a copy of the message
to any of the addresses
listed on the alternates list.
If the alternates command is given
with no argument,
the current set of alternate names is displayed.
- answered
-
(ans) Takes a message list and marks each message
as a having been answered.
This mark has no technical meaning in the mail system;
it just causes messages to be marked in the header summary,
and makes them specially addressable.
- cache
-
Only applicable to cached IMAP mailboxes;
takes a message list and reads the specified messages
into the IMAP cache.
- call
-
Calls a macro (see the
define
command).
- cd
-
Same as chdir.
- certsave
-
Only applicable to S/MIME signed messages.
Takes a message list and a file name
and saves the certificates contained within the message signatures
to the named file in both human-readable and PEM format.
The certificates can later be used to send encrypted messages
to the messages' originators by setting the
smime-encrypt-user@host
variable.
- chdir
-
(ch) Changes the user's working directory to that specified,
if given.
If no directory is given,
then changes to the user's login directory.
- classify
-
(cl) Takes a list of messages and
examines their contents for characteristics of junk mail
using Bayesian filtering.
Messages considered to be junk are then marked as such.
The junk mail database is not changed.
- collapse
-
(coll)
Only applicable to threaded mode.
Takes a message list
and makes all replies to these messages invisible
in header summaries,
unless they are in state `new'.
- connect
-
(conn) If operating in disconnected mode on an IMAP mailbox,
switch to online mode and connect to the mail server
while retaining the mailbox status.
See the description of the
disconnected
variable for more information.
- copy
-
(c) The copy command does the same thing that
save
does,
except that it does not mark the messages
it is used on for deletion when the user quits.
Compressed files and IMAP mailboxes are handled as described for the
folder
command.
- Copy
-
(C) Similar to
copy,
but saves the messages in a file named after the local part
of the sender address of the first message.
- decrypt
-
(dec) For unencrypted messages,
this command is identical to
copy.
Encrypted messages are first decrypted, if possible,
and then copied.
- Decrypt
-
(Dec) Similar to
decrypt,
but saves the messages in a file named after the local part
of the sender address of the first message.
- define
-
(def) Defines a macro.
A macro definition is a sequence of commands in the following form:
define name {
command1
command2
...
commandN
}
Once defined, a macro can be explicitly invoked using the
call
command,
or can be implicitly invoked by setting the
folder-hook
or
folder-hook-fullname
variables.
- defines
-
Prints the currently defined macros including their contents.
- delete
-
(d) Takes a list of messages as argument
and marks them all as deleted.
Deleted messages will not be saved in mbox,
nor will they be available for most other commands.
- discard
-
Same as ignore.
- disconnect
-
(disco) If operating in online mode on an IMAP mailbox,
switch to disconnected mode while retaining the mailbox status.
See the description of the
disconnected
variable for more information.
A list of messages may optionally be given as argument;
the respective messages are then read into the cache
before the connection is closed.
Thus `disco *' makes the entire current mailbox
available for disconnected use.
- dp or dt
-
Deletes the current message
and prints the next message.
If there is no next message,
mailx says `at EOF'.
- draft
-
Takes a message list and marks each message
as a draft.
This mark has no technical meaning in the mail system;
it just causes messages to be marked in the header summary,
and makes them specially addressable.
- echo
-
Echoes its arguments,
resolving special names
as documented for the folder command.
The escape sequences
`\a',
`\b',
`\c',
`\f',
`\n',
`\r',
`\t',
`\v',
`\\', and
`\0num'
are interpreted
as with the
echo(1)
command.
- edit
-
(e) Takes a list of messages
and points the text editor
at each one in turn.
Modified contents are discarded
unless the
writebackedited
variable is set.
- else
-
Marks the end of the then-part
of an if statement
and the beginning of the part
to take effect if the condition
of the if statement is false.
- endif
-
Marks the end of an if statement.
- exit
-
(ex or x) Effects an immediate return to the Shell
without modifying the user's system mailbox,
his mbox file,
or his edit file in -f.
- file
-
(fi) The same as folder.
- flag
-
(fl) Takes a message list
and marks the messages as `flagged' for urgent/special attention.
This mark has no technical meaning in the mail system;
it just causes messages to be highlighted in the header summary,
and makes them specially addressable.
- folders
-
With no arguments,
list the names of the folders in the folder directory.
With an existing folder as an argument,
lists then names of folders below the named folder;
e.g. the command `folders @'
lists the folders on the base level of the current IMAP server.
See also the
imap-list-depth
variable.
- folder
-
(fold) The folder command switches
to a new mail file or folder.
With no arguments, it tells the user
which file he is currently reading.
If an argument is given,
it will write out changes
(such as deletions) the user has made
in the current file and read in
the new file.
Some special conventions are recognized for the name.
# means the previous file,
% means the invoking user's system mailbox,
%user means user's system mailbox,
& means the invoking user's mbox file,
and +file means a file in the folder directory.
%:filespec expands to the same value as filespec,
but the file is handled as a system mailbox
e. g. by the mbox and save commands.
If the name matches one of the strings defined with the
shortcut
command,
it is replaced by its long form and expanded.
If the name ends with .gz or .bz2,
it is treated as compressed with
gzip(1)
or
bzip2(1),
respectively.
Likewise, if name does not exist,
but either name.gz or name.bz2 exists,
the compressed file is used.
If name refers to a directory
with the subdirectories `tmp', `new', and `cur',
it is treated as a folder in
maildir
format.
A name of the form
protocol://[user@]host[:port][/file]
is taken as an Internet mailbox specification.
The supported protocols are currently
imap
(IMAP v4r1),
imaps
(IMAP with SSL/TLS encryption),
pop3
(POP3),
and
pop3s
(POP3 with SSL/TLS encryption).
If
user
contains special characters, in particular `/' or `%',
they must be escaped in URL notation,
as `%2F' or `%25'.
The optional
file
part applies to IMAP only;
if it is omitted,
the default `INBOX' is used.
If mailx is connected to an IMAP server,
a name of the form @mailbox
refers to the mailbox on that server.
If the `folder' variable refers to an IMAP account,
the special name `%' selects the `INBOX' on that account.
- Followup
-
(F) Similar to
Respond,
but saves the message in a file
named after the local part of the first recipient's address.
- followup
-
(fo) Similar to
respond,
but saves the message in a file
named after the local part of the first recipient's address.
- followupall
-
Similar to
followup,
but responds to all recipients regardless of the
flipr
and
Replyall
variables.
- followupsender
-
Similar to
Followup,
but responds to the sender only regardless of the
flipr
and
Replyall
variables.
- forward
-
(fwd)
Takes a message and the address of a recipient
and forwards the message to him.
The text of the original message is included in the new one,
with the value of the
fwdheading
variable printed before.
The
fwdignore
and
fwdretain
commands specify which header fields are included in the new message.
Only the first part of a multipart message is included unless the
forward-as-attachment
option is set.
- Forward
-
(Fwd)
Similar to
forward,
but saves the message in a file named after
the local part of the recipient's address.
- from
-
(f) Takes a list of messages
and prints their message headers,
piped through the pager if the output does not fit on the screen.
- fwdignore
-
Specifies which header fields are to be ignored with the
forward
command.
This command has no effect when the
forward-as-attachment
option is set.
- fwdretain
-
Specifies which header fields are to be retained with the
forward
command.
fwdretain
overrides
fwdignore.
This command has no effect when the
forward-as-attachment
option is set.
- good
-
(go) Takes a list of messages
and marks all of them as not being junk mail.
Data from these messages is then inserted
into the junk mail database for future classification.
- headers
-
(h) Lists the current range of headers,
which is an 18-message group.
If a `+' argument is given,
then the next 18-message group is printed,
and if a `-' argument is given,
the previous 18-message group is printed.
- help
-
A synonym for ?.
- hold
-
(ho, also preserve) Takes a message list
and marks each message therein to be saved
in the user's system mailbox
instead of in mbox.
Does not override the delete command.
mailx
deviates from the POSIX standard with this command,
as a `next' command issued after `hold'
will display the following message,
not the current one.
- if
-
Commands in mailx's startup files
can be executed conditionally
depending on whether the user is sending
or receiving mail with the if command.
For example:
if receive
commands . . .
endif
An else form is also available:
if receive
commands . . .
else
commands . . .
endif
Note that the only allowed conditions are
receive,
send,
and
term
(execute command if standard input is a tty).
- ignore
-
Add the list of header fields named to the ignored list.
Header fields in the ignore list are not printed
on the terminal when a message is printed.
This command is very handy for suppression
of certain machine-generated header fields.
The Type and Print commands can be used
to print a message in its entirety,
including ignored fields.
If ignore is executed with no arguments,
it lists the current set of ignored fields.
- imap
-
Sends command strings directly to the current IMAP server.
Mailx operates always in IMAP selected state
on the current mailbox;
commands that change this
will produce undesirable results
and should be avoided.
Useful IMAP commands are:
-
- create
-
Takes the name of an IMAP mailbox as an argument
and creates it.
- getquotaroot
-
Takes the name of an IMAP mailbox as an argument
and prints the quotas that apply to the mailbox.
Not all IMAP servers support this command.
- namespace
-
Takes no arguments and prints the Personal Namespaces,
the Other User's Namespaces,
and the Shared Namespaces.
Each namespace type is printed in parentheses;
if there are multiple namespaces of the same type,
inner parentheses separate them.
For each namespace,
a namespace prefix and a hierarchy separator is listed.
Not all IMAP servers support this command.
- inc
-
Same as
newmail.
- junk
-
(j) Takes a list of messages
and marks all of them as junk mail.
Data from these messages is then inserted
into the junk mail database for future classification.
- kill
-
(k) Takes a list of messages and `kills' them.
Killed messages are not printed in header summaries,
and are ignored by the
next
command.
The
kill
command also sets the score of the messages to negative infinity,
so that subsequent
score
commands will not unkill them again.
Killing is only effective for the current session on a folder;
when it is quit, all messages are automatically unkilled.
- list
-
Prints the names of all available commands.
- Mail
-
(M) Similar to
mail,
but saves the message in a file
named after the local part of the first recipient's address.
- mail
-
(m) Takes as argument login names
and distribution group names
and sends mail to those people.
- mbox
-
Indicate that a list of messages be sent
to mbox in the user's home directory when
mailx
is quit.
This is the default action for messages
if unless the
hold
option is set.
mailx
deviates from the POSIX standard with this command,
as a `next' command issued after `mbox'
will display the following message,
not the current one.
- move
-
(mv) Acts like
copy,
but marks the messages for deletion
if they were transferred successfully.
- Move
-
(Mv) Similar to
move,
but moves the messages to a file named after the local part
of the sender address of the first message.
- newmail
-
Checks for new mail in the current folder
without committing any changes before.
If new mail is present, a message is printed.
If the
header
variable is set,
the headers of each new message are also printed.
- next
-
(n) like + or CR) Goes to the next message
in sequence and types it.
With an argument list, types the next matching message.
- New
-
Same as
unread.
- new
-
Same as
unread.
- online
-
Same as
connect.
- noop
-
If the current folder is located on an IMAP or POP3 server,
a NOOP command is sent.
Otherwise, no operation is performed.
- Pipe
-
(Pi) Like
pipe
but also
pipes ignored header fields
and all parts of MIME
multipart/alternative
messages.
- pipe
-
(pi) Takes a message list and a shell command
and pipes the messages through the command.
Without an argument,
the current message is piped
through the command given by the cmd variable.
If the page variable is set,
every message is followed by a formfeed character.
- preserve
-
(pre) A synonym for
hold.
- Print
-
(P) Like
print
but also
prints out ignored header fields
and all parts of MIME
multipart/alternative
messages.
See also
print,
ignore,
and
retain.
- print
-
(p) Takes a message list and types out each message
on the user's terminal.
If the message is a MIME multipart message,
all parts with a content type of `text' or `message' are shown,
the other are hidden except for their headers.
Messages are decrypted and converted to the terminal character set
if necessary.
- probability
-
(prob) For each word given as argument,
the contents of its junk mail database entry are printed.
- quit
-
(q) Terminates the session, saving all undeleted,
unsaved messages in the user's mbox file in his login directory,
preserving all messages marked with hold or preserve
or never referenced in his system mailbox,
and removing all other messages from his system mailbox.
If new mail has arrived during the session,
the message `You have new mail' is given.
If given while editing a mailbox file with the -f flag,
then the edit file is rewritten.
A return to the Shell is effected,
unless the rewrite of edit file fails,
in which case the user can escape
with the exit command.
- redirect
-
(red) Same as
resend.
- Redirect
-
(Red) Same as
Resend.
- remove
-
(rem) Removes the named folders.
The user is asked for confirmation
in interactive mode.
- rename
-
(ren) Takes the name of an existing folder
and the name for the new folder
and renames the first to the second one.
Both folders must be of the same type
and must be located on the current server for IMAP.
- Reply
-
(R) Reply to originator.
Does not reply to other recipients
of the original message.
- reply
-
(r) Takes a message list and sends mail
to the sender and all recipients of the specified message.
The default message must not be deleted.
- replyall
-
Similar to
reply,
but responds to all recipients regardless of the
flipr
and
Replyall
variables.
- replysender
-
Similar to
Reply,
but responds to the sender only regardless of the
flipr
and
Replyall
variables.
- Resend
-
Like
resend,
but does not add any header lines.
This is not a way to hide the sender's identity,
but useful for sending a message again
to the same recipients.
- resend
-
Takes a list of messages and a user name
and sends each message to the named user.
`Resent-From:' and related header fields are prepended
to the new copy of the message.
- Respond
-
Same as
Reply.
- respond
-
Same as
reply.
- respondall
-
Same as
replyall.
- respondsender
-
Same as
replysender.
- retain
-
Add the list of header fields named to the retained list.
Only the header fields in the retain list are shown
on the terminal when a message is printed.
All other header fields are suppressed.
The Type and Print commands can be used
to print a message in its entirety.
If retain is executed with no arguments,
it lists the current set of retained fields.
- Save
-
(S)
Similar to
save,
but saves the messages
in a file named after the local part
of the sender of the first message
instead of taking a filename argument.
- save
-
(s) Takes a message list and a filename
and appends each message
in turn to the end of the file.
If no filename is given,
the mbox file is used.
The filename in quotes,
followed by the line count and character count
is echoed on the user's terminal.
If editing a system mailbox,
the messages are marked for deletion.
Compressed files and IMAP mailboxes are handled as described for the
-f
command line option above.
- savediscard
-
Same as saveignore.
- saveignore
-
Saveignore is to save what ignore is to print and type.
Header fields thus marked are filtered out
when saving a message by save
or when automatically saving to mbox.
This command should only be applied to header fields
that do not contain information needed to decode the message,
as MIME content fields do.
If saving messages on an IMAP account,
ignoring fields makes it impossible
to copy the data directly on the server,
thus operation usually becomes much slower.
- saveretain
-
Saveretain is to save what retain is to print and type.
Header fields thus marked are the only ones
saved with a message when saving by save
or when automatically saving to mbox.
Saveretain overrides saveignore.
The use of this command is strongly discouraged
since it may strip header fields
that are needed to decode the message correctly.
- score
-
(sc) Takes a message list and a floating point number
and adds the number to the score of each given message.
All messages start at score 0 when a folder is opened.
When the score of a message becomes negative, it is `killed'
with the effects described for the
kill
command;
otherwise if it was negative before and becomes positive,
it is `unkilled'.
Scores only refer to the currently opened instance of a folder.
- set
-
(se) With no arguments, prints all variable values,
piped through the pager if the output does not fit on the screen.
Otherwise, sets option.
Arguments are of the form option=value
(no space before or after =)
or option.
Quotation marks may be placed around any part of the
assignment statement to quote blanks
or tabs, i.e. `set indentprefix="->"'.
If an argument begins with
no,
as in `set nosave',
the effect is the same as invoking the
unset
command with the remaining part of the variable
(`unset save').
- seen
-
Takes a message list and marks all messages as having been read.
- shell
-
(sh) Invokes an interactive version of the shell.
- shortcut
-
Defines a shortcut name and its string for expansion,
as described for the
folder
command.
With no arguments,
a list of defined shortcuts is printed.
- show
-
(Sh) Like
print,
but performs neither MIME decoding nor decryption
so that the raw message text is shown.
- size
-
Takes a message list and prints out
the size in characters of each message.
- sort
-
Create a sorted representation of the current folder,
and change the
next
command and the addressing modes
such that they refer to messages in the sorted order.
Message numbers are the same as in regular mode.
If the
header
variable is set,
a header summary in the new order is also printed.
Possible sorting criteria are:
-
- date
-
Sort the messages by their `Date:' field,
that is by the time they were sent.
- from
-
Sort messages by the value of their `From:' field,
that is by the address of the sender.
If the
showname
variable is set,
the sender's real name (if any) is used.
- size
-
Sort the messages by their size.
- score
-
Sort the messages by their score.
- status
-
Sort the messages by their message status
(new, read, old, etc.).
- subject
-
Sort the messages by their subject.
- thread
-
Create a threaded order,
as with the
thread
command.
- to
-
Sort messages by the value of their `To:' field,
that is by the address of the recipient.
If the
showname
variable is set,
the recipient's real name (if any) is used.
-
If no argument is given,
the current sorting criterion is printed.
- source
-
The source command reads commands from a file.
- thread
-
(th) Create a threaded representation of the current folder,
i.e. indent messages that are replies to other messages
in the header display,
and change the
next
command and the addressing modes
such that they refer to messages in the threaded order.
Message numbers are the same as in unthreaded mode.
If the
header
variable is set,
a header summary in threaded order is also printed.
- top
-
Takes a message list and prints the top few lines of each.
The number of lines printed is controlled
by the variable toplines
and defaults to five.
- touch
-
Takes a message list
and marks the messages for saving in the
mbox
file.
mailx
deviates from the POSIX standard with this command,
as a `next' command issued after `mbox'
will display the following message,
not the current one.
- Type
-
(T) Identical to the Print command.
- type
-
(t) A synonym for print.
- unalias
-
Takes a list of names defined by alias commands
and discards the remembered groups of users.
The group names no longer have any significance.
- unanswered
-
Takes a message list and marks each message
as not having been answered.
- uncollapse
-
(unc)
Only applicable to threaded mode.
Takes a message list
and makes the message and all replies to it visible
in header summaries again.
When a message becomes the current message,
it is automatically made visible.
Also when a message with collapsed replies is printed,
all of these are automatically uncollapsed.
- undef
-
Undefines each of the named macros.
It is not an error to use a name that does not belong to
one of the currently defined macros.
- undelete
-
(u) Takes a message list and marks each message as not being deleted.
- undraft
-
Takes a message list and marks each message
as a draft.
- unflag
-
Takes a message list and marks each message as not being `flagged'.
- unfwdignore
-
Removes the header field names
from the list of ignored fields for the
forward
command.
- unfwdretain
-
Removes the header field names
from the list of retained fields for the
forward
command.
- ungood
-
Takes a message list and undoes the effect of a
good
command that was previously applied on exactly these messages.
- unignore
-
Removes the header field names
from the list of ignored fields.
- unjunk
-
Takes a message list and undoes the effect of a
junk
command that was previously applied on exactly these messages.
- unkill
-
Takes a message list and `unkills' each message.
Also sets the score of the messages to 0.
- Unread
-
Same as
unread.
- unread
-
(U) Takes a message list and marks each message
as not having been read.
- unretain
-
Removes the header field names
from the list of retained fields.
- unsaveignore
-
Removes the header field names
from the list of ignored fields for saving.
- unsaveretain
-
Removes the header field names
from the list of retained fields for saving.
- unset
-
Takes a list of option names and discards their remembered
values;
the inverse of set.
- unshortcut
-
Deletes the shortcut names given as arguments.
- unsort
-
Disable sorted or threaded mode (see the
sort
and
thread
commands), return to normal message order
and,
if the
header
variable is set,
print a header summary.
- unthread
-
(unth) Same as
unsort.
- verify
-
(verif)
Takes a message list and verifies each message.
If a message is not an S/MIME signed message,
verification will fail for it.
The verification process checks
if the message was signed using a valid certificate,
if the message sender's email address matches
one of those contained within the certificate,
and if the message content has been altered.
- visual
-
(v) Takes a message list and invokes the display editor
on each message.
Modified contents are discarded
unless the
writebackedited
variable is set.
- write
-
(w) For conventional messages,
the body without all headers is written.
The output is decrypted and converted
to its native format, if necessary.
If the output file exists,
the text is appended.---If a message is in MIME multipart format,
its first part is written to the specified file
as for conventional messages,
and the user is asked for a filename
to save each other part;
if the contents of the first part are not to be saved,
`write /dev/null' can be used.
For the second and subsequent parts,
if the filename given starts with a `|' character,
the part is piped through the remainder of the filename
interpreted as a shell command.
In non-interactive mode, only the parts of the multipart message
that have a filename given in the part header are written,
the other are discarded.
The original message is never marked for deletion
in the originating mail folder.
For attachments,
the contents of the destination file are overwritten
if the file previously existed.
No special handling of compressed files is performed.
- xit
-
(x) A synonym for exit.
- z
-
Mailx presents message headers in windowfuls
as described under the headers command.
The z command scrolls to the next window of messages.
If an argument is given,
it specifies the window to use.
A number prefixed by `+' or `-' indicates
that the window is calculated in relation
to the current position.
A number without a prefix specifies an
absolute window number,
and a `$' lets mailx scroll
to the last window of messages.
- Z
-
Similar to
z,
but scrolls to the next or previous window
that contains at least one new or `flagged' message.
Tilde escapes
Here is a summary of the tilde escapes,
which are used when composing
messages to perform special functions.
Tilde escapes are only recognized
at the beginning of lines.
The name `tilde escape' is somewhat of a misnomer
since the actual escape character can be set
by the option escape.
- ~!command
-
Execute the indicated shell command,
then return to the message.
- ~.
-
Same effect as typing the end-of-file character.
- ~<filename
-
Identical to ~r.
- ~<!command
-
Command is executed using the shell.
Its standard output is inserted into the message.
- ~@ [filename . . . ]
-
With no arguments, edit the attachment list.
First, the user can edit all existing attachment data.
If an attachment's file name is left empty,
that attachment is deleted from the list.
When the end of the attachment list is reached,
mailx
will ask for further attachments,
until an empty file name is given.
If filename arguments are specified,
all of them are appended to the end of the attachment list.
Filenames which contain white space
can only be specified
with the first method (no filename arguments).
- ~A
-
Inserts the string contained in the
Sign
variable
(same as `~i Sign').
The escape sequences `\t' (tabulator) and `\n' (newline)
are understood.
- ~a
-
Inserts the string contained in the
sign
variable
(same as `~i sign').
The escape sequences `\t' (tabulator) and `\n' (newline)
are understood.
- ~bname . . .
-
Add the given names to the list of carbon copy recipients
but do not make the names visible in the Cc: line
(`blind' carbon copy).
- ~cname . . .
-
Add the given names to the list of carbon copy recipients.
- ~d
-
Read the file `dead.letter' from the user's home directory
into the message.
- ~e
-
Invoke the text editor on the message collected so far.
After the editing session is finished,
the user may continue appending text
to the message.
- ~fmessages
-
Read the named messages into the message being sent.
If no messages are specified,
read in the current message.
Message headers currently being ignored
(by the ignore or retain command)
are not included.
For MIME multipart messages,
only the first printable part is included.
- ~Fmessages
-
Identical to ~f, except all message headers and
all MIME parts are included.
- ~h
-
Edit the message header fields
`To:', `Cc:', `Bcc:', and `Subject:'
by typing each one in turn
and allowing the user to append text
to the end or modify the field
by using the current terminal erase and kill characters.
- ~H
-
Edit the message header fields
`From:', `Reply-To:', `Sender:', and `Organization:'
in the same manner as described for
~h.
The default values for these fields originate from the
from,
replyto,
and
ORGANIZATION
variables.
If this tilde command has been used,
changing the variables has no effect on the current message anymore.
- ~ivariable
-
Insert the value of the specified variable
into the message adding a newline character at the end.
If the variable is unset or empty,
the message remains unaltered.
The escape sequences `\t' (tabulator) and `\n' (newline)
are understood.
- ~mmessages
-
Read the named messages into the message being sent,
indented by a tab or by the value of indentprefix.
If no messages are specified,
read the current message.
Message headers currently being ignored
(by the ignore or retain command)
are not included.
For MIME multipart messages,
only the first printable part is included.
- ~Mmessages
-
Identical to ~m, except all message headers and
all MIME parts are included.
- ~p
-
Print out the message collected so far,
prefaced by the message header fields
and followed by the attachment list, if any.
If the message text is longer than the screen size,
it is piped through the pager.
- ~q
-
Abort the message being sent,
copying the message to
`dead.letter' in the user's home directory
if save is set.
- ~rfilename
-
Read the named file into the message.
- ~sstring
-
Cause the named string to become the current subject field.
- ~tname . . .
-
Add the given names to the direct recipient list.
- ~v
-
Invoke an alternate editor
(defined by the VISUAL option)
on the message collected so far.
Usually, the alternate editor
will be a screen editor.
After the editor is quit,
the user may resume appending text
to the end of the message.
- ~wfilename
-
Write the message onto the named file.
If the file exists,
the message is appended to it.
- ~x
-
Same as ~q,
except that the message is not saved to the `dead.letter' file.
- ~|command
-
Pipe the message through the command as a filter.
If the command gives no output or terminates abnormally,
retain the original text of the message.
The command
fmt(1)
is often used
as command to rejustify the message.
- ~:mailx-command
-
Execute the given mailx command.
Not all commands, however, are allowed.
- ~_mailx-command
-
Identical to ~:.
- ~~string
-
Insert the string of text in the message
prefaced by a single ~.
If the escape character has been changed,
that character must be doubled
in order to send it at the beginning of a line.
Variable options
Options are controlled via set and unset commands,
see their entries for a syntax description.
An option is also set
if it is passed to mailx
as part of the environment
(this is not restricted to specific variables as in the POSIX standard).
A value given in a startup file overrides
a value imported from the environment, but it is not possible to unset
an environment variable in a startup file.
Options may be either binary,
in which case it is only significant
to see whether they are set or not;
or string, in which case the actual value is of interest.
Binary options
The binary options include the following:
- allnet
-
Causes only the local part to be evaluated
when comparing addresses.
- append
-
Causes messages saved in mbox to be appended to the end
rather than prepended.
This should always be set.
- ask or asksub
-
Causes mailx to prompt for the subject
of each message sent.
If the user responds with simply a newline,
no subject field will be sent.
- askatend
-
Causes the prompts for `Cc:' and `Bcc:' lists
to appear after the message has been edited.
- askattach
-
If set, mailx asks for files to attach at the end of each message.
Responding with a newline indicates not to include an attachment.
- askcc
-
Causes the user to be prompted
for additional carbon copy recipients
(at the end of each message if
askatend
or
bsdcompat
is set).
Responding with a newline
indicates the user's satisfaction with the current list.
- askbcc
-
Causes the user to be prompted
for additional blind carbon copy recipients
(at the end of each message if
askatend
or
bsdcompat
is set).
Responding with a newline
indicates the user's satisfaction with the current list.
- asksign
-
Causes the user to be prompted
if the message is to be signed
at the end of each message.
The
smime-sign
variable is ignored when this variable is set.
- autocollapse
-
Causes threads to be collapsed automatically when
threaded mode is entered
(see the
collapse
command).
- autoinc
-
Same as
newmail.
- autoprint
-
Causes the delete command to behave like dp -
thus, after deleting a message,
the next one will be typed automatically.
- autothread
-
Causes threaded mode (see the
thread
command) to be entered automatically
when a folder is opened.
- bang
-
Enables the substitution of `!'
by the contents of the last command line
in shell escapes.
- bsdannounce
-
Causes automatic display of a header summary after executing a
folder
command.
- bsdcompat
-
Sets some cosmetical features to traditional BSD style;
has the same affect as setting `askatend' and
all other variables prefixed with `bsd',
setting prompt to `& ', and changing the default pager to
more.
- bsdflags
-
Changes the letters printed in the first column of a header summary
to traditional BSD style.
- bsdheadline
-
Changes the display of columns in a header summary
to traditional BSD style.
- bsdmsgs
-
Changes some informational messages
to traditional BSD style.
- bsdorder
-
Causes the `Subject:' field to appear
immediately after the `To:' field
in message headers and with the
~h
tilde command.
- bsdset
-
Changes the output format of the
set
command to traditional BSD style.
- chained-junk-tokens
-
Normally, the Bayesian junk mail filter bases its classifications
on single word tokens extracted from messages.
If this option is set,
adjacent words are combined to pairs,
which are then used as additional tokens.
This usually improves the accuracy of the filter,
but also increases the junk mail database
five- to tenfold.
- datefield
-
The date in a header summary
is normally the date of the mailbox `From ' line of the message.
If this variable is set,
the date as given in the `Date:' header field is used,
converted to local time.
- debug
-
Prints debugging messages and disables the actual delivery of messages.
Unlike
verbose,
this option is intended for
mailx
development only.
- disconnected
-
When an IMAP mailbox is selected and this variable is set,
no connection to the server is initiated.
Instead, data is obtained from the local cache (see
imap-cache).
Mailboxes that are not present in the cache
and messages that have not yet entirely been fetched from the server
are not available;
to fetch all messages in a mailbox at once,
the command `copy * /dev/null' can be used
while still in
online
mode.
Changes that are made to IMAP mailboxes in disconnected mode
are queued and committed later
when a connection to that server is opened in online mode.
This procedure is not completely reliable
since it cannot be guaranteed that the IMAP unique identifiers (UIDs)
on the server still match the ones in the cache at that time.
Data is saved to `dead.letter' when this problem occurs.
- disconnected-user@host
-
The specified account is handled as described for the
disconnected
variable above,
but other accounts are not affected.
- dot
-
The binary option dot causes mailx to interpret
a period alone on a line
as the terminator of a message the user is sending.
- editheaders
-
When a message is edited while being composed,
its header is included in the editable text.
`To:', `Cc:', `Bcc:', `Subject:', `From:', `Reply-To:', `Sender:',
and 'Organization:'
fields are accepted within the header,
other fields are ignored.
- emptybox
-
If set, an empty mailbox file is not removed.
This may improve the interoperability with other mail user agents
when using a common folder directory.
- emptystart
-
If the mailbox is empty,
mailx normally prints `No mail for user'
and exits immediately.
If this option is set,
mailx starts even with an empty mailbox.
- expandaddr
-
Causes
mailx
to expand message recipient addresses, as explained in the section,
Recipient address specifications.
- flipr
-
Exchanges the
Respond
with the
respond
commands and vice-versa.
- forward-as-attachment
-
Original messages are normally sent as inline text with the
forward
command,
and only the first part of a multipart message is included.
With this option,
messages are sent as MIME
message/rfc822
attachments,
and all of their parts are included.
The
fwdignore
and
fwdretain
options are ignored when the
forward-as-attachment
option is set.
- fullnames
-
When replying to a message,
mailx normally removes the comment parts of email addresses,
which by convention contain the full names of the recipients.
If this variable is set,
such stripping is not performed,
and comments are retained.
- header
-
Causes the header summary to be written at startup
and after commands that affect the number of messages
or the order of messages in the current folder;
enabled by default.
- hold
-
This option is used to hold messages
in the system mailbox by default.
- ignore
-
Causes interrupt signals from the terminal
to be ignored and echoed as @'s.
- ignoreeof
-
An option related to dot is ignoreeof
which makes mailx refuse to
accept a control-d as the end of a message.
Ignoreeof also applies to mailx command mode.
- imap-use-starttls
-
Causes
mailx
to issue a STARTTLS command
to make an unencrypted IMAP session SSL/TLS encrypted.
This functionality is not supported by all servers,
and is not used if the session is already encrypted by the IMAPS method.
- imap-use-starttls-user@host
-
Activates
imap-use-starttls
for a specific account.
- keep
-
This option causes mailx to truncate the user's system mailbox
instead of deleting it when it is empty.
This should always be set,
since it prevents malicious users
from creating fake mail folders
in a world-writable spool directory.
- keepsave
-
When a message is saved,
it is usually discarded
from the originating folder
when
mailx
is quit.
Setting this option
causes all saved message to be retained.
- markanswered
-
When a message is replied to
and this variable is set,
it is marked as having been answered.
This mark has no technical meaning in the mail system;
it just causes messages to be marked in the header summary,
and makes them specially addressable.
- metoo
-
Usually, when a group is expanded
that contains the sender,
the sender is removed from the expansion.
Setting this option causes
the sender to be included in the group.
- newmail
-
Checks for new mail in the current folder
each time the prompt is printed.
For IMAP mailboxes,
the server is then polled for new mail,
which may result in delayed operation
if the connection to the server is slow.
A
maildir
folder must be re-scanned to determine
if new mail has arrived.
-
If this variable is set to the special value
nopoll,
an IMAP server is not actively asked for new mail,
but new mail may still be detected and announced
with any other IMAP command that is sent to the server.
A
maildir
folder is not scanned then.
-
In any case,
the IMAP server may send notifications about messages
that have been deleted on the server
by another process or client.
In this case, `Expunged n messages' is printed
regardless of this variable,
and message numbers may have changed.
- noheader
-
Setting the option noheader is the same
as giving the -N flag on the command line.
- outfolder
-
Causes the filename given in the
record
variable
and the sender-based filenames for the
Copy
and
Save
commands
to be interpreted relative to the directory given in the
folder
variable rather than to the current directory
unless it is an absolute pathname.
- page
-
If set, each message the pipe command prints out
is followed by a formfeed character.
- piperaw
-
Send messages to the
pipe
command without performing MIME and character set conversions.
- pop3-use-apop
-
If this variable is set,
the APOP authentication method is used
when a connection to a POP3 server is initiated.
The advantage of this method over the usual USER/PASS authentication is
that the password is not sent over the network in clear text.
The connection fails
if the server does not support the APOP command.
- pop3-use-apop-user@host
-
Enables
pop3-use-apop
for a specific account.
- pop3-use-starttls
-
Causes
mailx
to issue a STLS command
to make an unencrypted POP3 session SSL/TLS encrypted.
This functionality is not supported by all servers,
and is not used if the session is already encrypted by the POP3S method.
- pop3-use-starttls-user@host
-
Activates
pop3-use-starttls
for a specific account.
- print-all-chars
-
This option causes all characters to be considered printable.
It is only effective if given in a startup file.
With this option set,
some character sequences in messages
may put the user's terminal in an undefined state
when printed;
it should only be used as a last resort
if no working system locale can be found.
- print-alternatives
-
When a MIME message part of type
multipart/alternative
is displayed and it contains a subpart of type
text/plain,
other parts are normally discarded.
Setting this variable causes all subparts to be displayed,
just as if the surrounding part was of type
multipart/mixed.
- quiet
-
Suppresses the printing of the version when first invoked.
- record-resent
-
If both this variable and the
record
variable are set,
the
resend
and
Resend
commands save messages to the
record
folder as it is normally only done for newly composed messages.
- reply-in-same-charset
-
If this variable is set,
mailx
first tries to use the same character set
of the original message for replies.
If this fails,
the
sendcharsets
variable is evaluated as usual.
- Replyall
-
Reverses the sense of reply and Reply commands.
- save
-
When the user aborts a message
with two RUBOUT (interrupt characters)
mailx copies the partial letter
to the file `dead.letter' in the home directory.
This option is set by default.
- searchheaders
-
If this option is set, then
a message-list specifier in the form `/x:y'
will expand to all messages containing
the substring `y' in the header field `x'.
The string search is case insensitive.
- sendwait
-
When sending a message,
wait until the mail transfer agent exits
before accepting further commands.
If the mail transfer agent returns a non-zero exit status,
the exit status of mailx will also be non-zero.
- showlast
-
Setting this option causes mailx to start at the
last message instead of the first one when opening a mail folder.
- showname
-
Causes
mailx
to use the sender's real name instead of the plain address
in the header field summary and in message specifications.
- showto
-
Causes the recipient of the message to be shown in the header summary
if the message was sent by the user.
- skipemptybody
-
If an outgoing message does not contain any text
in its first or only message part,
do not send it but discard it silently
(see also the
-E
option).
- smime-force-encryption
-
Causes
mailx
to refuse sending unencrypted messages.
- smime-sign
-
If this variable is set,
outgoing messages are S/MIME signed with the user's private key.
Signing a message enables a recipient to verify
that the sender used a valid certificate,
that the email addresses in the certificate
match those in the message header,
and that the message content has not been altered.
It does not change the message text,
and people will be able to read the message as usual.
- smime-no-default-ca
-
Do not load the default CA locations
when verifying S/MIME signed messages.
Only applicable if S/MIME support is built using OpenSSL.
- smtp-use-starttls
-
Causes mailx to issue a STARTTLS command
to make an SMTP session SSL/TLS encrypted.
Not all servers support this command;
because of common implementation defects,
it cannot be automatically determined
whether a server supports it or not.
- ssl-no-default-ca
-
Do not load the default CA locations
to verify SSL/TLS server certificates.
Only applicable if SSL/TLS support is built using OpenSSL.
- ssl-v2-allow
-
Accept SSLv2 connections.
These are normally not allowed
because this protocol version is insecure.
- stealthmua
-
Inhibits the generation of
the `Message-Id:' and `User-Agent:'
header fields that include obvious references to mailx.
There are two pitfalls associated with this:
First, the message id of outgoing messages is not known anymore.
Second, an expert may still use the remaining information in the header
to track down the originating mail user agent.
- verbose
-
Setting the option verbose is the same
as using the -v flag on the command line.
When mailx runs in verbose mode,
details of the actual message delivery
and protocol conversations for IMAP, POP3, and SMTP,
as well as of other internal processes,
are displayed on the user's terminal,
This is sometimes useful to debug problems.
Mailx
prints all data that is sent to remote servers in clear texts,
including passwords,
so care should be taken that no unauthorized option
can view the screen if this option is enabled.
- writebackedited
-
If this variable is set,
messages modified using the
edit
or
visual
commands are written back to the current folder when it is quit.
This is only possible for writable folders in
mbox
format.
Setting this variable also disables
MIME decoding and decryption for the editing commands.
String Options
The string options include the following:
- attrlist
-
A sequence of characters to print in the `attribute'
column of a header summary,
each for one type of messages in the following order:
new,
unread but old,
new but read,
read and old,
saved,
preserved,
mboxed,
flagged,
answered,
draft,
killed,
start of a collapsed thread,
collapsed,
classified as junk.
The default is `NUROSPMFATK+-J',
or `NU *HMFATK+-J' if
bsdflags
or the
SYSV3
environment variable
are set.
- autobcc
-
Specifies a list of recipients to which
a blind carbon copy of each outgoing message
will be sent automatically.
- autocc
-
Specifies a list of recipients to which
a carbon copy of each outgoing message
will be sent automatically.
- autosort
-
Causes sorted mode (see the
sort
command) to be entered automatically
with the value of this option as sorting method
when a folder is opened.
- cmd
-
The default value for the pipe command.
- crt
-
The valued option crt is used as a threshold
to determine how long a message must be
before PAGER is used to read it.
If crt is set without a value,
then the height of the terminal screen stored in the system
is used to compute the threshold (see
stty(1)).
- DEAD
-
The name of the file to use
for saving aborted messages.
This defaults to `dead.letter'
in the user's home directory.
- EDITOR
-
Pathname of the text editor to use
in the edit command and ~e escape.
If not defined,
then a default editor is used.
- encoding
-
The default MIME encoding to use
in outgoing text messages and message parts.
Valid values are 8bit or quoted-printable.
The default is 8bit.
In case the mail transfer system
is not ESMTP compliant,
quoted-printable should be used instead.
If there is no need to encode a message,
7bit transfer mode is used,
without regard to the value of this variable.
Binary data is always encoded in base64 mode.
- escape
-
If defined, the first character of this option
gives the character to use in the place of ~ to denote escapes.
- folder
-
The name of the directory to use
for storing folders of messages.
All folder names that begin with `+'
refer to files below that directory.
If the directory name begins with a `/',
mailx considers it to be an absolute pathname;
otherwise, the folder directory is found
relative to the user's home directory.
-
The directory name may also refer to an IMAP account;
any names that begin with `+'
then refer to IMAP mailboxes on that account.
An IMAP folder is normally given in the form
imaps://mylogin@imap.myisp.example
In this case,
the `+' and `@' prefixes for folder names
have the same effect
(see the
folder
command).
-
Some IMAP servers do not accept the creation of mailboxes
in the hierarchy base;
they require that they are created as subfolders of `INBOX'.
With such servers,
a folder name of the form
imaps://mylogin@imap.myisp.example/INBOX.
should be used
(the last character is the server's hierarchy delimiter).
Folder names prefixed by `+' will then refer to folders below `INBOX',
while folder names prefixed by `@'
refer to folders below the hierarchy base.
See the
imap namespace
command for a method to detect the appropriate prefix and delimiter.
- folder-hook
-
When a folder is opened and this variable is set,
the macro corresponding to the value of this variable is executed.
The macro is also invoked when new mail arrives,
but message lists for commands executed from the macro
only include newly arrived messages then.
- folder-hook-fullname
-
When a folder named
fullname
is opened,
the macro corresponding to the value of this variable is executed.
Unlike other folder specifications,
the fully expanded name of a folder, without metacharacters,
is used to avoid ambiguities.
The macro specified with
folder-hook
is not executed if this variable is effective for a folder
(unless it is explicitly invoked within the called macro).
- from
-
The address (or a list of addresses)
to put into the `From:' field of the message header.
If replying to a message,
these addresses are handled as if they were in the alternates list.
If the machine's hostname is not valid at the Internet
(for example at a dialup machine),
either this variable or
hostname
have to be set
to get correct Message-ID header fields.
If
from
contains more than one address,
the
sender
variable must also be set.
- fwdheading
-
The string to print before the text of a message
with the
forward
command
(unless the
forward-as-attachment
variable is set).
Defaults to ``-------- Original Message --------'' if unset.
If it is set to the empty string,
no heading is printed.
- headline
-
A format string to use for the header summary,
similar to
printf
formats.
A `%' character introduces a format specifier.
It may be followed by a number indicating the field width.
If the field is a number,
the width may be negative,
which indicates that it is to be left-aligned.
Valid format specifiers are:
%a | Message attributes.
|
%c | The score of the message.
|
%d | The date when the message was received.
|
%e | The indenting level in threaded mode.
|
%f | The address of the message sender.
|
%i | The message thread structure.
|
%l | The number of lines of the message.
|
%m | Message number.
|
%o | The number of octets (bytes) in the message.
|
%s | Message subject (if any).
|
%S | Message subject (if any) in double quotes.
|
%t | The position in threaded/sorted order.
|
%> | A `>' for the current message, otherwise ` '.
|
%< | A `<' for the current message, otherwise ` '.
|
%% | A `%' character.
|
-
The default is `%>%a%m %18f %16d %4l/%-5o %i%s',
or `%>%a%m %20f %16d %3l/%-5o %i%S' if
bsdcompat
is set.
- hostname
-
Use this string as hostname
when expanding local addresses
instead of the value obtained from
uname(2)
and
getaddrinfo(3).
- imap-auth
-
Sets the IMAP authentication method.
Valid values are `login' for the usual password-based authentication
(the default),
`cram-md5', which is a password-based authentication
that does not send the password over the network in clear text,
and `gssapi' for GSSAPI-based authentication.
- imap-auth-user@host
-
Sets the IMAP authentication method for a specific account.
- imap-cache
-
Enables caching of IMAP mailboxes.
The value of this variable must point to a directory
that is either existent or can be created by
mailx.
All contents of the cache can be deleted by
mailx
at any time;
it is not safe to make assumptions about them.
- imap-keepalive
-
IMAP servers may close the connection
after a period of inactivity;
the standard requires this to be at least 30 minutes,
but practical experience may vary.
Setting this variable to a numeric
value
greater than 0
causes a NOOP command to be sent each
value
seconds if no other operation is performed.
- imap-list-depth
-
When retrieving the list of folders on an IMAP server, the
folders
command stops after it has reached a certain depth
to avoid possible infinite loops.
The value of this variable sets the maximum depth allowed.
The default is 2.
If the folder separator on the current IMAP server is a slash `/',
this variable has no effect,
and the
folders
command does not descend to subfolders.
- indentprefix
-
String used by the `~m' and `~M' tilde escapes
and by the quote option
for indenting messages,
in place of the normal tab character (^I).
Be sure to quote the value
if it contains spaces or tabs.
- junkdb
-
The location of the junk mail database.
The string is treated like a folder name,
as described for the
folder
command.
-
The files in the junk mail database are normally stored in
compress(1)
format for saving space.
If processing time is considered more important,
uncompress(1)
can be used to store them in plain form.
Mailx
will then work using the uncompressed files.
- LISTER
-
Pathname of the directory lister
to use in the
folders
command
when operating on local mailboxes.
Default is /bin/ls.
- MAIL
-
Is used as the user's mailbox, if set.
Otherwise, a system-dependent default is used.
Can be a
protocol://
string (see the
folder
command for more information).
- MAILX_HEAD
-
A string to put at the beginning of each new message.
The escape sequences `\t' (tabulator) and `\n' (newline)
are understood.
- MAILX_TAIL
-
A string to put at the end of each new message.
The escape sequences `\t' (tabulator) and `\n' (newline)
are understood.
- maximum-unencoded-line-length
-
Messages that contain lines longer than the value of this variable
are encoded in quoted-printable
even if they contain only ASCII characters.
The maximum effective value is 950.
If set to 0,
all ASCII text messages are encoded in quoted-printable.
S/MIME signed messages are always encoded
in quoted-printable regardless of the value of this variable.
- MBOX
-
The name of the mbox file.
It can be the name of a folder.
The default is `mbox'
in the user's home directory.
- NAIL_EXTRA_RC
-
The name of an optional startup file
to be read after ~/.mailrc.
This variable is ignored if it is imported from the environment;
it has an effect only if it is set in /etc/mail.rc or ~/.mailrc
to allow bypassing the configuration with e. g. `MAILRC=/dev/null'.
Use this file for commands
that are not understood by other mailx implementations.
- newfolders
-
If this variable has the value
maildir,
newly created local folders will be in
maildir
format.
- nss-config-dir
-
A directory that contains the files
certN.db
to retrieve certificates,
keyN.db
to retrieve private keys,
and secmod.db,
where
N
is a digit.
These are usually taken from Mozilla installations,
so an appropriate value might be
`~/.mozilla/firefox/default.clm'.
Mailx
opens these files read-only
and does not modify them.
However, if the files are modified by Mozilla
while
mailx
is running,
it will print a `Bad database' message.
It may be necessary to create copies of these files
that are exclusively used by
mailx
then.
Only applicable if S/MIME and SSL/TLS support is built using
Network Security Services (NSS).
- ORGANIZATION
-
The value to put into the `Organization:' field of the message header.
- PAGER
-
Pathname of the program to use
in the more command
or when crt variable is set.
The default paginator
pg(1)
or, in BSD compatibility mode,
more(1)
is used
if this option is not defined.
- password-user@host
-
Set the password for
user
when connecting to
host.
If no such variable is defined for a host,
the user will be asked for a password on standard input.
Specifying passwords in a startup file
is generally a security risk,
the file should be readable
by the invoking user only.
- pipe-content/subcontent
-
When a MIME message part of
content/subcontent
type is displayed or it is replied to,
its text is filtered through the value of this variable
interpreted as a shell command.
Special care must be taken when using such commands
as mail viruses may be distributed by this method;
if messages of type
application/x-sh
were filtered through the shell, for example,
a message sender could easily execute arbitrary code
on the system
mailx
is running on.
- pop3-keepalive
-
POP3 servers may close the connection
after a period of inactivity;
the standard requires this to be at least 10 minutes,
but practical experience may vary.
Setting this variable to a numeric
value
greater than 0
causes a NOOP command to be sent each
value
seconds if no other operation is performed.
- prompt
-
The string printed when a command is accepted.
Defaults to `? ',
or to `& ' if the
bsdcompat
variable is set.
- quote
-
If set, mailx starts a replying message with the original message prefixed
by the value of the variable indentprefix.
Normally, a heading consisting of `Fromheaderfield wrote:' is printed
before the quotation.
If the string noheading is assigned to the quote variable,
this heading is omitted.
If the string headers is assigned,
the headers selected by the ignore/retain commands
are printed above the message body,
thus quote acts like an automatic ~m command then.
If the string allheaders is assigned,
all headers are printed above the message body,
and all MIME parts are included,
thus quote acts like an automatic ~M command then.
- record
-
If defined, gives the pathname of the folder
used to record all outgoing mail.
If not defined,
then outgoing mail is not so saved.
When saving to this folder fails,
the message is not sent
but saved to the `dead.letter' file instead.
- replyto
-
A list of addresses to put into the `Reply-To:' field
of the message header.
If replying to a message, such addresses are handled
as if they were in the alternates list.
- screen
-
When mailx initially prints the message headers,
it determines the number to print
by looking at the speed of the terminal.
The faster the terminal, the more it prints.
This option overrides this calculation
and specifies how many message headers
are printed.
This number is also used
for scrolling with the z command.
- sendcharsets
-
A comma-separated list of character set names
that can be used in Internet mail.
When a message that contains characters not representable in US-ASCII
is prepared for sending,
mailx
tries to convert its text
to each of the given character sets in order
and uses the first appropriate one.
The default is `utf-8'.
-
Character sets assigned to this variable should be ordered
in ascending complexity.
That is, the list should start with e.g.
`iso-8859-1' for compatibility with older mail clients,
might contain some other language-specific character sets,
and should end with `utf-8'
to handle messages that combine texts in multiple languages.
- sender
-
An address that is put into the `Sender:' field
of outgoing messages.
This field needs not normally be present.
It is, however, required
if the `From:' field contains more than one address.
It can also be used to indicate that a message
was sent on behalf of somebody other;
in this case, `From:' should contain the address
of the person that took responsibility for the message,
and `Sender:' should contain the address
of the person that actually sent the message.
The
sender
address is handled as if it were in the
alternates
list.
- sendmail
-
To use an alternate mail delivery system,
set this option to the full pathname
of the program to use.
This should be used with care.
- SHELL
-
Pathname of the shell to use
in the ! command and the ~! escape.
A default shell is used
if this option is not defined.
- Sign
-
-
A string for use with the
~A
command.
- sign
-
A string for use with the
~a
command.
- signature
-
Must correspond to the name of a readable file if set.
The file's content is then appended to each singlepart message
and to the first part of each multipart message.
Be warned that there is no possibility
to edit the signature for an individual message.
- smime-ca-dir
-
Specifies a directory with CA certificates for verification
of S/MIME signed messages.
The format is the same as described in
SSL_CTX_load_verify_locations(3).
Only applicable if S/MIME support is built using OpenSSL.
- smime-ca-file
-
Specifies a file with CA certificates for verification
of S/MIME signed messages.
The format is the same as described in
SSL_CTX_load_verify_locations(3).
Only applicable if S/MIME support is built using OpenSSL.
- smime-cipher-user@host
-
Specifies a cipher to use when generating S/MIME encrypted messages
for
user@host.
Valid ciphers are
rc2-40
(RC2 with 40 bits),
rc2-64
(RC2 with 64 bits),
des
(DES, 56 bits)
and
des-ede3
(3DES, 112/168 bits).
The default is 3DES.
It is not recommended to use the other ciphers
unless a recipient's client is actually unable to handle 3DES
since they are comparatively weak;
but even so, the recipient should upgrade his software in preference.
- smime-crl-file
-
Specifies a file that contains a CRL in PEM format
to use when verifying S/MIME messages.
Only applicable if S/MIME support is built using OpenSSL.
- smime-crl-dir
-
Specifies a directory that contains files with CRLs in PEM format
to use when verifying S/MIME messages.
Only applicable if S/MIME support is built using OpenSSL.
- smime-encrypt-user@host
-
If this variable is set,
messages to
user@host
are encrypted before sending.
If S/MIME support is built using OpenSSL,
the value of the variable must be set to the name of a file
that contains a certificate in PEM format.
If S/MIME support is built using NSS,
the value of this variable is ignored,
but if multiple certificates for
user@host
are available, the
smime-nickname-user@host
variable should be set.
Otherwise a certificate for the recipient
is automatically retrieved from the certificate database,
if possible.
-
If a message is sent to multiple recipients,
each of them for whom a corresponding variable is set
will receive an individually encrypted message;
other recipients will continue to receive the message in plain text
unless the
smime-force-encryption
variable is set.
It is recommended to sign encrypted messages,
i.e. to also set the
smime-sign
variable.
- smime-nickname-user@host
-
Specifies the nickname of a certificate
to be used when encrypting messages for
user@host .
Only applicable if S/MIME support is built using NSS.
- smime-sign-cert
-
Points to a file in PEM format
that contains the user's private key
as well as his certificate.
Both are used with S/MIME
for signing and decrypting messages.
Only applicable if S/MIME support is built using OpenSSL.
- smime-sign-cert-user@host
-
Overrides
smime-sign-cert
for the specific addresses.
When signing messages and the value of the
from
variable is set
to
user@host,
the specific file is used.
When decrypting messages,
their recipient fields (To: and Cc:) are searched for addresses
for which such a variable is set.
Mailx
always uses the first address that matches,
so if the same message is sent to more than one
of the user's addresses using different encryption keys,
decryption might fail.
Only applicable if S/MIME support is built using OpenSSL.
- smime-sign-nickname
-
Specifies that the named certificate be used for signing mail.
If this variable is not set,
but a single certificate matching the current
from
address is found in the database,
that one is used automatically.
Only applicable if S/MIME support is built using NSS.
- smime-sign-nickname-user@host
-
Overrides
smime-sign-nickname
for a specific address.
Only applicable if S/MIME support is built using NSS.
- smtp
-
Normally, mailx invokes
sendmail(8)
directly to transfer messages.
If the smtp variable is set, a SMTP connection to
the server specified by the value of this variable
is used instead.
If the SMTP server does not use the standard port,
a value of server:port can be given,
with port as a name or as a number.
-
There are two possible methods to get SSL/TLS encrypted SMTP sessions:
First, the STARTTLS command can be used to encrypt a session
after it has been initiated,
but before any user-related data has been sent; see
smtp-use-starttls
above.
Second, some servers accept sessions that are encrypted
from their beginning on. This mode is configured by assigning
smtps://server[:port]
to the
smtp
variable.
-
The SMTP transfer is executed in a child process;
unless either the
sendwait
or the
verbose
variable is set,
this process runs asynchronously.
If it receives a TERM signal,
it will abort and save the message to the `dead.letter' file.
- smtp-auth
-
Sets the SMTP authentication method.
If set to `login',
or if unset and smtp-auth-user is set,
AUTH LOGIN is used.
If set to `cram-md5',
AUTH CRAM-MD5 is used;
if set to `plain',
AUTH PLAIN is used.
Otherwise,
no SMTP authentication is performed.
- smtp-auth-user@host
-
Overrides
smtp-auth
for specific values of sender addresses,
depending on the
from
variable.
- smtp-auth-password
-
Sets the global password for SMTP AUTH.
Both user and password have to be given
for AUTH LOGIN and AUTH CRAM-MD5.
- smtp-auth-password-user@host
-
Overrides
smtp-auth-password
for specific values of sender addresses,
depending on the
from
variable.
- smtp-auth-user
-
Sets the global user name for SMTP AUTH.
Both user and password have to be given
for AUTH LOGIN and AUTH CRAM-MD5.
-
If this variable is set but neither
smtp-auth-password
or a matching
smtp-auth-password-user@host
can be found,
mailx
will as for a password on the user's terminal.
- smtp-auth-user-user@host
-
Overrides
smtp-auth-user
for specific values of sender addresses,
depending on the
from
variable.
- ssl-ca-dir
-
Specifies a directory with CA certificates for verification
of SSL/TLS server certificates.
See
SSL_CTX_load_verify_locations(3)
for more information.
Only applicable if SSL/TLS support is built using OpenSSL.
- ssl-ca-file
-
Specifies a file with CA certificates for verification
of SSL/TLS server certificates.
See
SSL_CTX_load_verify_locations(3)
for more information.
Only applicable if SSL/TLS support is built using OpenSSL.
- ssl-cert
-
Sets the file name
for a SSL/TLS client certificate
required by some servers.
Only applicable if SSL/TLS support is built using OpenSSL.
- ssl-cert-user@host
-
Sets an account-specific file name
for a SSL/TLS client certificate
required by some servers.
Overrides
ssl-cert
for the specified account.
Only applicable if SSL/TLS support is built using OpenSSL.
- ssl-cipher-list
-
Specifies a list of ciphers for SSL/TLS connections.
See ciphers(1) for more information.
Only applicable if SSL/TLS support is built using OpenSSL.
- ssl-crl-file
-
Specifies a file that contains a CRL in PEM format
to use when verifying SSL/TLS server certificates.
Only applicable if SSL/TLS support is built using OpenSSL.
- ssl-crl-dir
-
Specifies a directory that contains files with CRLs in PEM format
to use when verifying SSL/TLS server certificates.
Only applicable if SSL/TLS support is built using OpenSSL.
- ssl-key
-
Sets the file name
for the private key of a SSL/TLS client certificate.
If unset, the name of the certificate file is used.
The file is expected to be in PEM format.
Only applicable if SSL/TLS support is built using OpenSSL.
- ssl-key-user@host
-
Sets an account-specific file name
for the private key of a SSL/TLS client certificate.
Overrides
ssl-key
for the specified account.
Only applicable if SSL/TLS support is built using OpenSSL.
- ssl-method
-
Selects a SSL/TLS protocol version;
valid values are `ssl2', `ssl3', and `tls1'.
If unset, the method is selected automatically,
if possible.
- ssl-method-user@host
-
Overrides
ssl-method
for a specific account.
- ssl-rand-egd
-
Gives the pathname to an entropy daemon socket,
see
RAND_egd(3).
- ssl-rand-file
-
Gives the pathname to a file with entropy data,
see
RAND_load_file(3).
If the file is a regular file writable by the invoking user,
new data is written to it after it has been loaded.
Only applicable if SSL/TLS support is built using OpenSSL.
- ssl-verify
-
Sets the action to be performed if an error occurs
during SSL/TLS server certificate validation.
Valid values are
`strict' (fail and close connection immediately),
`ask' (ask whether to continue on standard input),
`warn' (print a warning and continue),
`ignore' (do not perform validation).
The default is `ask'.
- ssl-verify-user@host
-
Overrides
ssl-verify
for a specific account.
- toplines
-
If defined, gives the number of lines
of a message to be printed out
with the top command;
normally, the first five
lines are printed.
- ttycharset
-
The character set of the terminal mailx operates on.
There is normally no need to set this variable
since mailx can determine this automatically
by looking at the LC_CTYPE locale setting;
if this succeeds, the value is assigned at startup
and will be displayed by the set command.
Note that this is not necessarily a character set name
that can be used in Internet messages.
- VISUAL
-
Pathname of the text editor to use
in the visual command and ~v escape.
ENVIRONMENT VARIABLES
Besides the variables described above, mailx uses
the following environment strings:
- HOME
-
The user's home directory.
- LANG, LC_ALL, LC_COLLATE, LC_CTYPE, LC_MESSAGES
-
See
locale(7).
- MAILRC
-
Is used as startup file instead of ~/.mailrc if set.
When
mailx
scripts are invoked on behalf of other users,
this variable should be set to `/dev/null'
to avoid side-effects from reading their configuration files.
- NAILRC
-
If this variable is set and
MAILRC
is not set,
it is read as startup file.
- SYSV3
-
Changes the letters printed in the first column of a header summary.
- TMPDIR
-
Used as directory for temporary files instead of /tmp, if set.
FILES
- ~/.mailrc
-
File giving initial commands.
- /etc/mail.rc
-
System wide initialization file.
- ~/.mime.types
-
Personal MIME types.
- /etc/mime.types
-
System wide MIME types.
EXAMPLES
Getting started
The
mailx
command has two distinct usages, according to whether one
wants to send or receive mail.
Sending mail is simple: to send a
message to a user whose email address is, say,
<bill@host.example>,
use the shell
command:
$ mailx bill@host.example
then type your message.
Mailx
will prompt you for a message
subject
first;
after that, lines typed by you form the body of the message.
When you reach the end of the message, type
an EOT (control-d) at the beginning of a line, which will cause
mailx
to echo `EOT' and return you to the shell.
If, while you are composing the message
you decide that you do not wish to send it after all, you can
abort the letter with a RUBOUT. Typing a single RUBOUT
causes
mailx
to print `(Interrupt -- one more to kill letter)'.
Typing a second
RUBOUT causes
mailx
to save your partial letter on the file `dead.letter'
in your home directory and abort the letter.
Once you have
sent mail to someone, there is no way to undo the act, so be
careful.
If you want to send the same message to several other people,
you can list their email addresses on the command line.
Thus,
$ mailx sam@workstation.example bob@server.example
Subject: Fees
Tuition fees are due next Friday. Don't forget!
<Control-d>
EOT
$
will send the reminder to <sam@workstation.example>.
and
<bob@server.example>.
To read your mail, simply type
$ mailx
Mailx
will respond by typing its version number and date and then listing
the messages you have waiting.
Then it will type a prompt and await your command.
The messages are assigned numbers starting with 1---you
refer to the messages with these numbers.
Mailx
keeps track of which messages are
new
(have been sent since you last read your mail) and
read
(have been read by you). New messages have an
N
next to them in the header listing and old, but unread messages have
a
U
next to them.
Mailx
keeps track of new/old and read/unread messages by putting a
header field called
Status
into your messages.
To look at a specific message, use the
type
command, which may be abbreviated to simply
t .
For example, if you had the following messages:
O 1 drfoo@myhost.example Wed Sep 1 19:52 18/631 "Fees"
O 2 sam@friends.example Thu Sep 2 00:08 30/895
you could examine the first message by giving the command:
type 1
which might cause
mailx
to respond with, for example:
Message 1:
From drfoo@myhost.example Wed Sep 1 19:52:25 2004
Subject: Fees
Status: R
Tuition fees are due next Wednesday. Don't forget!
Many
mailx
commands that operate on messages take a message number as an
argument like the
type
command.
For these commands, there is a notion of a current message.
When you enter the
mailx
program, the current message is initially the first
(or the first recent) one.
Thus, you can often omit the message number and use, for example,
t
to type the current message.
As a further shorthand, you can type a message
by simply giving its message number.
Hence,
1
would type the first message.
Frequently, it is useful to read the messages in your mailbox in order,
one after another.
You can read the next message in
mailx
by simply typing a newline.
As a special case, you can type a newline as your first command to
mailx
to type the first message.
If, after typing a message, you wish to immediately send a reply,
you can do so with the
reply
command.
This command,
like
type,
takes a message number as an argument.
mailx
then begins a message addressed to the user who sent you the message.
You may then type in your letter in reply, followed by a <control-d>
at the beginning of a line, as before.
Note that
mailx
copies the subject header from the original message.
This is useful in that correspondence
about a particular matter will tend to retain the same subject heading,
making it easy to recognize.
If there are other header fields in the message,
like `Cc:',
the information found will also be used.
Sometimes you will receive a message that has been sent to
several people and wish to reply only
to the person who sent it.
Reply
with a capital
R
replies to a message, but sends a copy to the sender only.
If you wish, while reading your mail, to send a message to someone,
but not as a reply to one of your messages, you can send the message
directly with the
mail
command, which takes as arguments the names of the recipients you wish
to send to.
For example, to send a message to <frank@machine.example>,
you would do:
mail frank@machine.example
To delete a message from the mail folder,
you can use the
delete
command.
In addition to not saving deleted messages,
mailx
will not let you type them, either.
The effect is to make the message disappear
altogether, along with its number.
Many features of
mailx
can be tailored to your liking with the
set
command.
The
set
command has two forms, depending on whether you are setting a
binary
option or a
valued
option.
Binary options are either on or off. For example, the
askcc
option informs
mailx
that each time you send a message, you want it to prompt you for
a `Cc:' header,
to be included in the message.
To set the
askcc
option, you would type
set askcc
Valued options are values which
mailx
uses to adapt to your tastes.
For example, the
record
option tells
mailx
where to save messages sent by you,
and is specified by
set record=Sent
for example.
Note that no spaces are allowed in
set record=Sent.
Mailx
includes a simple facility for maintaining groups of messages together
in folders.
To use the folder facility, you must tell
mailx
where you wish to keep your folders.
Each folder of messages will be a single file.
For convenience, all of your folders are kept in
a single directory of your choosing.
To tell
mailx
where your folder directory is, put a line of the form
set folder=letters
in your
.mailrc
file.
If, as in the example above,
your folder directory does not begin with a `/',
mailx
will assume that your folder directory is to be found starting from
your home directory.
Anywhere a file name is expected, you can use a folder name, preceded
with `+'.
For example, to put a message into a folder with the
save
command, you can use:
save +classwork
to save the current message in the
classwork
folder.
If the
classwork
folder does not yet exist, it will be created.
Note that messages which are saved with the
save
command are automatically removed from your system mailbox.
In order to make a copy of a message in a folder without causing
that message to be removed from your system mailbox, use the
copy
command, which is identical in all other respects to the
save
command.
The
folder
command
can be used to direct
mailx
to the contents of a different folder.
For example,
folder +classwork
directs
mailx
to read the contents of the
classwork
folder.
All of the commands that you can use on your system
mailbox are also applicable to folders, including
type,
delete,
and
reply.
To inquire which folder you are currently editing, use simply:
folder
To list your current set of folders, use the
folders
command.
Finally, the
help
command is available to print out a brief summary of the most important
mailx
commands.
While typing in a message to be sent to others, it is often
useful to be able to invoke the text editor on the partial message,
print the message, execute a shell command, or do some other
auxiliary function.
Mailx
provides these capabilities through
tilde escapes ,
which consist of a tilde (~) at the beginning of a line, followed by
a single character which indicates the function to be performed.
For example, to print the text of the message so far, use:
~p
which will print a line of dashes, the recipients of your message, and
the text of the message so far.
A list of the most important tilde escapes is available with `~?'.
IMAP or POP3 client setup
First you need the following data from your ISP:
the host name of the IMAP or POP3 server,
user name and password for this server,
and a notice whether the server uses SSL/TLS encryption.
Assuming the host name is `server.myisp.example'
and your user name for that server is `mylogin',
you can refer to this account using the
folder
command or
-f
command line option with
imaps://mylogin@server.myisp.example
(This string is not necessarily the same as your Internet mail address.)
You can replace `imaps://' with `imap://'
if the server does not support SSL/TLS.
(If SSL/TLS support is built using NSS, the
nss-config-dir
variable must be set before a connection can be initiated,
see above).
Use `pop3s://' or `pop3://' if the server does not offer IMAP.
You should use IMAP if you can, though;
first because it requires fewer network operations than POP3
to get the contents of the mailbox
and is thus faster;
and second because message attributes
are maintained by the IMAP server,
so you can easily distinguish new and old messages
each time you connect.
Even if the server does not accept IMAPS or POP3S connections,
it is possible that it supports the STARTTLS method
to make a session SSL/TLS encrypted
after the initial connection has been performed,
but before authentication begins.
The only reliable method to see if this works is to try it; enter one of
set imap-use-starttls
set pop3-use-starttls
before you initiate the connection.
As you probably want messages to be deleted from this account
after saving them,
prefix it with `%:'.
The
shortcut
command can be used to avoid typing that many characters
every time you want to connect:
shortcut myisp %:imaps://mylogin@server.myisp.example
You might want to put this string into a startup file.
As the
shortcut
command is specific to this implementation of
mailx
and will confuse other implementations,
it should not be used in
~/.mailrc,
instead, put
set NAIL_EXTRA_RC=~/.nailrc
in
~/.mailrc
and create a file
~/.nailrc
containing the
shortcut
command above.
You can then access your remote mailbox by invoking
`mailx -f myisp' on the command line,
or by executing `fi myisp' within mailx.
If you want to use more than one IMAP mailbox on a server,
or if you want to use the IMAP server for mail storage too,
the
account
command
(which is also mailx-specific)
is more appropriate than the
shortcut
command.
You can put the following in
~/.nailrc:
account myisp {
set folder=imaps://mylogin@server.myisp.example
set record=+Sent MBOX=+mbox outfolder
}
and can then access incoming mail for this account by invoking
`mailx -A myisp' on the command line,
or by executing `ac myisp' within mailx.
After that,
a command like `copy 1 +otherfolder'
will refer to otherfolder on the IMAP server.
In particular,
`fi &' will change to the
mbox
folder,
and
`fi +Sent' will show your recorded sent mail,
with both folders located on the IMAP server.
Mailx
will ask you for a password string
each time you connect to a remote account.
If you can reasonably trust the security
of your workstation,
you can give this password in the startup file as
set password-mylogin@server.myisp.example="SECRET"
You should change the permissions of this file to 0600, see
chmod(1).
Mailx
supports different authentication methods for both IMAP and POP3.
If Kerberos is used at your location,
you can try to activate GSSAPI-based authentication by
set imap-auth=gssapi
The advantage of this method is that
mailx
does not need to know your password at all,
nor needs to send sensitive data over the network.
Otherwise, the options
set imap-auth=cram-md5
set pop3-use-apop
for IMAP and POP3, respectively,
offer authentication methods
that avoid to send the password in clear text over the network,
which is especially important if SSL/TLS cannot be used.
If the server does not offer any of these authentication methods,
conventional user/password based authentication must be used.
It is sometimes helpful to set the
verbose
option when authentication problems occur.
Mailx
will display all data sent to the server in clear text on the screen
with this option,
including passwords.
You should thus take care that no unauthorized person
can look at your terminal when this option is set.
If you regularly use the same workstation
to access IMAP accounts,
you can greatly enhance performance
by enabling local caching of IMAP messages.
For any message that has been fully or partially fetched from the server,
a local copy is made and is used when the message is accessed again,
so most data is transferred over the network once only.
To enable the IMAP cache,
select a local directory name and put
set imap-cache=~/localdirectory
in the startup file.
All files within that directory
can be overwritten or deleted by mailx at any time,
so you should not use the directory to store other information.
Once the cache contains some messages,
it is not strictly necessary anymore
to open a connection to the IMAP server
to access them.
When mailx is invoked with the -D option,
or when the
disconnected
variable is set,
only cached data is used
for any folder you open.
Messages that have not yet been completely cached
are not available then,
but all other messages can be handled
as usual.
Changes made to IMAP mailboxes in
disconnected
mode are committed to the IMAP server
next time it is used in
online
mode.
Synchronizing the local status
with the status on the server
is thus partially within your responsibility;
if you forget to initiate a connection to the server again
before you leave your location,
changes made on one workstation
are not available on others.
Also if you alter IMAP mailboxes from a workstation
while uncommitted changes are still pending on another,
the latter data may become invalid.
The same might also happen because of internal server status changes.
You should thus carefully evaluate this feature in your environment
before you rely on it.
Many servers will close the connection
after a short period of inactivity. Use one of
set pop3-keepalive=30
set imap-keepalive=240
to send a keepalive message each 30 seconds for POP3,
or each 4 minutes for IMAP.
If you encounter problems connecting to a SSL/TLS server,
try the
ssl-rand-egd
and
ssl-rand-file
variables (see the OpenSSL FAQ for more information)
or specify the protocol version with
ssl-method.
Contact your ISP
if you need a client certificate
or if verification of the server certificate fails.
If the failed certificate is indeed valid,
fetch its CA certificate by executing the shell command
$ openssl s_client </dev/null -showcerts -connect \
server.myisp.example:imaps 2>&1 | tee log
(see
s_client(1))
and put it into the file specified with
ssl-ca-file.
The data you need is located at the end of the certificate chain
within (and including) the `BEGIN CERTIFICATE'
and `END CERTIFICATE' lines.
(Note that it is possible to fetch
a forged certificate by this method.
You can only completely rely
on the authenticity of the CA certificate
if you fetch it in a way that is trusted by other means,
such as by personally receiving the certificate on storage media.)
Creating a score file or message filter
The scoring commands are best separated
from other configuration for clarity,
and are mostly
mailx
specific.
It is thus recommended to put them in a separate file
that is sourced from your NAIL_EXTRA_RC as follows:
source ~/.scores
The .scores file could then look as follows:
define list {
score (subject "important discussion") +10
score (subject "annoying discussion") -10
score (from "nicefellow@goodnet") +15
score (from "badguy@poornet") -5
move (header x-spam-flag "+++++") +junk
}
set folder-hook-imap://user@host/public.list=list
In this scheme,
you would see any mail from `nicefellow@goodnet',
even if the surrounding discussion is annoying;
but you normally would not see mail from `badguy@poornet',
unless he participates in the important discussion.
Messages that are marked with five or more plus characters
in their `X-Spam-Flag' field
(inserted by some server-side filtering software)
are moved to the folder `junk' in the
folder
directory.
Be aware that all criteria in () lead to substring matches,
so you would also score messages
from e.g. `notsobadguy@poornetmakers' negative here.
It is possible to select addresses exactly using "address"
message specifications,
but these cannot be executed remotely
and will thus cause all headers
to be downloaded from IMAP servers while looking for matches.
When searching messages on an IMAP server,
best performance is usually achieved
by sending as many criteria as possible
in one large () specification,
because each single such specification
will result in a separate network operation.
Activating the Bayesian filter
The Bayesian junk mail filter works
by examining the words contained in messages.
You decide yourself what a good and what a bad message is.
Thus the resulting filter is your very personal one;
once it is correctly set up,
it will filter only messages similar to those
previously specified by you.
To use the Bayesian filter,
a location for the junk mail database must be defined first:
set junkdb=~/.junkdb
The junk mail database does not contain
actual words extracted from messages,
but hashed representations of them.
A foreign person who can read the database
could only examine the frequency of previously known words
in your mail.
If you have sufficient disk space (several 10 MB) available,
it is recommended that you set the
chained-junk-tokens
option.
The filter will then also consider two-word tokens,
improving its accuracy.
A set of good messages and junk messages must now be available;
it is also possible to use the incoming new messages for this purpose,
although it will of course take some time
until the filter becomes useful then.
Do not underestimate the amount of statistical data needed;
some hundred messages are typically necessary
to get satisfactory results,
and many thousand messages for best operation.
You have to pass the good messages to the
good
command,
and the junk messages to the
junk
command.
If you ever accidentally mark a good message as junk or vice-versa,
call the
ungood
or
unjunk
command to correct this.
Once a reasonable amount of statistics has been collected,
new messages can be classified automatically.
The
classify
command marks all messages that the filter considers to be junk,
but it does not perform any action on them by default.
It is recommended that you move these messages into a separate
folder just for the case that false positives occur,
or to pass them to the
junk
command later again to further improve the junk mail database.
To automatically move incoming junk messages
every time the inbox is opened,
put lines like the following into your
.scores
file (or whatever name you gave to the file in the last example):
define junkfilter {
classify (smaller 20000) :n
move :j +junk
}
set folder-hook-imap://user@host/INBOX=junkfilter
If you set the
verbose
option before running the
classify
command,
mailx
prints the words it uses for calculating the junk status
along with their statistical probabilities.
This can help you to find out
why some messages are not classified
as you would like them to be.
To see the statistical probability of a given word,
use the
probability
command.
If a junk message was not recognized as such,
use the
junk
command to correct this.
Also if you encounter a false positive
(a good message that was wrongly classified as junk),
pass it to the
good
command.
Since the
classify
command must examine the entire text
of all new messages in the respective folder,
this will also cause all of them to be downloaded from the IMAP server.
You should thus restrict the size of messages for automatic filtering.
If server-based filtering is also available,
you might try if that works for you first.
Reading HTML mail
You need either the
w3m
or
lynx
utility
or another command-line web browser
that can write plain text to standard output.
set pipe-text/html="w3m -dump -T text/html"
or
set pipe-text/html="lynx -dump -force_html /dev/stdin"
will then cause HTML message parts to be converted into a more friendly form.
Viewing PDF attachments
Most PDF viewers do not accept input directly from a pipe.
It is thus necessary to store the attachment in a temporary file, as with
set pipe-application/pdf="cat >/tmp/mailx$$.pdf; \
acroread /tmp/mailx$$.pdf; rm /tmp/mailx$$.pdf"
Note that security defects are discovered in PDF viewers
from time to time.
Automatical command execution like this
can compromise your system security,
in particular if you stay not always informed
about such issues.
Signed and encrypted messages with S/MIME
S/MIME provides two central mechanisms:
message signing and message encryption.
A signed message contains some data in addition
to the regular text.
The data can be used to verify
that the message was sent using a valid certificate,
that the sender's address in the message header
matches that in the certificate,
and that the message text has not been altered.
Signing a message does not change its regular text;
it can be read regardless of whether the recipient's software
is able to handle S/MIME.
It is thus usually possible to sign all outgoing messages
if so desired.---Encryption, in contrast,
makes the message text invisible for all people
except those who have access to the secret decryption key.
To encrypt a message,
the specific recipient's public encryption key must be known.
It is thus not possible to send encrypted mail to people
unless their key has been retrieved
from either previous communication or public key directories.
A message should always be signed before it is encrypted.
Otherwise, it is still possible that the encrypted message text
is altered.
A central concept to S/MIME is that of the certification authority (CA).
A CA is a trusted institution that issues certificates.
For each of these certificates,
it can be verified that it really originates from the CA,
provided that the CA's own certificate is previously known.
A set of CA certificates is usually delivered with OpenSSL
and installed on your system.
If you trust the source of your OpenSSL software installation,
this offers reasonable security for S/MIME on the Internet.
In general, a certificate cannot be more secure
than the method its CA certificate has been retrieved with, though.
Thus if you download a CA certificate from the Internet,
you can only trust the messages you verify using that certificate
as much as you trust the download process.
The first thing you need for participating in S/MIME message exchange
is your personal certificate,
including a private key.
The certificate contains public information,
in particular your name and your email address,
and the public key that is used by others
to encrypt messages for you,
and to verify signed messages they supposedly received from you.
The certificate is included in each signed message you send.
The private key must be kept secret.
It is used to decrypt messages that were
previously encrypted with your public key,
and to sign messages.
For personal use,
it is recommended that you get a S/MIME certificate
from one of the major CAs on the Internet using your WWW browser.
(Many CAs offer such certificates for free.)
You will usually receive
a combined certificate and private key
in PKCS#12 format which
mailx
does not directly accept
if S/MIME support is built using OpenSSL.
To convert it to PEM format,
use the following shell command:
$ openssl pkcs12 -in cert.p12 -out cert.pem -clcerts \
-nodes
If you omit the
-nodes
parameter,
you can specifiy an additional
PEM pass phrase
for protecting the private key.
Mailx
will then ask you for that pass phrase
each time it signs or decrypts a message.
You can then use
set smime-sign-cert-myname@myisp.example=cert.pem
to make this private key and certificate known to
mailx.
If S/MIME support is built using NSS,
the PKCS#12 file must be installed using Mozilla
(provided that
nss-config-dir
is set appropriately,
see above),
and no further action is necessary
unless multiple user certificates
for the same email address are installed.
In this case,
the
smime-sign-nickname
variable has to be set appropriately.
You can now sign outgoing messages.
Just use
set smime-sign
to do so.
From each signed message you send,
the recipient can fetch your certificate
and use it to send encrypted mail back to you.
Accordingly if somebody sends you a signed message,
you can do the same.
First use the
verify
command to check the validity of the certificate.
After that,
retrieve the certificate and tell
mailx
that it should use it for encryption:
certsave filename
set smime-encrypt-user@host=filename
If S/MIME support is built using NSS,
the saved certificate must be installed using Mozilla.
The value of the
smime-encrypt-user@host
is ignored then,
but if multiple certificates for the recipient are available,
the
smime-nickname-user@host
variable must be set.
You should carefully consider
if you prefer to store encrypted messages in decrypted form.
If you do, anybody who has access to your mail folders can read them,
but if you do not,
you might be unable to read them yourself later
if you happen to lose your private key.
The
decrypt
command saves messages in decrypted form,
while the
save,
copy,
and
move
commands leave them encrypted.
Note that neither S/MIME signing nor encryption
applies to message subjects or other header fields.
Thus they may not contain sensitive information
for encrypted messages,
and cannot be trusted even if the message content
has been verified.
When sending signed messages,
it is recommended to repeat any important header information
in the message text.
Using CRLs with S/MIME or SSL/TLS
Certification authorities (CAs) issue
certificate revocation lists (CRLs) on a regular basis.
These lists contain the serial numbers of certificates
that have been declared invalid after they have been issued.
Such usually happens
because the private key for the certificate has been compromised,
because the owner of the certificate has left
the organization that is mentioned in the certificate,
etc.
To seriously use S/MIME or SSL/TLS verification,
an up-to-date CRL is required for each trusted CA.
There is otherwise no method
to distinguish between valid and invalidated certificates.
Mailx
currently offers no mechanism to fetch CRLs,
or to access them on the Internet,
so you have to retrieve them by some external mechanism.
If S/MIME and SSL/TLS support are built using OpenSSL,
mailx
accepts CRLs in PEM format only;
CRLs in DER format must be converted,
e.g. with the shell command
$ openssl crl -inform DER -in crl.der -out crl.pem
To tell
mailx
about the CRLs,
a directory
that contains all CRL files
(and no other files)
must be created.
The
smime-crl-dir
or
ssl-crl-dir
variables, respectively,
must then be set to point to that directory.
After that,
mailx
requires a CRL to be present
for each CA that is used
to verify a certificate.
If S/MIME and SSL/TLS support are built using NSS,
CRLs can be imported in Mozilla applications
(provided that
nss-config-dir
is set appropriately).
Sending mail from scripts
If you want to send mail from scripts,
you must be aware that
mailx
reads the user's configuration files by default.
So unless your script is only intended for your own personal use
(as e.g. a cron job),
you need to circumvent this by invoking
mailx
like
MAILRC=/dev/null mailx -n
You then need to create a configuration for
mailx
for your script.
This can be done by either pointing the
MAILRC
variable to a custom configuration file,
or by passing the configuration in environment variables.
Since many of the configuration options are not valid shell variables, the
env
command is useful in this situation.
An invocation could thus look like
env MAILRC=/dev/null from=scriptreply@domain smtp=host \
smtp-auth-user=login smtp-auth-password=secret \
smtp-auth=login mailx -n -s "subject" \
-a attachment_file recipient@domain <content_file
SEE ALSO
fmt(1),
newaliases(1),
openssl(1),
pg(1),
more(1),
vacation(1),
ssl(3),
aliases(5),
locale(7),
mailaddr(7),
sendmail(8)
NOTES
Variables in the environment passed to
mailx
cannot be unset.
The character set conversion relies
on the
iconv(3)
function.
Its functionality differs widely
between the various system environments
mailx runs on.
If the message `Cannot convert from a to b' appears,
either some characters within the message header or text
are not appropriate for the currently selected terminal character set,
or the needed conversion is not supported by the system.
In the first case,
it is necessary to set
an appropriate LC_CTYPE locale (e.g. en_US)
or the
ttycharset
variable.
In the second case, the
sendcharsets
and
ttycharset
variables must be set to the same value
to inhibit character set conversion.
If
iconv()
is not available at all,
the value assigned to
sendcharsets
must match the character set that is used on the terminal.
Mailx expects input text to be in Unix format,
with lines separated by
newline
(^J, \n) characters only.
Non-Unix text files that use
carriage return
(^M, \r)
characters in addition will be treated as binary data;
to send such files as text, strip these characters e. g. by
-
tr -d '\015' <input | mailx . . .
or fix the tools that generate them.
Limitations with IMAP mailboxes are:
It is not possible to edit messages,
but it is possible to append them.
Thus to edit a message,
create a local copy of it,
edit it, append it,
and delete the original.
The line count for the header display
is only appropriate if the entire message has been downloaded
from the server.
The marking of messages as `new' is performed by the IMAP server;
use of the
exit
command instead of
quit
will not cause it to be reset,
and if the
autoinc/newmail
variables are unset,
messages that arrived during a session
will not be in state `new' anymore
when the folder is opened again.
Also if commands queued in disconnected mode are committed,
the IMAP server will delete the `new' flag
for all messages in the changed folder,
and new messages will appear as unread
when it is selected for viewing later.
The `flagged', `answered', and `draft' attributes are usually permanent,
but some IMAP servers are known to drop them without notification.
Message numbers may change with IMAP
every time before the prompt is printed
if mailx is notified by the server
that messages have been deleted
by some other client or process.
In this case, `Expunged n messages' is printed,
and message numbers may have changed.
Limitations with POP3 mailboxes are:
It is not possible to edit messages,
they can only be copied and deleted.
The line count for the header display
is only appropriate if the entire message has been downloaded
from the server.
The status field of a message is maintained by the server
between connections;
some servers do not update it at all,
and with a server that does,
the `exit' command will not cause the message status to be reset.
The `newmail' command and the `newmail' variable
have no effect.
It is not possible to rename or to remove POP3 mailboxes.
If a
RUBOUT
(interrupt) is typed while an IMAP or POP3 operation is in progress,
mailx
will wait until the operation can be safely aborted,
and will then return to the command loop
and print the prompt again.
When a second
RUBOUT
is typed while
mailx
is waiting for the operation to complete,
the operation itself will be canceled.
In this case,
data that has not been fetched yet
will have to be fetched
before the next command can be performed.
If the canceled operation
was using an SSL/TLS encrypted channel,
an error in the SSL transport will very likely result,
and the connection is no longer usable.
As mailx is a mail user agent,
it provides only basic SMTP services.
If it fails to contact its upstream SMTP server,
it will not make further attempts to transfer the message
at a later time,
and it does not leave other information about this condition
than an error message on the terminal
and a `dead.letter' file.
This is usually not a problem if the SMTP server
is located in the same local network
as the computer on which mailx is run.
However, care should be taken when using a remote server of an ISP;
it might be better to set up a local SMTP server then
which just acts as a proxy.
Mailx immediately contacts the SMTP server (or
/usr/lib/sendmail)
even when operating in
disconnected
mode.
It would not make much sense for mailx to defer outgoing mail
since SMTP servers usually provide
much more elaborated delay handling
than mailx could perform as a client.
Thus the recommended setup for sending mail in
disconnected
mode is to configure a local SMTP server
such that it sends outgoing mail
as soon as an external network connection is available again,
i.e. to advise it to do that from a network startup script.
The junk mail filter follows the concepts developed by
Paul Graham in his articles,
``A Plan for Spam'', August 2002,
<http://www.paulgraham.com/spam.html>,
and ``Better Bayesian Filtering'', January 2003,
<http://www.paulgraham.com/better.html>.
Chained tokens are due to a paper by
Jonathan A. Zdziarski,
``Advanced Language Classification using Chained Tokens'',
February 2004,
<http://www.nuclearelephant.com/papers/chained.html>.
A mail command appeared in Version 1 AT&T Unix.
Berkeley Mail was written in 1978 by Kurt Shoens.
This man page is derived from
from The Mail Reference Manual
originally written by Kurt Shoens.
Heirloom Mailx enhancements are maintained and documented
by Gunnar Ritter.
Portions of this text are reprinted and reproduced in electronic form
from IEEE Std 1003.1, 2003 Edition, Standard for Information Technology
--- Operating System Interface (POSIX), The Open Group Base
Specifications Issue 6, Copyright © 2001-2003 by the Institute of
Electrical and Electronics Engineers, Inc and The Open Group. In the
event of any discrepancy between this version and the original IEEE and
The Open Group Standard, the original IEEE and The Open Group Standard
is the referee document. The original Standard can be obtained online at
http://www.opengroup.org/unix/online.html .
Redistribution of this material is permitted so long as this notice remains
intact.