Email Delphi ActiveX Reference Documentation
TChilkatEmail
Current Version: 11.1.0
Represents a complete Email object.
Importing the Chilkat ActiveX into Delphi
Important: When upgrading to a new version of Chilkat, make sure to re-imported ActiveX DLL into Delphi to regenerate the files described below.
Chilkat v9.5.*: If using Chilkat v9.5.*, then use "Chilkat_v9_5_0_TLB" instead of "Chilkat_TLB", and the DLLs are named ChilkatAx-9.5.0-win32.dll (or ChilkatAx-9.5.0-x64.dll).
Two things are required to use an ActiveX in Delphi:
- The ActiveX DLL needs to be registered via regsvr32 on the system where the Delphi application runs. See How To Register ActiveX DLLs for detailed information.
- See also: ActiveX Registration Tutorial
- The ActiveX component needs to be "imported". Use the Delphi Import Component Wizard to import the Chilkat type library. This creates the following files: Chilkat_TLB.pas and Chilkat_TLB.dcr. The Chilkat_TLB.pas should be added to your project.
To import the Chilkat type library, do the following:
- In the Delphi RAD Studio, select the menu item "Component" --> "Import a Type Library".
- Find "Chilkat ActiveX" in the list and select it. This will only appear in the list if the ChilkatAx-win32.dll (or ChilkatAx-x64.dll) has been registered w/ regsvr32.
- Check the "Generate Component Wrappers" checkbox.
- Select a directory where the unit files (.pas and .dcr) should be generated.
- Select "Create Unit" and then "Finish".
- Add the .pas to your Delphi project.
To use a Chilkat ActiveX object in your Delphi code, add "Chilkat_TLB" to the "uses" statement. For example:
uses Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics, Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, Chilkat_TLB;
Object Creation
var obj: TChilkatEmail; ... begin obj := TChilkatEmail.Create(Self); ... // When finished, free the object instance. obj.Free();
Properties
Body
The body of the email. If the email has both HTML and plain-text bodies, this property returns the HTML body. The GetHtmlBody and GetPlainTextBody methods can be used to access a specific body. The HasHtmlBody and HasPlainTextBody methods can be used to determine the presence of a body.
Charset
Represents the main charset of the email, such as utf-8, iso-8859-1, Shift_JIS, us-ascii, etc.  This property can be empty if there is no explicit charset, such as for emails with only us-ascii.
Setting this property causes Chilkat to use the new charset in HTML and plain-text bodies, where possible. This can include updating the HTML META tag in HTML bodies to agree with the charset specified in the email header and also the byte representation of the HTML body in the email.
DebugLogFilePath
If set to a file path, this property logs the LastErrorText of each Chilkat method or property call to the specified file. This logging helps identify the context and history of Chilkat calls leading up to any crash or hang, aiding in debugging.
Enabling the VerboseLogging property provides more detailed information. This property is mainly used for debugging rare instances where a Chilkat method call causes a hang or crash, which should generally not happen.
Possible causes of hangs include:
- A timeout property set to 0, indicating an infinite timeout.
- A hang occurring within an event callback in the application code.
- An internal bug in the Chilkat code causing the hang.
Decrypted
1 if the email arrived encrypted and was successfully decrypted, otherwise 0.   This property is only meaningful when the ReceivedEncrypted property is equal to 1.
EmailDateStr
The date/time from the Date header in the UTC/GMT timezone in RFC822 string form.
EncryptedBy
If the email was received encrypted, this contains the details of the certificate used for encryption.
topFileDistList
Set this property to send an email to a list of recipients stored in a plain text file. The file format is simple: one recipient per line, no comments allowed, blank lines are ignored.Setting this property is equivalent to adding a CKX-FileDistListheader field to the email. Chilkat Mail treats header fields beginning with CKX-specially in that these fields are never transmitted with the email when sent. However, CKX fields are saved and restored when saving to XML or loading from XML (or MIME). When sending an email containing a CKX-FileDistListheader field, Chilkat Mail will read the distribution list file and send the email to each recipient. Emails can be sent individually, or with BCC, 100 recipients at a time. (see the MailMan.SendIndividual property).
From
The combined name and email address of the sender, such as John Smith 
FromAddress
FromName
Header
The complete MIME header of the email.
topLanguage
A read-only property that identifies the primary language group for the email. Possible values are:
The language group determination is made soley on the subject and plain-text/HTML email bodies. Characters in the FROM, TO, CC, and other header fields are not considered.
latin1(for English and all Western European languages)
central(for Central European languages such as Polish, Czech, Hungarian, etc.)
russian(for Cyrillic languages)
greek
turkish
hebrew
arabic
thai
vietnamese
chinese
japanese
korean
devanagari
bengali
gurmukhi
gujarati
oriya
tamil
telugu
kannada
malayalam
sinhala
lao
tibetan
myanmar
georgian
unknown
The primary determining factor is the characters found in the Subject header field.  For example, if an email contains Japanese in the Subject, but the body contains Russian characters, it will be considered japanese.
The language is determined by where the Unicode chars fall in various blocks in the Unicode Basic Multilingual Plane.  For more information, see the book Unicode Demystified by Richard Gillam.
LastBinaryResult
This property is mainly used in SQL Server stored procedures to retrieve binary data from the last method call that returned binary data. It is only accessible if Chilkat.Global.KeepBinaryResult is set to 1. This feature allows for the retrieval of large varbinary results in an SQL Server environment, which has restrictions on returning large data via method calls, though temp tables can handle binary properties.
LastErrorHtml
Provides HTML-formatted information about the last called method or property. If a method call fails or behaves unexpectedly, check this property for details. Note that information is available regardless of the method call's success.
topLastErrorText
Provides plain text information about the last called method or property. If a method call fails or behaves unexpectedly, check this property for details. Note that information is available regardless of the method call's success.
LastErrorXml
Provides XML-formatted information about the last called method or property. If a method call fails or behaves unexpectedly, check this property for details. Note that information is available regardless of the method call's success.
topLastMethodSuccess
Indicates the success or failure of the most recent method call: 1 means success, 0 means failure. This property remains unchanged by property setters or getters.  This method is present to address challenges in checking for null or Nothing returns in certain programming languages.  Note: This property does not apply to methods that return integer values or to boolean-returning methods where the boolean does not indicate success or failure.
LastStringResult
In SQL Server stored procedures, this property holds the string return value of the most recent method call that returns a string. It is accessible only when Chilkat.Global.KeepStringResult is set to TRUE. SQL Server has limitations on string lengths returned from methods and properties, but temp tables can be used to access large strings.
LastStringResultLen
The length, in characters, of the string contained in the LastStringResult property.
topLocalDateStr
The date/time found in the Date header field returned in the local timezone in RFC822 string form.
Mailer
Identifies the email software that sent the email.
topNumAlternatives
The number of alternative bodies present in the email. An email that is not multipart/alternativewill return 0 alternatives. An email that is multipart/alternative will return a number greater than or equal to 1.
NumAttachedMessages
Returns the number of embedded emails.  Some mail clients will embed an email that is to be forwarded into a new email as a message/rfc822 subpart of the MIME message structure.  This property tells how many emails have been embedded.  The original email can be retrieved by calling GetAttachedMessage.
NumAttachments
The number of attachments contained in the email.
Note: If an email is downloaded from an IMAP server without attachments, then the number of attachments should be obtained by calling the IMAP object's GetMailNumAttach method. This property indicates the actual number of attachments already present within the email object.
NumBcc
NumCC
NumDaysOld
Returns the number of days old from the current system date/time.  The email's date is obtained from the Date header field.  If the Date header field is missing, or invalid, then -9999 is returned.  A negative number may be returned if the Date header field contains a future date/time.  (However, -9999 represents an error condition.)
NumDigests
Returns the number of message/rfc822 parts contained within the multipart/digest enclosure. If no multipart/digest enclosure exists, then this property has the value of 0. The GetDigest method is called to get the Nth digest as an email object.
NumHeaderFields
The number of header fields. When accessing a header field by index, the 1st header field is at index 0, and the last is at NumHeaderFields-1. (Chilkat indexing is always 0-based.)
topNumRelatedItems
The number of related items present in this email. Related items are typically image files (JPEGs or GIFs) or style sheets (CSS files) that are included with HTML formatted messages with internal CIDhyperlinks.
NumReplacePatterns
Returns the number of replacement patterns previously set by calling the SetReplacePattern method 1 or more times. If replacement patterns are set, the email bodies and header fields are modified by applying the search/replacement strings during the message sending process.
NumReports
(For multipart/report emails that have sub-parts with Content-Types such as message/feedback-report.)   Any MIME sub-part within the email that has a Content-Type of message/*, but is not a message/rfc822, is considered to be a report and is included in this count.  (A message/rfc822 is considered an attached message and is handled by the NumAttachedMessages property and the GetAttachedMessage method.)  
Any MIME sub-part having a Content-Type equal to text/rfc822-headers is also considered to be a report.  
The GetReport method may be called to get the body content of each report contained within a multipart/report email.
NumTo
OaepHash
Selects the hash algorithm for use within OAEP padding when encrypting email using RSAES-OAEP.  The valid choices are sha1, sha256, sha384, sha512,
OaepMgfHash
Selects the MGF hash algorithm for use within OAEP padding when encrypting email using RSAES-OAEP.  The valid choices are sha1, sha256, sha384, sha512,
OaepPadding
Selects the RSA encryption scheme when encrypting email. The default value is 0, which selects RSAES_PKCS1-V1_5.   If set to 1, then RSAES_OAEP is used.
OverwriteExisting
When 1 (the default) the methods to save email attachments and related items will overwrite files if they already exist.  If 0, then the methods that save email attachments and related items will append a string of 4 characters to create a unique filename if a file already exists.  The filename of the attachment (or related item) within the email object is updated and can be retrieved by the program to determine the actual file(s) created.
Pkcs7CryptAlg
When an email is sent encrypted (using PKCS7 public-key encryption), this selects the underlying symmetric encryption algorithm. Possible values are: aes, aes-gcm, des, 3des, and rc2.  The default value is aes.
Note: The aes-gcm option was added in Chilkat v10.0.0
Pkcs7KeyLength
When the email is sent encrypted (using PKCS7 public-key encryption), this selects the key length of the underlying symmetric encryption algorithm. The possible values allowed depend on the Pkcs7CryptAlg property.  For aes, the key length may be 128, 192, or 256.  For 3des the key length must be 192.  For des the key length must be 40.  For rc2 the key length can be 40, 56, 64, or 128.
PreferredCharset
Only applies when building an email with non-English characters where the charset is not explicitly set. The Chilkat email component will automatically choose a charset based on the languages found within an email (if the charset is not already specified within the MIME or explicitly specified by setting the Charset property). The default charset chosen for each language is:
Chinese: gb2312
Japanese: shift_JIS
Korean: ks_c_5601-1987
Thai: windows-874
All others: iso-8859-*
This allows for charsets such as iso-2022-jp to be chosen instead of the default. If the preferred charset does not apply to the situation, it is not used. For example, if the preferred charset is iso-2022-jp, but the email contains Greek characters, then the preferred charset is ignored.
PrependHeaders
If 1, then header fields added via the AddHeaderField or AddHeaderField2 methods are prepended to the top of the header as opposed to appended to the bottom.  The default value is 0.
ReceivedEncrypted
1 if this email was originally received with encryption, otherwise 0.
ReceivedSigned
1 if this email was originally received with a digital signature, otherwise 0.
ReplyTo
Sets the Reply-To header field to the specified email address such as john@example.com.  The Reply-To header automatically defaults to the From email address.  You would only set this property if you wish for the Reply-To email address to be different from the From address.  
There is usually only a single Reply-To email address.  If multiple Reply-To addresses are needed, then set with a comma separated list of email addresses such as john@example.com, mary@somewhere.com.
ReturnReceipt
Set to 1 if you want the email to request a return-receipt when received by the recipient.  The default value is 0.
Setting this property causes the Disposition-Notification-To email header to be added when the email is sent.
SendEncrypted
SendSigned
Set to 1 if this email should be sent with a digital signature.
Note: Please be aware of the Apple Mail bug explained in the web page at the link below.
SignaturesValid
1 if the email was received with one or more digital signatures, and if all the signatures were validated indicating that the email was not altered.  Otherwise this property is set to 0.   (This property is only meaningful when the ReceivedSigned property is equal to 1.)
SignedBy
If the email was received digitally signed, this property contains the fields of the cert's SubjectDN.
For example:  US, 60187, Illinois, Wheaton, 1719 E Forest Ave, Chilkat Software, Inc., Chilkat Software, Inc.
It is like the DN (Distinguished Name), but without the AttrName= before each attribute.
SigningAlg
Selects the signature algorithm to be used when sending signed (PKCS7) email.  The default value is PKCS1-v1_5.  This can be set to RSASSA-PSS (or simply pss) to use the RSASSA-PSS signature scheme.
Note: This property only applies when signing with an RSA private key. It does not apply for ECC or DSA private keys.
SigningHashAlg
Selects the underlying hash algorithm used when sending signed (PKCS7) email.  Possible values are sha1, sha256, sha384, sha512, md5, and md2.
Size
The size in bytes of the email, including all parts and attachments.
Note: This property is only valid if the full email was downloaded. If only the header was downloaded, then this property will contain the size of just the header.
topSubject
The email subject.
topUidl
This is the unique ID assigned by the POP3 server. Emails can be retrieved or deleted from the POP3 server via the UIDL. The header field for this property is X-UIDL.
Important:  Emails downloaded via the IMAP protocol do not have UIDL's.  UIDL's are specific to the POP3 protocol.   IMAP servers use UID's  (notice the spelling difference -- UIDL vs. UID).  An email downloaded via the Chilkat IMAP component will contain a ckx-imap-uid header field that holds either an IMAP UID or sequence number.  If the email was downloaded (from IMAP) using a UID,then ckx-imap-uid contains a UID.  If the email was downloaded by sequence number, then it contains a sequence number (not unique and can change with a new session).   The ckx-imap-isUid header, which can have the value YES or NO, tells what ckx-imap-uid contains.
UncommonOptions
This is a catch-all property to be used for uncommon needs. This property defaults to the empty string, and should typically remain empty.
As of v9.5.0.79, the only possible value is:
- NO_FORMAT_FLOWED- Don't automatically add- format=flowedto any Content-Type header.
UnpackUseRelPaths
Applies to the UnpackHtml method.  If 1, then relative paths are used within the HTML for the links to the related files (images and style sheets) that were unpacked to the filesystem.  Otherwise absolute paths are used.   The default value is 1.
VerboseLogging
If set to 1, then the contents of LastErrorText (or LastErrorXml, or LastErrorHtml) may contain more verbose information. The default value is 0.  Verbose logging should only be used for debugging.  The potentially large quantity of logged information may adversely affect peformance.
Version
Methods
AddAttachmentBd
Adds an attachment using the contents of a BinData object. If contentType is empty, then the content-type will be inferred from the filename extension.
Returns 1 for success, 0 for failure.
AddAttachmentHeader
Adds or replaces a MIME header field in one of the email attachments. If the header field does not exist, it is added. Otherwise it is replaced.
AddBcc
Adds a recipient to the blind carbon-copy list. emailAddress is required, but friendlyName may be empty.
To add multiple BCC recipients, call this method once per recipient.
Returns 1 for success, 0 for failure.
AddCC
Adds a recipient to the carbon-copy list. emailAddress is required, but friendlyName may be empty.
To add multiple CC recipients, call this method once per recipient.
Returns 1 for success, 0 for failure.
AddDataAttachment
Adds an attachment directly from data in memory to the email.
Returns 1 for success, 0 for failure.
AddDataAttachment2
Adds an attachment to an email from in-memory data. Same as AddDataAttachment but allows the content-type to be specified.
Returns 1 for success, 0 for failure.
AddEncryptCert
Allows for certificates to be explicitly specified for sending encrypted email to one or more recipients. Call this method once per certificate to be used. The ClearEncryptCerts method may be called to clear the list of explicitly-specified certificates.
Note: It is possible to send encrypted email without explicitly specifying the certificates. On Windows computers, the registry-based Current-User and Local-Machine certificate stores are automatically searched for certs matching each of the recipients (To, CC, and BCC recipients).
Note: The SetEncryptCert method is equivalent to calling ClearEncryptCerts followed by AddEncryptCert.
Returns 1 for success, 0 for failure.
AddFileAttachment
Adds a file as an attachment to the email. Returns the MIME content-type of the attachment, which is inferred based on the filename extension.
Returns a zero-length WideString on failure
AddFileAttachment2
Same as AddFileAttachment, but the content type can be explicitly specified.
Returns 1 for success, 0 for failure.
AddHeaderField
Any standard or non-standard (custom) header field can be added to the email with this method. One interesting feature is that all header fields whose name begins with CKX- will not be included in the header when an email is sent. These fields will be included when saved to or loaded from XML. This makes it easy to include persistent meta-data with an email which your programs can use in any way it chooses.
Important: This method will replace an already-existing header field. To allow for adding duplicate header fields, call AddHeaderField2 (see below).
topAddHeaderField2
This method is the same as AddHeaderField, except that if the header field already exists, it is not replaced. A duplicate header will be added.
topAddHtmlAlternativeBody
Sets the HTML body of the email. Use this method if there will be multiple versions of the body, but in different formats, such as HTML and plain text. Otherwise, set the body by calling the SetHtmlBody method.
Returns 1 for success, 0 for failure.
AddiCalendarAlternativeBody
Adds an iCalendar (text/calendar) alternative body to the email. The icalContent contains the content of the iCalendar data. A sample is shown here:
BEGIN:VCALENDAR VERSION:2.0 PRODID:-//hacksw/handcal//NONSGML v1.0//EN BEGIN:VEVENT UID:uid1@example.com DTSTAMP:19970714T170000Z ORGANIZER;CN=John Doe:MAILTO:john.doe@example.com DTSTART:19970714T170000Z DTEND:19970715T035959Z SUMMARY:Bastille Day Party END:VEVENT END:VCALENDARThe methodName is the
method attribute used in the Content-Type header field in the alternative body.  For example, if set to REQUEST, then the alternative body's header would look like this:
Content-Type: text/calendar; method=REQUEST Content-Transfer-Encoding: base64
Returns 1 for success, 0 for failure.
topAddMultipleBcc
Adds multiple recipients to the blind carbon-copy list. The parameter is a string containing a comma separated list of full email addresses. Returns True if successful.
Returns 1 for success, 0 for failure.
AddMultipleCC
Adds multiple recipients to the carbon-copy list. The parameter is a string containing a comma separated list of full email addresses. Returns True if successful.
Returns 1 for success, 0 for failure.
topAddMultipleTo
Adds multiple recipients to the to list. The parameter is a string containing a comma separated list of full email addresses. Returns True if successful.
Returns 1 for success, 0 for failure.
topAddPfxSourceBd
Adds a PFX file to the object's list of sources for locating certificates and private keys during decryption or signing. To add multiple PFX sources, call this method for each file. bd should contain the bytes of a PFX file (also known as PKCS12 or .p12). The password is the password for the PFX.
Returns 1 for success, 0 for failure.
topAddPfxSourceData
Adds a PFX to the object's internal list of sources to be searched for certificates and private keys when decrypting. Multiple PFX sources can be added by calling this method once for each. (On the Windows operating system, the registry-based certificate stores are also automatically searched, so it is commonly not required to explicitly add PFX sources.)
The pfxBytes contains the bytes of a PFX file (also known as PKCS12 or .p12).
Returns 1 for success, 0 for failure.
AddPfxSourceFile
Adds a PFX file to the object's internal list of sources to be searched for certificates and private keys when decrypting. Multiple PFX files can be added by calling this method once for each. (On the Windows operating system, the registry-based certificate stores are also automatically searched, so it is commonly not required to explicitly add PFX sources.)
The pfxFilePath contains the bytes of a PFX file (also known as PKCS12 or .p12).
Returns 1 for success, 0 for failure.
topAddPlainTextAlternativeBody
Sets the plain-text body of the email. Use this method if there will be multiple versions of the body, but in different formats, such as HTML and plain text. Otherwise, simply set the Body property.
Returns 1 for success, 0 for failure.
AddRelatedBd
Adds a related item using the contents of a BinData object. Returns the Content-ID for the newly added relted item.
Returns a zero-length WideString on failure
AddRelatedBd2
Adds a related item using the contents of a BinData object.  The fileNameInHtml should be set to the filename/path/url used in the corresponding HTML IMG tag's src attribute.
Returns 1 for success, 0 for failure.
AddRelatedData
Adds the memory data as a related item to the email and returns the Content-ID. Emails formatted in HTML can include images with this call and internally reference the image through a cidhyperlink. (Chilkat Email.NET fully supports the MHTML standard.)
Returns a zero-length WideString on failure
AddRelatedData2
Adds a related item to the email from in-memory byte data. Related items are things such as images and style sheets that are embedded within an HTML email. They are not considered attachments because their sole purpose is to participate in the display of the HTML. This method differs from AddRelatedData in that it does not use or return a Content-ID. The filename argument should be set to the filename used in the HTML img tag's src attribute (if it's an image), or the URL referenced in an HTML link tag for a stylesheet.
topAddRelatedFile
Adds the contents of a file to the email and returns the Content-ID. Emails formatted in HTML can include images with this call and internally reference the image through a cid hyperlink. (Chilkat Email.NET fully supports the MHTML standard.)
Returns a zero-length WideString on failure
AddRelatedFile2
Adds a related item to the email from a file. Related items are things such as images and style sheets that are embedded within an HTML email. They are not considered attachments because their sole purpose is to participate in the display of the HTML. This method differs from AddRelatedFile in that it does not use or return a Content-ID. The filenameInHtml argument should be set to the filename used in the HTML img tag's src attribute (if it's an image), or the URL referenced in an HTML link tag for a stylesheet. The filenameOnDisk is the path in the local filesystem of the file to be added.
Note: Outlook.com will not properly display embedded HTMl images when the filenameInHtml includes a path part. Apparently, Outlook.com is only capable of correctly displaying images when the filenameInHtml is a only a filename. Other email clients, such as Mozilla Thunderbird, have no trouble when the filenameInHtml includes a path part.
Returns 1 for success, 0 for failure.
AddRelatedHeader
Adds or replaces a MIME header field in one of the email's related items. If the header field does not exist, it is added. Otherwise it is replaced.
topAddRelatedString
Adds a related item to the email. A related item is typically an image or style sheet referenced by an HTML tag within the HTML email body. The contents of the related item are passed str. nameInHtml specifies the filename that should be used within the HTML, and not an actual filename on the local filesystem. charset specifies the charset that should be used for the text content of the related item. Returns the content-ID generated for the added item.
Returns a zero-length WideString on failure
AddRelatedString2
Adds a related item to the email from an in-memory string. Related items are things such as images and style sheets that are embedded within an HTML email. They are not considered attachments because their sole purpose is to participate in the display of the HTML.  The filenameInHtml argument should be set to the filename used in the HTML img tag's src attribute (if it's an image), or the URL referenced in an HTML link tag for a stylesheet.  The charset argument indicates that the content should first be converted to the specified charset prior to adding to the email.  It should hava a value such as iso-8859-1, utf-8, Shift_JIS, etc.
AddStringAttachment
Adds an attachment directly from a string in memory to the email.
Returns 1 for success, 0 for failure.
AddStringAttachment2
Adds an attachment to an email. The path specifies the filename to be used for the attachment and is not an actual filename existing on the local filesystem. The content contains the text data for the attachment. The string will be converted to the charset specified in charset before being added to the email.
Note: Beginning in v9.5.0.48, the charset may be prepended with bom- or no-bom- to include or exclude the BOM (preamble) for charsets such as utf-16 or utf-8.  For example: no-bom-utf-8 or bom-utf-8.
Returns 1 for success, 0 for failure.
topAddTo
Adds a recipient to the to list. emailAddress is required, but friendlyName may be empty. Emails that have no To recipients will be sent to <undisclosed-recipients>.
To add multiple recipients, call this method once per TO recipient.
Returns 1 for success, 0 for failure.
AesDecrypt
Decrypts and restores an email message that was previously encrypted using AesEncrypt. The password must match the password used for encryption.
Returns 1 for success, 0 for failure.
topAesEncrypt
Encrypts the email body, all alternative bodies, all message sub-parts and attachments using 128-bit AES CBC encryption. Decrypting is achieved by calling AesDecrypt with the same password. The AesEncrypt/Decrypt methods use symmetric password-based AES encryption and greatly simplify sending and receiving encrypted emails because certificates and private keys are not used. However, the sending and receiving applications must both use Chilkat, and the password must be pre-known on both ends.
Returns 1 for success, 0 for failure.
topAppendToBody
Appends a string to the plain-text body.
topApplyFixups
Sometimes emails created by other software or systems are not formatted according to typical conventions. This method provides a means to automatically fix certain problems.
The fixups set to a comma-separated list of keywords that identify the fixups to be applied.  At the moment, there is only one fixup defined (FixRelated)  as described here:
- FixRelated: Fixes the email so that HTML related items (images for example) are properly located in the email MIME structure. This prevents them from being seen as attachments.
Returns 1 for success, 0 for failure.
topAspUnpack
Please see the examples at the following pages for detailed information:
Returns 1 for success, 0 for failure.
topAspUnpack2
Please see the examples at the following pages for detailed information:
Returns a zero-length byte array (as an OleVariant) on failure.
An empty array will have a VarArrayHighBound of -1 meaning 0 elements.
AttachEmail
Attaches copy of the email to this email object. The attached email will be encapsulated in an message/rfc822 sub-part.
Returns 1 for success, 0 for failure.
AttachMessage
Attaches a MIME message to the email object. The attached MIME will be encapsulated in an message/rfc822 sub-part.
Returns 1 for success, 0 for failure.
BEncodeBytes
Takes a byte array of multibyte (non-Unicode) data and returns a Unicode B-Encoded string.
Returns a zero-length WideString on failure
topBEncodeString
Takes a Unicode string, converts it to the charset specified in the 2nd parameter, B-Encodes the converted multibyte data, and returns the encoded Unicode string.
Returns a zero-length WideString on failure
topClear
Clears the email object of all information to the state as if the object was just created, which will have default headers such as Mime-Version, Date, Message-ID, Content-Type, Content-Transfer-Encoding, and X-Priority.
topClearBcc
Clears the list of blind carbon-copy recipients.
topClearCC
Clears the list of carbon-copy recipients.
topClearEncryptCerts
Clears the internal list of explicitly specified certificates to be used for this encrypted email.
topClearTo
Clears the list of to recipients.
ComputeGlobalKey2
Computes a global unique key for the email. The key is created by a digest-MD5 hash of the concatenation of the following:
messageID + CRLF + subject + CRLF + from + CRLF + date + CRLF + recipientAddrs
messageID contains the contents of the Message-ID header field.
subject contains the contents of the Subject header field, trimmed of whitespace from both ends, 
    where TAB chars are converted to SPACE chars, and internal whitespace is trimmed so that 
   no more than one SPACE char in a row exists.
from contains the lowercase FROM header email address.
date contains the contents of the DATE header field.
toAddrs contains lowercase TO and CC recipient email addresses, comma separated, with duplicates removed, and sorted 
    in ascending order.  The BCC addresses are NOT included.
(After calling this method, the LastErrorText property can be examined to see the string that was hashed.)
The 16-byte MD5 hash is returned as an encoded string.  The encoding determines the encoding:  base64, hex, url, etc.     If bFold is 1, then the 16-byte MD5 hash is folded to 8 bytes with an XOR to produce a shorter key.Returns a zero-length WideString on failure
topConvertInlineImages
Converts images embedded inline within HTML to multipart/related MIME parts referenced from the HTML by CID.
Returns 1 for success, 0 for failure.
CreateTempMht
Saves the email to a temporary MHT file so that a WebBrowser control can navigate to it and display it. If fileName is empty, a temporary filename is generated and returned. If fileName is non-empty, then it will be created or overwritten, and the input filename is simply returned.The MHT file that is created will not contain any of the email's attachments, if any existed. Also, if the email was plain-text, the MHT file will be saved such that the plain-text is converted to HTML using pre-formatted text (pre HTML tags) allowing it to be displayed correctly in a WebBrowser.
Returns a zero-length WideString on failure
topDropAttachments
Removes all attachments from the email.
topDropRelatedItem
A related item is typically an embedded image referenced from the HTML in the email via a CID hyperlink.  This method removes the Nth embedded image from the email.  Note: If the HTML tries to reference the removed image, it will be displayed as a broken image link.
DropRelatedItems
A related item is typically an embedded image referenced from the HTML in the email via a CID hyperlink.  This method removes all the embedded images from the email.
DropSingleAttachment
Drops a single attachment from the email. Returns True if successful.
Returns 1 for success, 0 for failure.
topGenerateFilename
Generates a unique filename for this email. The filename will be different each time the method is called.
Returns a zero-length WideString on failure
topGetAlternativeBody
Returns the Nth alternative body. The NumAlternatives property tells the number of alternative bodies present. Use the GetHtmlBody and GetPlainTextBody methods to easily get the HTML or plain text alternative bodies.
Returns a zero-length WideString on failure
topGetAlternativeBodyBd
Returns contents of the Nth alternative body to binData. The 1st alternative body is at index 0. This method should only be called when the NumAlternatives property has a value greater than 0.
Returns 1 for success, 0 for failure.
topGetAlternativeBodyByContentType
Returns the alternative body by content-type, such as text/plain, text/html, text/xml, etc.
Returns a zero-length WideString on failure
topGetAlternativeContentType
Returns the content type of the Nth alternative body. The NumAlternatives property tells the number of alternative bodies present.
Returns a zero-length WideString on failure
topGetAltHeaderField
Returns the value of a header field within the Nth alternative body's MIME sub-part.
Returns a zero-length WideString on failure
topGetAttachedEmail
GetAttachedMessageAttr
Returns a header field attribute value for  the Nth attached (embedded) email.  For example, to get the value of the name attribute in the Content-Type header for the 1st attached message:
Content-Type: message/rfc822; name="md75000024149.eml"then the method arguments should contain the values 0,
Content-Type, name.Returns a zero-length WideString on failure
topGetAttachedMessageFilename
Returns the filename of the Nth attached (embedded) email.  The filename is the filename attribute of the content-disposition header field found within the Nth message/rfc822 sub-part of the calling email object.
Important: The attached message filename is only present if the Content-Disposition header exists AND contains a filename attribute.  If questions arise, one could open the email in a text editor to examine the MIME sub-header for the attached message (where the Content-Type = message/rfc822).  For example, here is a sub-header that has a filename:
Content-Type: message/rfc822; name="GetAttachedMessageAttr.eml" Content-Transfer-Encoding: 7bit Content-Disposition: attachment; filename="GetAttachedMessageAttr.eml"Here is an attached message sub-header that does NOT have a filename:
Content-Type: message/rfc822 Content-Transfer-Encoding: 7bit Content-Disposition: attachment
Returns a zero-length WideString on failure
topGetAttachmentAttr
Returns a header field attribute value from the header field of the Nth attachment.
Returns a zero-length WideString on failure
topGetAttachmentBd
Copies an attachment's binary data into binData. The first attachment is at index 0.
Returns 1 for success, 0 for failure.
topGetAttachmentContentID
Returns the ContentID header field for the Nth attachment. The first attachment is at index 0.
Returns a zero-length WideString on failure
GetAttachmentContentType
Returns the Content-Type header field for the Nth attachment. Indexing of attachments begins at 0.
Returns a zero-length WideString on failure
GetAttachmentData
Retrieves an attachment's binary data for in-memory access.
Returns a zero-length byte array (as an OleVariant) on failure.
An empty array will have a VarArrayHighBound of -1 meaning 0 elements.
GetAttachmentFilename
Retrieves an attachment's filename.
Returns a zero-length WideString on failure
GetAttachmentHeader
Returns the value of a header field (by name) of an attachment.
Returns a zero-length WideString on failure
GetAttachmentSize
Returns the size (in bytes) of the Nth attachment. The 1st attachment is at index 0. Returns -1 if there is no attachment at the specified index.
GetAttachmentString
Retrieves an attachment's data as a String. All CRLF sequences will be translated to single newline characters.  The charset indicates how to interpret the bytes of the attachment.  For example, if the attachment is a text file using the utf-8 byte representation for characters, pass utf-8.
Returns a zero-length WideString on failure
topGetAttachmentStringCrLf
Retrieves an attachment's data as a String. All end-of-lines will be translated to CRLF sequences.
Returns a zero-length WideString on failure
topGetBcc
Returns a blind carbon-copy recipient's full email address.
Returns a zero-length WideString on failure
GetBccAddr
Returns the Nth BCC address (only the address part, not the friendly-name part).
Returns a zero-length WideString on failure
GetBccName
Returns the Nth BCC name (only the friendly-name part, not the address part).
Returns a zero-length WideString on failure
GetCC
Returns a carbon-copy recipient's full email address.
Returns a zero-length WideString on failure
GetCcAddr
Returns the Nth CC address (only the address part, not the friendly-name part).
Returns a zero-length WideString on failure
topGetCcName
Returns the Nth CC name (only the friendly-name part, not the address part).
Returns a zero-length WideString on failure
topGetDeliveryStatusInfo
If the email is a multipart/report, then it is a delivery status notification.  This method can be used to get individual pieces of information from the message/delivery-status part of the email.  This method should only be called if the IsMultipartReport method returns 1.
The fieldName should be set a string such as Final-Recipient, Status, Action, Reporting-MTA, etc.
Reporting-MTA: dns; XYZ.abc.nl Final-recipient: RFC822; someEmailAddr@doesnotexist123.nl Action: failed Status: 5.4.4 X-Supplementary-Info: < #5.4.4 smtp;554 5.4.4 SMTPSEND.DNS.NonExistentDomain; nonexistent domain>
Returns a zero-length WideString on failure
GetDigestEmail
Returns in email the Nth digest email contained within a multipart/digest. The 1st digest is at index 0. Use the NumDigests property to get the number of digests available.
Returns 1 for success, 0 for failure.
topGetDsnInfo
If the IsMultipartReport property indicates that the email is multipart/report, you can use this method to obtain the delivery status information, including the final recipients, in a JSON format that is easy to parse.
Returns 1 for success, 0 for failure.
GetFileContent
Reads a file and returns the contents. This is here purely for convenience.
Returns a zero-length byte array (as an OleVariant) on failure.
An empty array will have a VarArrayHighBound of -1 meaning 0 elements.
GetHeaderField
GetHeaderFieldName
Return the name of the Nth header field. The NumHeaderFields() method can be used to get the number of header fields. The GetHeaderField() method can be used to get the value of the field given the field name.
The 1st header field is at index 0. (All Chilkat indexing is 0-based.)
Returns a zero-length WideString on failure
GetHeaderFieldValue
Returns the value of the Nth header field. (Indexing begins at 0) The number of header fields can be obtained from the NumHeaderFields property.
The 1st header field is at index 0, the last header field is at index NumHeaderFields-1. (All Chilkat indexing is 0-based.)
Returns a zero-length WideString on failure
topGetHtmlBody
GetHtmlBodySb
Returns the body having the text/html content type.  If inlineImageData is 1, the related images found in the MIME are inlined as base64 directly within the returned HTML.  The HTML is returned in sb.
Returns 1 for success, 0 for failure.
GetImapUid
When email headers are downloaded from an IMAP server (using Chilkat IMAP), a ckx-imap-uid header field is added.  The content of this header is the UID or sequence number of the email on the IMAP server.   In addition, a ckx-imap-isUid header field is added, and this will have the value YES or NO.  If the value is YES, then ckx-imap-uid contains a UID, if the value is NO, then ckx-imap-uid contains the sequence number.
This method returns the UID if ckx-imap-uid exists and contains a UID, otherwise it returns 0xFFFFFFFF.
An application that wishes to download the full email would use this UID and then call the Chilkat IMAP object's FetchSingle or FetchSingleAsMime methods.
Note:If an email was downloaded from the IMAP server in a way such that the UID is not received, then there will be no ckx-imap-uid header field and this method would return 0xFFFFFFFF.  For example, if emails are downloaded by sequence numbers via the Imap.FetchSequence method, then UIDs are not used and therefore the email object will not contain this information.
GetMime
Return the email as MIME text containing the email header, body (or bodies), related items (if any), and all attachments
Returns a zero-length WideString on failure
GetMimeBd
Return the email as binary MIME containing the email header, body (or bodies), related items (if any), and all attachments. The MIME is appended to the existing contents (if any) of bindat.
Returns 1 for success, 0 for failure.
topGetMimeBinary
Returns the full MIME of an email.
Returns a zero-length byte array (as an OleVariant) on failure.
An empty array will have a VarArrayHighBound of -1 meaning 0 elements.
GetMimeSb
Return the email as MIME text containing the email header, body (or bodies), related items (if any), and all attachments. The MIME is appended to the existing contents (if any) of sb.
Returns 1 for success, 0 for failure.
GetNthBinaryPartOfType
Returns the binary bytes of the Nth MIME sub-part having a specified content type (such as application/pdf.   Indexing begins at 0.   Call GetNumPartsOfType to find out how many MIME sub-parts exist for any given content type.   If inlineOnly is 1, then only MIME sub-parts having a content-disposition of inline are included.   If excludeAttachments is 1, then MIME sub-parts having a content-disposition of attachment are excluded.
Note: If the email was downloaded as header-only, it will not contain all the parts of the full email. Also, if downloaded from IMAP excluding attachments, those parts that are the attachments will (of course) be missing.
Note: Beginning in v9.5.0.95, the contentType can be wildcarded.  For example, it is possible to specify text/*, or simply * to match any Content-Type.  
Note: Only non-multipart MIME parts are matched.
Returns a zero-length byte array (as an OleVariant) on failure.
An empty array will have a VarArrayHighBound of -1 meaning 0 elements.
GetNthBinaryPartOfTypeBd
Loads bd with the binary bytes of the Nth MIME sub-part matching the contentType, which can be an exact Content-Type such as application/pdf, or a wildcarded Content-Type such as application/*, or */*.     Indexing begins at 0.   Call GetNumPartsOfType to find out how many MIME sub-parts exist for any given content type.   If inlineOnly is 1, then only MIME sub-parts having a content-disposition of inline are included.   If excludeAttachments is 1, then MIME sub-parts having a content-disposition of attachment are excluded.
Note: If the email was downloaded as header-only, it will not contain all the parts of the full email. Also, if downloaded from IMAP excluding attachments, those parts that are the attachments will (of course) be missing.
Note: Beginning in v9.5.0.95, the contentType can be wildcarded.  For example, it is possible to specify text/*, or simply * to match any Content-Type.  
Note: Only non-multipart MIME parts are matched.
Returns 1 for success, 0 for failure.
GetNthContentType
Returns the Content-Type of the Nth MIME sub-part matching the specified contentType.  The contentType can be a Content-Type such as text/plain, or a wildcarded Content-Type such as text/*, or even just * to match all Content-Types. 
 If inlineOnly is 1, then only MIME sub-parts having a content-disposition of inline are included.   If excludeAttachments is 1, then MIME sub-parts having a content-disposition of attachment are excluded. 
Note: Only non-multipart content-types are matched.
Returns a zero-length WideString on failure
GetNthTextPartOfType
Returns the text of the Nth MIME sub-part having a specified content type (such as text/plain.   Indexing begins at 0.   Call GetNumPartsOfType to find out how many MIME sub-parts exist for any given content type.   If inlineOnly is 1, then only MIME sub-parts having a content-disposition of inline are included.   If excludeAttachments is 1, then MIME sub-parts having a content-disposition of attachment are excluded.
Note: If the email was downloaded as header-only, it will not contain all the parts of the full email. Also, if downloaded from IMAP excluding attachments, those parts that are the attachments will (of course) be missing.
Note: Beginning in v9.5.0.95, the contentType can be wildcarded.  For example, it is possible to specify text/*, or simply * to match any Content-Type.  
Note: Only non-multipart MIME parts are matched.
Returns a zero-length WideString on failure
GetNumPartsOfType
Returns the number of MIME sub-parts within the email having a specified content type (such as text/plain).   If inlineOnly is 1, then only MIME sub-parts having a content-disposition of inline are included.   If excludeAttachments is 1, then MIME sub-parts having a content-disposition of attachment are excluded.
Note: If the email was downloaded as header-only, it will not contain all the parts of the full email. Also, if downloaded from IMAP excluding attachments, those parts that are the attachments will (of course) be missing.
Note: Beginning in v9.5.0.95, the inlineOnly can be wildcarded.  For example, it is possible to specify text/*, or simply * to match any Content-Type.  
Note: Only non-multipart MIME parts are matched (i.e. leaf-node MIME parts that contain a text or binary body).
GetPlainTextBody
Returns the email body having the text/plain content type.
Returns a zero-length WideString on failure
topGetRelatedAttr
Returns a header field attribute value from the header field of the Nth related item.
Returns a zero-length WideString on failure
topGetRelatedContentID
Returns the content ID of a related item contained with the email. Related items are typically images and style-sheets embedded within HTML emails.
Returns a zero-length WideString on failure
GetRelatedContentLocation
Returns the Content-Location of a related item contained with the email. Related items are typically images and style-sheets embedded within HTML emails.
Returns a zero-length WideString on failure
GetRelatedContentType
Returns the content-type of the Nth related content item in an email message.
Returns a zero-length WideString on failure
GetRelatedData
Returns the content of a related item contained with the email. Related items are typically images and style-sheets embedded within HTML emails.
Returns a zero-length byte array (as an OleVariant) on failure.
An empty array will have a VarArrayHighBound of -1 meaning 0 elements.
GetRelatedFilename
Returns the filename of a related item contained with the email. Related items are typically images and style-sheets embedded within HTML emails.
Returns a zero-length WideString on failure
GetRelatedHeader
Returns the value of a header field (by name) of a related item.
Returns a zero-length WideString on failure
GetRelatedString
Returns the text with CR line-endings of a related item contained with the email. Related items are typically images and style-sheets embedded within HTML emails.
Returns a zero-length WideString on failure
topGetRelatedStringCrLf
Returns the text with CRLF line-endings of a related item contained with the email. Related items are typically images and style-sheets embedded within HTML emails.
Returns a zero-length WideString on failure
topGetReplacePattern
Returns a replacement pattern previously defined for mail-merge operations.
Returns a zero-length WideString on failure
GetReplaceString
Returns a replacement string for a previously defined pattern/replacement string pair. (This is a mail-merge feature.)
Note: This method was found to not be working correctly and is fixed in Chilkat v9.5.0.91.
Returns a zero-length WideString on failure
GetReplaceString2
Returns a replacement string for a previously defined pattern/replacement string pair. (This is a mail-merge feature.)
Returns a zero-length WideString on failure
GetReport
(See the NumReports property.) Returns the body content of the Nth report within a multipart/report email.
Multipart/report is a message type that contains data formatted for a mail server to read. It is split between a text/plain (or some other content/type easily readable) and a message/delivery-status, which contains the data formatted for the mail server to read.
It is defined in RFC 3462
Returns a zero-length WideString on failure
GetTo
Returns a to recipient's full email address.
Returns a zero-length WideString on failure
GetToAddr
Returns the Nth To address (only the address part, not the friendly-name part).
Returns a zero-length WideString on failure
topGetToName
Returns the Nth To name (only the friendly-name part, not the address part).
Returns a zero-length WideString on failure
topGetXml
Convert the email object to an XML document in memory
Returns a zero-length WideString on failure
topHasHeaderMatching
Returns 1 if the email has a header field with the specified fieldName with a value matching valuePattern.  Case sensitivity is controlled by caseSensitive.   The valuePattern may include 0 or more asterisk (wildcard) characters which match 0 or more of any character.
HasHtmlBody
Returns true if the email has an HTML body.
topHasPlainTextBody
Returns true if the email has a plain-text body.
topIsMultipartReport
LastDecryptCert
Returns in cert the certificate used to decrypt this email.
Returns 1 for success, 0 for failure.
topLastSignerCert
Returns the Nth certificate in index used to digitally sign this email. Signed emails are typically signed by a single signer, but it is possible to have multiple signers. The 1st signer is at index 0.
Returns 1 for success, 0 for failure.
topLinkedDomains
Extracts domain names from hyperlinks in an HTML email. Lowercase domains are appended to domains without creating duplicates.
Returns 1 for success, 0 for failure.
topLoadBodyFromFile
Sets the plain-text or HTML body from the contents of a file.   For an HTML file, the isHtml argument should be 1 (otherwise 0). The character encoding of the file, ,such as utf-8, ansi, etc. is specified by charset.
LoadEml
Loads a complete email from a .EML file. (EML files are simply RFC822 MIME text files.)
Note: This replaces the entire contents of the email object, including the To/CC recipients.
Returns 1 for success, 0 for failure.
topLoadTaskResult
Loads the email object from a completed asynchronous task.
Returns 1 for success, 0 for failure.
LoadXml
Loads an email with the contents of an XML email file.
Note: This replaces the entire contents of the email object, including the To/CC recipients.
Returns 1 for success, 0 for failure.
topLoadXmlString
Loads an email from an XML string (previously obtained by calling the GetXml method). The contents of the calling email object are erased and replaced with the email contained within the XML string.
Returns 1 for success, 0 for failure.
topMakeCopy
QEncodeBytes
Takes a byte array of multibyte (non-Unicode) data and returns a Unicode Q-Encoded string.
Returns a zero-length WideString on failure
topQEncodeString
Takes a Unicode string, converts it to the charset specified in the 2nd parameter, Q-Encodes the converted multibyte data, and returns the encoded Unicode string.
Returns a zero-length WideString on failure
topRemoveAttachedMessage
Removes the Nth message/rfc822 sub-part of the email. Indexing begins at 0.
topRemoveAttachedMessages
Removes all message/rfc822 sub-parts of the email object.
topRemoveAttachmentPaths
Removes path information from all attachment filenames.
topRemoveHeaderField
Removes by name all occurrences of a header field.
topRemoveHtmlAlternative
Removes the HTML body from the email (if an HTML body exists).
topRemovePlainTextAlternative
Removes the plain-text body from the email (if a plain-text body exists).
topSaveAllAttachments
Save all the attachments of an email to files in a directory specified by dirPath. The OverwriteExisting property controls whether existing files are allowed to be overwritten.
Note: Email attachment filenames can be renamed or modified prior to saving. The number of attachments is available in the NumAttachments property. An application can loop over the attachments to get the filename for each by calling GetAttachmentFilename(index). Each attachment's filename can be set by calling SetAttachmentFilename(index, newFilename).
Returns 1 for success, 0 for failure.
SaveAttachedFile
Saves the Nth email attachment to the directory specified by dirPath. The 1st attachment is at index 0. The OverwriteExisting property controls whether existing files are allowed to be overwritten.
Returns 1 for success, 0 for failure.
SaveEml
SaveRelatedItem
Saves the Nth related item to the directory specified by dirPath. (The 1st related item is at index 0) Related content items are typically image or style-sheets embedded within an HTML email. The OverwriteExisting property controls whether existing files are allowed to be overwritten.
Returns 1 for success, 0 for failure.
topSaveXml
SetAttachmentCharset
Sets the charset attribute of the content-type header field for a specified attachment. This can be used if the attachment is a text file that contains text in a non us-ascii charset such as Shift_JIS, iso-8859-2, big5, iso-8859-5, etc.
Returns 1 for success, 0 for failure.
topSetAttachmentDisposition
Set's an attachment's disposition.  The default disposition of an attachment is attachment.  This method is typically called to change the disposition to inline.  The 1st attachment is at index 0.
Returns 1 for success, 0 for failure.
topSetAttachmentFilename
Renames a email attachment's filename. The 1st attachment is at index 0.
Returns 1 for success, 0 for failure.
SetBinaryBody
Sets the main body of the email to binary content of any type.  The disposition can be an empty string, inline, or attachment.  If a filename is specified, the disposition must be non-empty because the filename is an attribute of the content-disposition header field.
Returns 1 for success, 0 for failure.
topSetBodyBd
This function sets the email's main body to binary content. bd contains the binary data. disposition specifies the disposition and can be an empty string, inline, or attachment. If filename is provided, disposition must be specified because filename is an attribute of the content-disposition header.
Returns 1 for success, 0 for failure.
topSetDecryptCert
Allows for a certificate to be explicity provided for decryption. When an email object is loaded via any method, such as LoadEml, SetFromMimeText, SetFromMimeBytes, etc., security layers (signatures and encryption) are automatically unwrapped. This method could be called prior to calling a method that loads the email.
Returns 1 for success, 0 for failure.
topSetDecryptCert2
Allows for a certificate and private key to be explicity specified for decryption. When an email object is loaded via any method, such as LoadEml, SetFromMimeText, SetFromMimeBytes, etc., security layers (signatures and encryption) are automatically unwrapped. Decryption requires a private key. On Windows-based systems, the private key is often pre-installed and nothing need be done to provide it because Chilkat will automatically find it and use it. However, if not on a Windows system, or if the private key was not pre-installed, then it can be provided by this method, or via the AddPfxSourceFile / AddPfxSourceData methods.
Returns 1 for success, 0 for failure.
SetDt
Sets the Date header field of the email to have the value of the date/time object provided.
Returns 1 for success, 0 for failure.
SetEdifactBody
Creates a typical email used to send EDIFACT messages. Does the following:
- Sets the email body to the EDIFACT message passed in message.
- Sets the Content-Transfer-Encoding to Base64.
- Set the Content-Type equal to application/EDIFACT.
- Sets the Content-Type header's name attribute to name.
- Sets the Content-Disposition equal to attachment.
- Sets the Content-Disposition's filenameattribute equal to filename.
- The EDIFACT message is converted to the charset indicated by charset, and encoded using Base64 in the email body.
SetEncryptCert
Set the encryption certificate to be used in encryption. Use the CreateCS, CertStore, and Cert classes to create a Cert object by either locating a certificate in a certificate store or loading one from a file.
Returns 1 for success, 0 for failure.
SetFromMimeBd
Loads an email with the MIME stored in a BinData object.
Note: This replaces the entire contents of the email object, including the To/CC recipients.
Returns 1 for success, 0 for failure.
topSetFromMimeBytes
Loads the email object with the mimeBytes.  If the email object already contained an email, it is entirely replaced.  The character encoding (such as utf-8, iso-8859-1, etc.)  of the bytes is automatically inferred from the content.  If for some reason it is not possible to determine the character encoding, the SetFromMimeBytes2 method may be called to explicitly specify the charset.
Returns 1 for success, 0 for failure.
topSetFromMimeBytes2
Loads the email object with the mimeBytes. If the email object already contained an email, it is entirely replaced.
The charset specifies the character encoding of the MIME bytes (such as utf-8, iso-8859-1, etc.).
Returns 1 for success, 0 for failure.
topSetFromMimeSb
Loads an email with the MIME stored in a StringBuilder object.
Note: This replaces the entire contents of the email object, including the To/CC recipients.
Returns 1 for success, 0 for failure.
SetFromMimeText
Loads an email with the contents of a .eml (i.e. MIME) contained in a string.
Note: This replaces the entire contents of the email object, including the To/CC recipients.
Returns 1 for success, 0 for failure.
topSetFromXmlText
Loads an email from an XML string.
Note: This replaces the entire contents of the email object, including the To/CC recipients.
Returns 1 for success, 0 for failure.
topSetHtmlBody
SetMbHtmlBody
Sets the HTML email body from a byte array containing character data in the specified character set. This method also updates the email content-typeheader to properly reflect the content type of the body.
Returns 1 for success, 0 for failure.
topSetMbPlainTextBody
Sets the plain-text email body from a byte array containing character data in the specified character set. This method also updates the email content-typeheader to properly reflect the content type of the body.
Returns 1 for success, 0 for failure.
topSetRelatedFilename
SetReplacePattern
Create a pattern/replacement-text pair for mail-merge. When the email is sent via the MailMan's SendEmail method, or any other mail-sending method, the patterns are replaced with the replacement strings during the sending process. To define multiple replacement patterns, simply call SetReplacePattern once per pattern/replacement string. (Note: The MailMan's RenderToMime method will also do pattern replacements. Methods such as SaveEml or GetMime do not replace patterns.)
Note: Replacement patterns may be placed in any header field, and in both HTML and plain-text email bodies.
Returns 1 for success, 0 for failure.
SetSigningCert
Set the certificate to be used in creating a digital signature. Use the CreateCS, CertStore, and Cert classes to create a Cert object by either locating a certificate in a certificate store or loading one from a file.
Returns 1 for success, 0 for failure.
SetSigningCert2
Explicitly sets the certificate and private key to be used for sending digitally signed email. If the certificate's private key is already installed on the computer, then one may simply call SetSigningCert because the Chilkat component will automatically locate and use the corresponding private key (stored in the Windows Protected Store). In most cases, if the digital certificate is already installed w/ private key on the computer, it is not necessary to explicitly set the signing certificate at all. The Chilkat component will automatically locate and use the certificate containing the FROM email address (from the registry-based certificate store where it was installed).
Returns 1 for success, 0 for failure.
topSetTextBody
Sets the body of the email and also sets the Content-Type header field of the contentType. If the email is already multipart/alternative, an additional alternative with the indicated Content-Type will be added. If an alternative with the same Content-Type already exists, it is replaced.
ToDsn
Creates a new Delivery Status Notification (DSN) email in the format specified by RFC 3464. The DSN email is generated in dsnEmail.
Returns 1 for success, 0 for failure.
ToForward
ToMdn
Creates a new MDN (Message Disposition Notification) email in message having the format as specified in RFC 3798.
Returns 1 for success, 0 for failure.
topToReply
Generates a reply email in reply with updated header and body fields to enable sending as a reply. Note: Attachments are excluded from the reply, but attached messages are included. To exclude attached messages, call RemoveAttachedMessages on the reply email object.
Returns 1 for success, 0 for failure.
topUnpackHtml
Unpacks an HTML email into an HTML file and related files (images and style sheets). The links within the HTML are updated to point to the files unpacked and saved to disk.
The unpackDir is the absolute or relative directory path where the HTML file should be written. The partsSubdir is the subdirectory beneath unpackDir where images and style sheets should be written. If partsSubdir does not already exist, it is automatically created.
For example, if unpackDir = C:/test, htmlFilename = myEmail.html, and partsSubdir = images, then C:/test/myEmail.html is created, and the related files are written into C:/test/images.
Note: The UnpackHtml method extracts images that are actually contained within the email itself.  If the HTML contains an IMG tag that just links to an image on the web (but the image data is not contained locally within the email), then the image is not unpacked (because it would need to be downloaded from the web).
Returns 1 for success, 0 for failure.
UnSpamify
Unobfuscates emails by undoing what spammers do to obfuscate email. It removes comments from HTML bodies and unobfuscates hyperlinked URLs.
topUnzipAttachments
Unzips and replaces any Zip file attachments with the expanded contents. As an example, if an email contained a single Zip file containing 3 GIF image files as an attachment, then after calling this method the email would contain 3 GIF file attachments, and the Zip attachment would be gone.If an email contains multiple Zip file attachments, each Zip is expanded and replaced with the contents.
Returns 1 for success, 0 for failure.
topUseCertVault
Adds an XML certificate vault to the object's internal list of sources to be searched for certificates and private keys when encrypting/decrypting or signing/verifying. Unlike the AddPfxSourceData and AddPfxSourceFile methods, only a single XML certificate vault can be used. If UseCertVault is called multiple times, only the last certificate vault will be used, as each call to UseCertVault will replace the certificate vault provided in previous calls.
Returns 1 for success, 0 for failure.
topZipAttachments
Replaces all the attachments of an email with a single Zip file attachment having the filename specified.
Returns 1 for success, 0 for failure.
topDeprecated
BounceAddress
This property is deprecated and applications should use the MailMan.SmtpMailFrom property instead.
Clone
This method is deprecated.  Applications should instead call MakeCopy.
Creates and returns an identical copy of the Email object.
Returns nil on failure
CreateDsn
This method is deprecated.  Applications should instead call ToDsn.
Creates a new DSN (Delivery Status Notification) email having the format as specified in RFC 3464. See the example (below) for more detailed information.
Returns nil on failure
CreateForward
This method is deprecated.  Applications should instead call ToForward.
Returns a copy of the Email object with the body and header fields changed so that the newly created email can be forwarded. After calling CreateForward, simply add new recipients to the created email, and call MailMan.SendEmail.
Returns nil on failure
CreateMdn
This method is deprecated.  Applications should instead call ToMdn.
Creates a new MDN (Message Disposition Notification) email having the format as specified in RFC 3798. See the example (below) for more detailed information.
Returns nil on failure
CreateReply
This method is deprecated.  Applications should instead call ToReply.
Returns a copy of the Email object with the body and header fields changed so that the newly created email can be sent as a reply. After calling CreateReply, simply prepend additional information to the body, and call MailMan.SendEmail.
Note: Attachments are not included in the returned reply email. However, attached messages are included. If an application does not wish to include the attached messages in a reply email, they can be removed by calling RemoveAttachedMessages on the reply email object.
Returns nil on failure
FindIssuer
This method is deprecated.  Applications can instead call the certificate object's GetIssuer method.
Digitally signed and/or encrypted emails are automatically unwrapped when received from a POP3 or IMAP server, or when loaded from any source such as a MIME string, in-memory byte data, or a .eml file.   The results of the signature verification / decryption are stored in the properties such as ReceivedSigned, ReceivedEncrypted, SignaturesValid, etc.  The signing certificate can be obtained via the GetSigningCert function.  If the signature contained more certificates in the chain of authentication, this method provides a means to access them.
During signature verification, the email object collects the certs found in the signature and holds onto them internally.  To get the issuing certificate of the signing certificate, call this method passing the cert returned by GetSigningCert.  If the issuing cert is available, it is returned.  Otherwise nil is returned.  If the cert passed in is the root (i.e. a self-signed certificate), then the cert object returned is a copy of the cert passed in.  
To traverse the chain  to the root, one would  write a loop that on first iteration passes the cert returned by GetSignedByCert (not GetSignerCert), and then on each subsequent iteration passes the cert from the previous iteration.  The loop would exit when a cert is returned that has the same SubjectDN and SerialNumber as what was passed in (or when FindIssuer returns nil).
Returns nil on failure
GetAttachedMessage
This method is deprecated.  Applications should instead call GetAttachedEmail.
Returns an embedded message/rfc822 subpart as an email object.  (Emails are embedded as message/rfc822 subparts by some mail clients when forwarding an email.)  This method allows the original email to be accessed.
Returns nil on failure
GetDigest
This method is deprecated.  Applications should instead call GetDigestEmail.
Returns an digest contained within a multipart/digest as an email object. The 1st digest is at index 0. Use the NumDigests property to get the number of digests available.
Returns nil on failure
GetDsnFinalRecipients
This method is deprecated.  Applications should instead call GetDsnInfo.
If the email is a multipart/report, then it is a delivery status notification.  This method can be used to get Final-Recipient values from the message/delivery-status part of the email.  This method should only be called if the IsMultipartReport method returns 1.
Returns nil on failure
GetDt
This method is deprecated.  Applications should instead use the EmailDateStr property.
Returns the date/time found in the Date header field as a date/time object.
Returns nil on failure
GetEncryptCert
GetEncryptedByCert
This method is deprecated.  Applications should instead call LastDecryptCert to get the certificate used to decrypt this email.
Returns the certificate associated with a received encrypted email.
Returns nil on failure
GetLinkedDomains
This method is deprecated.  Applications should instead call LinkedDomains.
Parses an HTML email and returns the set of domain names that occur in hyperlinks within the HTML body.
Returns nil on failure
GetSignedByCert
This method is deprecated.  Applications should instead call LastSignerCert to get the certificate used to sign this email.
Return the certificate used to digitally sign this email.
Returns nil on failure
GetSignedByCertChain
This method is deprecated.  Applications can get the cert chain by calling LastSignerCert to get the certificate object, and then get the certificate chain from the certificate object.
Return the full certificate chain of the certificate used to digitally sign this email.
Returns nil on failure
GetSigningCert
Return the certificate that will be used to digitally sign this email. This is the cerficate that was previously set by calling the SetSigningCert method.
Returns nil on failure