1Net::SMTP(3)          User Contributed Perl Documentation         Net::SMTP(3)
2
3
4

NAME

6       Net::SMTP - Simple Mail Transfer Protocol Client
7

SYNOPSIS

9           use Net::SMTP;
10
11           # Constructors
12           $smtp = Net::SMTP->new('mailhost');
13           $smtp = Net::SMTP->new('mailhost', Timeout => 60);
14

DESCRIPTION

16       This module implements a client interface to the SMTP and ESMTP
17       protocol, enabling a perl5 application to talk to SMTP servers. This
18       documentation assumes that you are familiar with the concepts of the
19       SMTP protocol described in RFC2821.  With IO::Socket::SSL installed it
20       also provides support for implicit and explicit TLS encryption, i.e.
21       SMTPS or SMTP+STARTTLS.
22
23       The Net::SMTP class is a subclass of Net::Cmd and (depending on
24       avaibility) of IO::Socket::IP, IO::Socket::INET6 or IO::Socket::INET.
25

EXAMPLES

27       This example prints the mail domain name of the SMTP server known as
28       mailhost:
29
30           #!/usr/local/bin/perl -w
31
32           use Net::SMTP;
33
34           $smtp = Net::SMTP->new('mailhost');
35           print $smtp->domain,"\n";
36           $smtp->quit;
37
38       This example sends a small message to the postmaster at the SMTP server
39       known as mailhost:
40
41           #!/usr/local/bin/perl -w
42
43           use Net::SMTP;
44
45           my $smtp = Net::SMTP->new('mailhost');
46
47           $smtp->mail($ENV{USER});
48           if ($smtp->to('postmaster')) {
49            $smtp->data();
50            $smtp->datasend("To: postmaster\n");
51            $smtp->datasend("\n");
52            $smtp->datasend("A simple test message\n");
53            $smtp->dataend();
54           } else {
55            print "Error: ", $smtp->message();
56           }
57
58           $smtp->quit;
59

CONSTRUCTOR

61       new ( [ HOST ] [, OPTIONS ] )
62           This is the constructor for a new Net::SMTP object. "HOST" is the
63           name of the remote host to which an SMTP connection is required.
64
65           On failure "undef" will be returned and $@ will contain the reason
66           for the failure.
67
68           "HOST" is optional. If "HOST" is not given then it may instead be
69           passed as the "Host" option described below. If neither is given
70           then the "SMTP_Hosts" specified in "Net::Config" will be used.
71
72           "OPTIONS" are passed in a hash like fashion, using key and value
73           pairs.  Possible options are:
74
75           Hello - SMTP requires that you identify yourself. This option
76           specifies a string to pass as your mail domain. If not given
77           localhost.localdomain will be used.
78
79           SendHello - If false then the EHLO (or HELO) command that is
80           normally sent when constructing the object will not be sent. In
81           that case the command will have to be sent manually by calling
82           "hello()" instead.
83
84           Host - SMTP host to connect to. It may be a single scalar
85           (hostname[:port]), as defined for the "PeerAddr" option in
86           IO::Socket::INET, or a reference to an array with hosts to try in
87           turn. The "host" method will return the value which was used to
88           connect to the host.  Format - "PeerHost" from IO::Socket::INET new
89           method.
90
91           Port - port to connect to.  Default - 25 for plain SMTP and 465 for
92           immediate SSL.
93
94           SSL - If the connection should be done from start with SSL,
95           contrary to later upgrade with "starttls".  You can use SSL
96           arguments as documented in IO::Socket::SSL, but it will usually use
97           the right arguments already.
98
99           LocalAddr and LocalPort - These parameters are passed directly to
100           IO::Socket to allow binding the socket to a specific local address
101           and port.
102
103           Domain - This parameter is passed directly to IO::Socket and makes
104           it possible to enforce IPv4 connections even if IO::Socket::IP is
105           used as super class. Alternatively Family can be used.
106
107           Timeout - Maximum time, in seconds, to wait for a response from the
108           SMTP server (default: 120)
109
110           ExactAddresses - If true the all ADDRESS arguments must be as
111           defined by "addr-spec" in RFC2822. If not given, or false, then
112           Net::SMTP will attempt to extract the address from the value
113           passed.
114
115           Debug - Enable debugging information
116
117           Example:
118
119               $smtp = Net::SMTP->new('mailhost',
120                                      Hello => 'my.mail.domain',
121                                      Timeout => 30,
122                                      Debug   => 1,
123                                     );
124
125               # the same
126               $smtp = Net::SMTP->new(
127                                      Host => 'mailhost',
128                                      Hello => 'my.mail.domain',
129                                      Timeout => 30,
130                                      Debug   => 1,
131                                     );
132
133               # the same with direct SSL
134               $smtp = Net::SMTP->new('mailhost',
135                                      Hello => 'my.mail.domain',
136                                      Timeout => 30,
137                                      Debug   => 1,
138                                      SSL     => 1,
139                                     );
140
141               # Connect to the default server from Net::config
142               $smtp = Net::SMTP->new(
143                                      Hello => 'my.mail.domain',
144                                      Timeout => 30,
145                                     );
146

METHODS

148       Unless otherwise stated all methods return either a true or false
149       value, with true meaning that the operation was a success. When a
150       method states that it returns a value, failure will be returned as
151       undef or an empty list.
152
153       "Net::SMTP" inherits from "Net::Cmd" so methods defined in "Net::Cmd"
154       may be used to send commands to the remote SMTP server in addition to
155       the methods documented here.
156
157       banner ()
158           Returns the banner message which the server replied with when the
159           initial connection was made.
160
161       domain ()
162           Returns the domain that the remote SMTP server identified itself as
163           during connection.
164
165       hello ( DOMAIN )
166           Tell the remote server the mail domain which you are in using the
167           EHLO command (or HELO if EHLO fails).  Since this method is invoked
168           automatically when the Net::SMTP object is constructed the user
169           should normally not have to call it manually.
170
171       host ()
172           Returns the value used by the constructor, and passed to
173           IO::Socket::INET, to connect to the host.
174
175       etrn ( DOMAIN )
176           Request a queue run for the DOMAIN given.
177
178       starttls ( SSLARGS )
179           Upgrade existing plain connection to SSL.  You can use SSL
180           arguments as documented in IO::Socket::SSL, but it will usually use
181           the right arguments already.
182
183       auth ( USERNAME, PASSWORD )
184       auth ( SASL )
185           Attempt SASL authentication. Requires Authen::SASL module. The
186           first form constructs a new Authen::SASL object using the given
187           username and password; the second form uses the given Authen::SASL
188           object.
189
190       mail ( ADDRESS [, OPTIONS] )
191       send ( ADDRESS )
192       send_or_mail ( ADDRESS )
193       send_and_mail ( ADDRESS )
194           Send the appropriate command to the server MAIL, SEND, SOML or
195           SAML. "ADDRESS" is the address of the sender. This initiates the
196           sending of a message. The method "recipient" should be called for
197           each address that the message is to be sent to.
198
199           The "mail" method can some additional ESMTP OPTIONS which is passed
200           in hash like fashion, using key and value pairs.  Possible options
201           are:
202
203            Size        => <bytes>
204            Return      => "FULL" | "HDRS"
205            Bits        => "7" | "8" | "binary"
206            Transaction => <ADDRESS>
207            Envelope    => <ENVID>     # xtext-encodes its argument
208            ENVID       => <ENVID>     # similar to Envelope, but expects argument encoded
209            XVERP       => 1
210            AUTH        => <submitter> # encoded address according to RFC 2554
211
212           The "Return" and "Envelope" parameters are used for DSN (Delivery
213           Status Notification).
214
215           The submitter address in "AUTH" option is expected to be in a
216           format as required by RFC 2554, in an RFC2821-quoted form and
217           xtext-encoded, or <> .
218
219       reset ()
220           Reset the status of the server. This may be called after a message
221           has been initiated, but before any data has been sent, to cancel
222           the sending of the message.
223
224       recipient ( ADDRESS [, ADDRESS, [...]] [, OPTIONS ] )
225           Notify the server that the current message should be sent to all of
226           the addresses given. Each address is sent as a separate command to
227           the server.  Should the sending of any address result in a failure
228           then the process is aborted and a false value is returned. It is up
229           to the user to call "reset" if they so desire.
230
231           The "recipient" method can also pass additional case-sensitive
232           OPTIONS as an anonymous hash using key and value pairs.  Possible
233           options are:
234
235             Notify  => ['NEVER'] or ['SUCCESS','FAILURE','DELAY']  (see below)
236             ORcpt   => <ORCPT>
237             SkipBad => 1        (to ignore bad addresses)
238
239           If "SkipBad" is true the "recipient" will not return an error when
240           a bad address is encountered and it will return an array of
241           addresses that did succeed.
242
243             $smtp->recipient($recipient1,$recipient2);  # Good
244             $smtp->recipient($recipient1,$recipient2, { SkipBad => 1 });  # Good
245             $smtp->recipient($recipient1,$recipient2, { Notify => ['FAILURE','DELAY'], SkipBad => 1 });  # Good
246             @goodrecips=$smtp->recipient(@recipients, { Notify => ['FAILURE'], SkipBad => 1 });  # Good
247             $smtp->recipient("$recipient,$recipient2"); # BAD
248
249           Notify is used to request Delivery Status Notifications (DSNs), but
250           your SMTP/ESMTP service may not respect this request depending upon
251           its version and your site's SMTP configuration.
252
253           Leaving out the Notify option usually defaults an SMTP service to
254           its default behavior equivalent to ['FAILURE'] notifications only,
255           but again this may be dependent upon your site's SMTP
256           configuration.
257
258           The NEVER keyword must appear by itself if used within the Notify
259           option and "requests that a DSN not be returned to the sender under
260           any conditions."
261
262             {Notify => ['NEVER']}
263
264             $smtp->recipient(@recipients, { Notify => ['NEVER'], SkipBad => 1 });  # Good
265
266           You may use any combination of these three values
267           'SUCCESS','FAILURE','DELAY' in the anonymous array reference as
268           defined by RFC3461 (see http://www.ietf.org/rfc/rfc3461.txt for
269           more information.  Note: quotations in this topic from same.).
270
271           A Notify parameter of 'SUCCESS' or 'FAILURE' "requests that a DSN
272           be issued on successful delivery or delivery failure,
273           respectively."
274
275           A Notify parameter of 'DELAY' "indicates the sender's willingness
276           to receive delayed DSNs.  Delayed DSNs may be issued if delivery of
277           a message has been delayed for an unusual amount of time (as
278           determined by the Message Transfer Agent (MTA) at which the message
279           is delayed), but the final delivery status (whether successful or
280           failure) cannot be determined.  The absence of the DELAY keyword in
281           a NOTIFY parameter requests that a "delayed" DSN NOT be issued
282           under any conditions."
283
284             {Notify => ['SUCCESS','FAILURE','DELAY']}
285
286             $smtp->recipient(@recipients, { Notify => ['FAILURE','DELAY'], SkipBad => 1 });  # Good
287
288           ORcpt is also part of the SMTP DSN extension according to RFC3461.
289           It is used to pass along the original recipient that the mail was
290           first sent to.  The machine that generates a DSN will use this
291           address to inform the sender, because he can't know if recipients
292           get rewritten by mail servers.  It is expected to be in a format as
293           required by RFC3461, xtext-encoded.
294
295       to ( ADDRESS [, ADDRESS [...]] )
296       cc ( ADDRESS [, ADDRESS [...]] )
297       bcc ( ADDRESS [, ADDRESS [...]] )
298           Synonyms for "recipient".
299
300       data ( [ DATA ] )
301           Initiate the sending of the data from the current message.
302
303           "DATA" may be a reference to a list or a list and must be encoded
304           by the caller to octets of whatever encoding is required, e.g. by
305           using the Encode module's "encode()" function.
306
307           If specified the contents of "DATA" and a termination string
308           ".\r\n" is sent to the server. The result will be true if the data
309           was accepted.
310
311           If "DATA" is not specified then the result will indicate that the
312           server wishes the data to be sent. The data must then be sent using
313           the "datasend" and "dataend" methods described in Net::Cmd.
314
315       bdat ( DATA )
316       bdatlast ( DATA )
317           Use the alternate DATA command "BDAT" of the data chunking service
318           extension defined in RFC1830 for efficiently sending large MIME
319           messages.
320
321       expand ( ADDRESS )
322           Request the server to expand the given address Returns an array
323           which contains the text read from the server.
324
325       verify ( ADDRESS )
326           Verify that "ADDRESS" is a legitimate mailing address.
327
328           Most sites usually disable this feature in their SMTP service
329           configuration.  Use "Debug => 1" option under new() to see if
330           disabled.
331
332       help ( [ $subject ] )
333           Request help text from the server. Returns the text or undef upon
334           failure
335
336       quit ()
337           Send the QUIT command to the remote SMTP server and close the
338           socket connection.
339
340       can_inet6 ()
341           Returns whether we can use IPv6.
342
343       can_ssl ()
344           Returns whether we can use SSL.
345

ADDRESSES

347       Net::SMTP attempts to DWIM with addresses that are passed. For example
348       an application might extract The From: line from an email and pass that
349       to mail(). While this may work, it is not recommended.  The application
350       should really use a module like Mail::Address to extract the mail
351       address and pass that.
352
353       If "ExactAddresses" is passed to the constructor, then addresses should
354       be a valid rfc2821-quoted address, although Net::SMTP will accept the
355       address surrounded by angle brackets.
356
357        funny user@domain      WRONG
358        "funny user"@domain    RIGHT, recommended
359        <"funny user"@domain>  OK
360

SEE ALSO

362       Net::Cmd, IO::Socket::SSL
363

AUTHOR

365       Graham Barr <gbarr@pobox.com>.
366
367       Steve Hay <shay@cpan.org> is now maintaining libnet as of version
368       1.22_02.
369
371       Copyright (C) 1995-2004 Graham Barr.  All rights reserved.
372
373       Copyright (C) 2013-2016 Steve Hay.  All rights reserved.
374

LICENCE

376       This module is free software; you can redistribute it and/or modify it
377       under the same terms as Perl itself, i.e. under the terms of either the
378       GNU General Public License or the Artistic License, as specified in the
379       LICENCE file.
380
381
382
383perl v5.30.1                      2020-01-30                      Net::SMTP(3)
Impressum