Difference between revisions of "TSmtpCli"
Jump to navigation
Jump to search
(13 intermediate revisions by 2 users not shown) | |||
Line 3: | Line 3: | ||
== Overview == | == Overview == | ||
− | * '''unit''' | + | * '''unit''' [[OverbyteIcsSmtpProt.pas | OverbyteIcsSmtpProt.pas]] |
− | * '''inheritance''' | + | * '''inheritance''' TIcsWndControl -> TCustomSmtpClient -> TSmtpCli |
Component '''TSmtpCli''' implements client-side of the Simple Mail Transfer Protocol as specified in | Component '''TSmtpCli''' implements client-side of the Simple Mail Transfer Protocol as specified in | ||
− | RFC [http://rfc | + | RFC [http://www.ietf.org/rfc/rfc2821.txt 2821], and MIME message format according to RFC [http://www.ietf.org/rfc/rfc1521.txt 1521] and [http://www.ietf.org/rfc/rfc2045.txt 2045]. Currently supported SMTP Service Extensions for Authentication are |
− | AUTH LOGIN, AUTH PLAIN, AUTH CRAM-MD5 and AUTH CRAM-SHA1 (RFC [http://rfc | + | AUTH LOGIN, AUTH PLAIN, AUTH CRAM-MD5 and AUTH CRAM-SHA1 (RFC [http://www.ietf.org/rfc/rfc2554.txt 2554] as well as RFC [http://www.ietf.org/rfc/rfc1734.txt 1734]). |
The TSmtpCli methods are [[Asynchronous_Paradigm | '''non-blocking''']], a synchronously working counterpart is also available, see [[TSyncSmtpCli | TSyncSmtpCli]]. | The TSmtpCli methods are [[Asynchronous_Paradigm | '''non-blocking''']], a synchronously working counterpart is also available, see [[TSyncSmtpCli | TSyncSmtpCli]]. | ||
Line 18: | Line 18: | ||
| valign="top" width="140" | [[TSmtpCli.Allow8BitChars | Allow8BitChars ]] |||| If set to FALSE enables internal encoding of header lines and MailMessage text | | valign="top" width="140" | [[TSmtpCli.Allow8BitChars | Allow8BitChars ]] |||| If set to FALSE enables internal encoding of header lines and MailMessage text | ||
|- | |- | ||
− | | valign="top" | [[TSmtpCli.AuthType | AuthType]] |||| Authentication | + | | valign="top" | [[TSmtpCli.AuthType | AuthType]] |||| Authentication type to be used with method [[TSmtpCli.Auth | '''Auth''']] |
|- | |- | ||
− | | valign="top" | [[TSmtpCli.AuthTypesSupported | AuthTypesSupported]] |||| A list of authentication | + | | valign="top" | [[TSmtpCli.AuthTypesSupported | AuthTypesSupported]] |||| A list of authentication types supported by the server available after SMTP command [[TSmtpCli.Ehlo | '''EHLO''']] returned |
|- | |- | ||
| valign="top" | [[TSmtpCli.CharSet | CharSet]] |||| [http://www.iana.org/assignments/character-sets Character set] of the mail message, default value is the preferred MIME name of current system charset | | valign="top" | [[TSmtpCli.CharSet | CharSet]] |||| [http://www.iana.org/assignments/character-sets Character set] of the mail message, default value is the preferred MIME name of current system charset | ||
|- | |- | ||
− | | valign="top" | [[TSmtpCli.CodePage | CodePage]] |||| The [http://msdn.microsoft.com/en-us/library/dd317756.aspx Windows code page identifier] mapped to | + | | valign="top" | [[TSmtpCli.CodePage | CodePage]] |||| The [http://msdn.microsoft.com/en-us/library/dd317756.aspx Windows code page identifier] mapped to value of property [[TSmtpCli.CharSet | CharSet]] (V7) |
|- | |- | ||
| valign="top" | [[TSmtpCli.ConfirmReceipt | ConfirmReceipt]] |||| Request confirmation of receipt | | valign="top" | [[TSmtpCli.ConfirmReceipt | ConfirmReceipt]] |||| Request confirmation of receipt | ||
Line 38: | Line 38: | ||
| valign="top" | [[TSmtpCli.DefaultEncoding | DefaultEncoding]] |||| Default Transfer-Encoding | | valign="top" | [[TSmtpCli.DefaultEncoding | DefaultEncoding]] |||| Default Transfer-Encoding | ||
|- | |- | ||
− | | valign="top" | [[TSmtpCli.EmailFiles | EmailFiles]] |||| | + | | valign="top" | [[TSmtpCli.EmailFiles | EmailFiles]] |||| List of files to be attached |
|- | |- | ||
| valign="top" | [[TSmtpCli.ErrorMessage | ErrorMessage]] |||| Last SMTP error message | | valign="top" | [[TSmtpCli.ErrorMessage | ErrorMessage]] |||| Last SMTP error message | ||
Line 64: | Line 64: | ||
| valign="top" | [[TSmtpCli.HdrTo | HdrTo]] |||| Value of mail header line '''To''' | | valign="top" | [[TSmtpCli.HdrTo | HdrTo]] |||| Value of mail header line '''To''' | ||
|- | |- | ||
− | | valign="top" | [[TSmtpCli.Host | Host]] |||| Host name or IP | + | | valign="top" | [[TSmtpCli.Host | Host]] |||| Host name or IP address of the SMTP server |
|- | |- | ||
| valign="top" | [[TSmtpCli.LastResponse | LastResponse]] |||| Last response from the mail server. | | valign="top" | [[TSmtpCli.LastResponse | LastResponse]] |||| Last response from the mail server. | ||
|- | |- | ||
− | | valign="top" | [[TSmtpCli.LocalAddr | LocalAddr]] |||| | + | | valign="top" | [[TSmtpCli.LocalAddr | LocalAddr]] |||| Interface to be bound to the socket, defaults to "0.0.0.0" = any interface |
|- | |- | ||
| valign="top" | [[TSmtpCli.MailMessage | MailMessage]] |||| The mail message text. | | valign="top" | [[TSmtpCli.MailMessage | MailMessage]] |||| The mail message text. | ||
Line 98: | Line 98: | ||
| valign="top" | [[TSmtpCli.Username | Username]] |||| SMTP login username | | valign="top" | [[TSmtpCli.Username | Username]] |||| SMTP login username | ||
|- | |- | ||
− | | valign="top" | [[TSmtpCli.WrapMessageText | WrapMessageText]] |||| Tries to insert line breaks in unencoded MailMessage text if | + | | valign="top" | [[TSmtpCli.WrapMessageText | WrapMessageText]] |||| Tries to insert line breaks in unencoded [[TSmtpCli.MailMessage | MailMessage]] text if line length exceed value of property WrapMsgMaxLineLen |
|- | |- | ||
| valign="top" | [[TSmtpCli.WrapMsgMaxLineLen | WrapMsgMaxLineLen]] |||| MailMessage maximum line length (V7) | | valign="top" | [[TSmtpCli.WrapMsgMaxLineLen | WrapMsgMaxLineLen]] |||| MailMessage maximum line length (V7) | ||
Line 112: | Line 112: | ||
| valign="top" | [[TSmtpCli.CalcMsgSize | CalcMsgSize]] |||| Calculates message size (V7) | | valign="top" | [[TSmtpCli.CalcMsgSize | CalcMsgSize]] |||| Calculates message size (V7) | ||
|- | |- | ||
− | | valign="top" | [[TSmtpCli.CalcMsgSizeSync | CalcMsgSizeSync]] |||| Calculates message size (V7) | + | | valign="top" | [[TSmtpCli.CalcMsgSizeSync | CalcMsgSizeSync]] |||| Calculates message size synchronously (V7) |
|- | |- | ||
| valign="top" | [[TSmtpCli.Connect | Connect]] |||| Connects to the mail server. | | valign="top" | [[TSmtpCli.Connect | Connect]] |||| Connects to the mail server. | ||
Line 170: | Line 170: | ||
| valign="top" | [[TSmtpCli.OnHeaderLine | OnHeaderLine]] |||| Triggered on each mail header line. | | valign="top" | [[TSmtpCli.OnHeaderLine | OnHeaderLine]] |||| Triggered on each mail header line. | ||
|- | |- | ||
− | | valign="top" | [[TSmtpCli.OnMessageDataSent | OnMessageDataSent]] |||| Triggered whenever message data | + | | valign="top" | [[TSmtpCli.OnMessageDataSent | OnMessageDataSent]] |||| Triggered whenever message data have been sent (V7). |
|- | |- | ||
| valign="top" | [[TSmtpCli.OnProcessHeader | OnProcessHeader]] |||| Triggered before the mail header lines are formed. | | valign="top" | [[TSmtpCli.OnProcessHeader | OnProcessHeader]] |||| Triggered before the mail header lines are formed. |
Latest revision as of 20:12, 17 January 2016
Main page -> ICS component reference -> TSmtpCli
Overview
- unit OverbyteIcsSmtpProt.pas
- inheritance TIcsWndControl -> TCustomSmtpClient -> TSmtpCli
Component TSmtpCli implements client-side of the Simple Mail Transfer Protocol as specified in RFC 2821, and MIME message format according to RFC 1521 and 2045. Currently supported SMTP Service Extensions for Authentication are AUTH LOGIN, AUTH PLAIN, AUTH CRAM-MD5 and AUTH CRAM-SHA1 (RFC 2554 as well as RFC 1734). The TSmtpCli methods are non-blocking, a synchronously working counterpart is also available, see TSyncSmtpCli.
Properties
Allow8BitChars | If set to FALSE enables internal encoding of header lines and MailMessage text | |
AuthType | Authentication type to be used with method Auth | |
AuthTypesSupported | A list of authentication types supported by the server available after SMTP command EHLO returned | |
CharSet | Character set of the mail message, default value is the preferred MIME name of current system charset | |
CodePage | The Windows code page identifier mapped to value of property CharSet (V7) | |
ConfirmReceipt | Request confirmation of receipt | |
Connected | Are we connected to the mail server? | |
ContentType | Either HTML or plain text (smtpHtml or smtpPlainText) | |
ConvertToCharset | Allow charset conversion (ignored by UNICODE compilers, new in V7) | |
CtrlSocket | The underlying instance of TWSocket handles the connection and raw data exchange. | |
DefaultEncoding | Default Transfer-Encoding | |
EmailFiles | List of files to be attached | |
ErrorMessage | Last SMTP error message | |
FoldHeaders | Fold header lines if their length exceed the limit | |
FromName | E-mail address sent to the mail server with SMTP command MAIL | |
Handle | Handle of the hidden window used internally by the component | |
HdrCc | Value of mail header line CC | |
HdrFrom | Value of mail header line From | |
HdrPriority | Mail priority (creates a custom mail header line). | |
HdrReplyTo | Value of mail header line Reply-To | |
HdrReturnPath | Value of mail header line Return-Path | |
HdrSender | Value of mail header line Sender | |
HdrSubject | Value of mail header line Subject | |
HdrTo | Value of mail header line To | |
Host | Host name or IP address of the SMTP server | |
LastResponse | Last response from the mail server. | |
LocalAddr | Interface to be bound to the socket, defaults to "0.0.0.0" = any interface | |
MailMessage | The mail message text. | |
MaxMessageSize | Indicates the maximum message size accepted by the server (V7) | |
MessageID | A unique ID created for each mail message, appears as mail header line (Message-ID) | |
MessageSize | Size of the e-mail (V7) | |
OwnHeaders | Set OwnHeaders to True in order to send your own, custom header lines. | |
Password | SMTP login password | |
Port | Port number of the SMTP server, defaults to 25 | |
RcptName | E-mail address to be sent to the mail server with SMTP command RCPT | |
RequestType | Current request type | |
ShareMode | ShareMode of the stream (file attachments). | |
SignOn | Parameter sent with the SMTP commands HELO and EHLO | |
SizeSupported | Indicates whether the server supports the RFC-1870 SIZE extension (V7) | |
State | Current component state | |
Username | SMTP login username | |
WrapMessageText | Tries to insert line breaks in unencoded MailMessage text if line length exceed value of property WrapMsgMaxLineLen | |
WrapMsgMaxLineLen | MailMessage maximum line length (V7) |
Methods
Abort | Cancels any transactions in progress, closes server connection. | |
Auth | Sends SMTP command AUTH starting the authentication process. | |
CalcMsgSize | Calculates message size (V7) | |
CalcMsgSizeSync | Calculates message size synchronously (V7) | |
Connect | Connects to the mail server. | |
Create | Constructor | |
Data | Sends SMTP command DATA. | |
Destroy | Destructor | |
Ehlo | Sends SMTP command EHLO. | |
Helo | Sends SMTP command HELO. | |
HighLevelAsync | Execute multiple commands consecutively | |
Executes methods MailFrom, RcptTo, and Data consecutively. | ||
MailFrom | Sends SMTP command MAIL | |
MailFromSIZE | Same as MailFrom however appends the message size as argument (V7) | |
Open | Executes methods Connect, Ehlo, and Auth consecutively. | |
Quit | Sends SMTP command QUIT | |
RcptNameAdd | Assigns recipients to the various recipient lists. | |
RcptTo | Sends SMTP command RCPT, for each recipient in the lists. | |
Rset | Sends SMTP command RSET. | |
ThreadAttach | Attaches the component to current thread context. | |
ThreadDetach | Detaches the component from current thread context. | |
Vrfy | Sends SMTP command VRFY. |
Events
OnAfterFileOpen | Triggered after the attempt to open a file to be attached. | |
OnAttachContentType | Triggered before the content-type header line of an attachment part header is formed. | |
OnAttachHeader | Triggered after all header lines of an attachment part header have been formed. | |
OnBeforeFileOpen | Triggered before the attempt to open a file to be attached. | |
OnCommand | Triggered on every command that is sent. | |
OnDisplay | Triggered on every command/response. Useful for debugging purposes. | |
OnGetData | Triggered when the component requests next data line, useful for sending custom data. | |
OnHeaderLine | Triggered on each mail header line. | |
OnMessageDataSent | Triggered whenever message data have been sent (V7). | |
OnProcessHeader | Triggered before the mail header lines are formed. | |
OnRcptToError | Triggered when one of the recipients are i.e. rejected by server for some reason. | |
OnRequestDone | Triggered when a request is completed. | |
OnResponse | Triggered on server's response. | |
OnSessionClosed | Triggered when the connection has been closed. | |
OnSessionConnected | Triggered when a connection has been established. |
How to
See also