Mime PureBasic Reference Documentation
Mime
Current Version: 11.1.0
Chilkat MIME allows you to easily create and manipulate MIME and S/MIME messages from within your applications.
Object Creation
obj.i = CkMime::ckCreate()
; Make sure to dispose of the object when finished like this:
CkMime::ckDispose(obj);
Properties
Boundary
Declare setCkBoundary(obj.i, value.s)
The boundary string for a multipart MIME message.
It is the value of the boundary attribute of the Content-Type header field. For example, if the Content-Type header is this:
Content-Type: multipart/mixed; boundary="------------080707010302060306060800"then the value of the Boundary property is "------------080707010302060306060800".
When building multipart MIME messages, the boundary is automatically generated by methods such as NewMultipartMixed, to be a unique and random string, so explicitly setting the boundary is usually not necessary.
Charset
Declare setCkCharset(obj.i, value.s)
The value of the charset attribute of the Content-Type header field.  For example, if the Content-Type header is this:
Content-Type: text/plain; charset="iso-8859-1"then the value of the Charset property is
iso-8859-1.CmsOptions
Declare setCkCmsOptions(obj.i, value.s)
A JSON string for controlling extra CMS (PKCS7) signature and validation options.
topContentType
Declare setCkContentType(obj.i, value.s)
The MIME content type, such as text/plain, text/html, image/gif, multipart/alternative, multipart/mixed, etc.
It is the value of the Content-Type header field, excluding any attributes. For example, if the Content-Type header is this:
Content-Type: multipart/mixed; boundary="------------080707010302060306060800"then the value of the ContentType property is
multipart/mixed.CurrentDateTime
DebugLogFilePath
Declare setCkDebugLogFilePath(obj.i, value.s)
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.
Disposition
Declare setCkDisposition(obj.i, value.s)
The value of the Content-Disposition header field, excluding any attributes. For example, if the Content-Disposition header is this:
Content-Disposition: attachment; filename="starfish.gif"then the value of the Disposition property is
attachment.Encoding
Declare setCkEncoding(obj.i, value.s)
The value of the Content-Transfer-Encoding header field.  Typical values are base64, quoted-printable, 7bit, 8bit, binary, etc.  For example, if the Content-Transfer-Encoding header is this:
Content-Transfer-Encoding: base64then the value of the Encoding property is
base64.
top
Filename
Declare setCkFilename(obj.i, value.s)
The value of the filename attribute of the Content-Disposition header field.  For example, if the Content-Disposition header is this:
Content-Disposition: attachment; filename="starfish.gif"then the value of the Filename property is
starfish.gif.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
Declare setCkLastMethodSuccess(obj.i, value.i)
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.
Micalg
Declare setCkMicalg(obj.i, value.s)
The value of the micalg attribute of the Content-Type header field.  For example, if the Content-Type header is this:
Content-Type: multipart/signed; protocol="application/x-pkcs7-signature"; micalg=sha1; boundary="------------ms000908010507020408060303"then the value of the Micalg property is
sha.
Note:  The micalg attribute is only present in PKCS7 signed MIME.   Setting the Micalg property has the effect of choosing the hash algorithm used w/ signing.  Possible choices are sha1, md5, sha256, sha384, and sha512.    However, it is preferable to set the signing hash algorithm by setting the SigningHashAlg property instead.
Name
Declare setCkName(obj.i, value.s)
The value of the name attribute of the Content-Type header field.  For example, if the Content-Type header is this:
Content-Type: image/gif; name="starfish.gif"then the value of the Name property is
starfish.gif.NumDecryptCerts
The number of certificates found when decrypting S/MIME. This property is set after UnwrapSecurity is called.
topNumHeaderFields
The number of header fields. Header field names and values can be retrieved by index (starting at 0) by calling GetHeaderFieldName and GetHeaderFieldValue.
topNumParts
MIME messages are composed of parts in a tree structure. The NumParts property contains the number of direct children. To traverse an entire MIME tree, one would recursively descend the tree structure by iterating from 0 to NumParts-1, calling GetPart to get each direct child MIME object. The traversal would continue by iterating over each child's parts, and so on.
topNumSignerCerts
The number of certificates found when verifying signature(s). This property is set after UnwrapSecurity is called.
topOaepHash
Declare setCkOaepHash(obj.i, value.s)
Selects the hash algorithm for use within OAEP padding when encrypting MIME using RSAES-OAEP.  The valid choices are sha1, sha256, sha384, sha512,
OaepMgfHash
Declare setCkOaepMgfHash(obj.i, value.s)
Selects the MGF hash algorithm for use within OAEP padding when encrypting MIME using RSAES-OAEP.  The valid choices are sha1, sha256, sha384, sha512,    The default is sha1.
OaepPadding
Declare setCkOaepPadding(obj.i, value.i)
Selects the RSA encryption scheme when encrypting MIME.  The default value is 0, which selects RSAES_PKCS1-V1_5.   If set to 1, then RSAES_OAEP is used.
Pkcs7CryptAlg
Declare setCkPkcs7CryptAlg(obj.i, value.s)
When the MIME is encrypted (using PKCS7 public-key encryption), this selects the underlying symmetric encryption algorithm. Possible values are: aes, des, 3des, and rc2.   The default value is aes.
Pkcs7KeyLength
Declare setCkPkcs7KeyLength(obj.i, value.i)
When the MIME is 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.
Protocol
Declare setCkProtocol(obj.i, value.s)
The value of the protocol attribute of the Content-Type header field.  For example, if the Content-Type header is this:
Content-Type: multipart/signed; protocol="application/x-pkcs7-signature"; micalg=sha1; boundary="------------ms000908010507020408060303"then the value of the Protocol property is
application/x-pkcs7-signature.
top
SigningAlg
Declare setCkSigningAlg(obj.i, value.s)
Selects the signature algorithm to be used when creating signed (PKCS7/CMS) MIME.  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.
Also: This property does not get set when a signature is verified. It is only used to specify the algorithm when creating a signature. The LastJsonData method can be used to get information about the verified signature(s).
SigningHashAlg
Declare setCkSigningHashAlg(obj.i, value.s)
Selects the underlying hash algorithm used when creating signed (PKCS7) MIME.  Possible values are sha1, sha256, sha384, sha512, md5, and md2.
Note: This property does not get set when a signature is verified. It is only used to specify the algorithm when creating a signature. The LastJsonData method can be used to get information about the verified signature(s).
topUncommonOptions
Declare setCkUncommonOptions(obj.i, value.s)
This is a catch-all property to be used for uncommon needs. This property defaults to the empty string and should typically remain empty.
topUnwrapExtras
Declare setCkUnwrapExtras(obj.i, value.i)
Controls whether extra (informative) header fields are added to the MIME message when unwrapping security.
UseMmDescription
Declare setCkUseMmDescription(obj.i, value.i)
Controls whether the boilerplate text This is a multi-part message in MIME format. is used as the body content of a multipart MIME part.
UseXPkcs7
Declare setCkUseXPkcs7(obj.i, value.i)
If 1, then the Content-Type header fields created by Chilkat will use x-pkcs7 instead of simply pkcs7 .  For example:
Content-Type: multipart/signed; boundary="----=_NextPart_af8_0422_dbec3a60.7178e470"; protocol="application/x-pkcs7-signature"; micalg=sha1 or Content-Type: application/x-pkcs7-mime; name="smime.p7m"If
0, then the pcks7 is used.  For example:
Content-Type: multipart/signed; boundary="----=_NextPart_af8_0422_dbec3a60.7178e470"; protocol="application/pkcs7-signature"; micalg=sha1 or Content-Type: application/pkcs7-mime; name="smime.p7m"The default value of this property is
1, meaning that x- is used by default.
top
VerboseLogging
Declare setCkVerboseLogging(obj.i, value.i)
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
AddContentLength
Computes the size of the MIME body and adds a Content-Length header field with the computed value. If the MIME body is non-multipart, the Content-Length is just the size of the content. If the MIME is multipart, then the Content-Length is the sum of all the sub-parts. Calling this method more than once causes the Content-Length header to be re-computed and updated.
AddDecryptCert
Makes a certificate available for decrypting if needed by methods that decrypt, such as UnwrapSecurity. This method may be called multiple times to make more than one certificate (and it's private key) available. Alternative methods for making certificates available are UseCertVault, AddPfxSourceFile, and AddPfxSourceData.
Returns 1 for success, 0 for failure.
topAddDetachedSignature
Signs the message using the certificate provided. If successful, the message is converted to multipart/signed and the original message will be contained in the first sub-part.
Returns 1 for success, 0 for failure.
AddDetachedSignature2
Same as AddDetachedSignature, except an extra argument is provided to control whether header fields from the calling MIME object are transferred to the content part of the multipart/signed object. This method transforms the calling object into a multipart/signed MIME with two sub-parts. The first contains the original content of the calling object, and the second contains the digital signature.
Returns 1 for success, 0 for failure.
topAddDetachedSignaturePk
Adds a detached signature using a certificate and it's associated private key. This method would be used when the private key is external to the certificate -- for example, if a PFX/P12 file is not used, but instead a pair of .cer and .pem files are used (one for the certificate and one for the associated private key).
Returns 1 for success, 0 for failure.
AddDetachedSignaturePk2
Same as AddDetachedSignaturePk, except an extra argument is provided to control whether header fields from the calling MIME object are transferred to the content part of the multipart/signed object. This method transforms the calling object into a multipart/signed MIME with two sub-parts. The first contains the original content of the calling object, and the second contains the digital signature.
Returns 1 for success, 0 for failure.
topAddEncryptCert
Adds a certificate to the object's internal list of certificates to be used when the EncryptN method is called. (See the EncryptN method for more information.) The internal list may be cleared by calling ClearEncryptCerts.
Returns 1 for success, 0 for failure.
topAddHeaderField
Adds a header field to the MIME.
Returns 1 for success, 0 for failure.
AddPfxSourceBd
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 to the PFX.
Returns 1 for success, 0 for failure.
topAddPfxSourceFile
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.
topAppendPart
Appends a MIME message to the sub-parts of this message. Arbitrarily complex messages with unlimited nesting levels can be created. If the calling Mime object is not already multipart, it is automatically converted to multipart/mixed first.
Returns 1 for success, 0 for failure.
AppendPartFromFile
Loads a file and creates a Mime message object using the file extension to determine the content type, and adds it as a sub-part to the calling object.
Returns 1 for success, 0 for failure.
topAsnBodyToXml
When the body of a MIME part contains PKCS7 (ASN.1 in DER format, base64-encoded), this method can be used to convert the ASN.1 to an XML format for inspection. Here is an example of how an ASN.1 body might look:
Content-Type: application/x-pkcs7-mime; name="smime.p7m"; smime-type="signed-data" Content-Transfer-Encoding: base64 Content-Disposition: attachment; filename="smime.p7m" MIIXXAYJKoZIhvcNAQcCoIIXTTCCF0kCAQExCzAJBgUrDgMCGgUAMFoGCSqGSIb3DQEHAaBNBEtD b250ZW50LVR5cGU6IHRleHQvcGxhaW4NCkNvbnRlbnQtVHJhbnNmZXItRW5jb2Rpbmc6IDdiaXQN Cg0KdGhpcyBpcyBhIHRlc3SgghI/MIIE3jCCA8agAwIBAgICAwEwDQYJKoZIhvcNAQEFBQAwYzEL ...The XML produced would look something like this:
<?xml version="1.0" encoding="utf-8" ?>
<sequence>
    <oid>1.2.840.113549.1.7.2</oid>
    <contextSpecific tag="0" constructed="1">
        <sequence>
            <int>01</int>
            <set>
                <sequence>
                    <oid>1.3.14.3.2.26</oid>
                    <null />
                </sequence>
            </set>
            <sequence>
                <oid>1.2.840.113549.1.7.1</oid>
                <contextSpecific tag="0" constructed="1">
...
Returns an empty string on failure. Use the LastMethodSuccess property to check for success.
topClearEncryptCerts
Clears the internal list of certificates added by previous calls to the AddEncryptCert method. (See the EncryptN method for information about encrypting using multiple certificates.)
topContainsEncryptedParts
Returns 1 if the MIME message contains encrypted parts.
Note: This method examines the MIME as-is. If UnwrapSecurity is called and it is successful, then the MIME should no longer contain encrypted parts, and this method would return 0.
Note:  If a signed MIME message is then encrypted, then it is not possible to know that the MIME is both encrypted and signed until UnwrapSecurity is called.  (In other words, it is not possible to know the contents of the encrypted MIME until it is decrypted.) Therefore, the ContainsSignedParts method would return 0.
ContainsSignedParts
Returns 1 if the MIME message contains signed parts.
Note: This method examines the MIME as-is. If UnwrapSecurity is called and it is successful, then the MIME should no longer contain signed parts, and this method would return 0.
Note:  If a signed MIME message is then encrypted, then it is not possible to know that the MIME is both encrypted and signed until UnwrapSecurity is called.  (In other words, it is not possible to know the contents of the encrypted MIME until it is decrypted.) Therefore, the ContainsSignedParts method would return 0.
Note: The same concept also applies to opaque signatures, such as with the MIME produced by calling ConvertToSigned.
Convert8Bit
Changes the content-transfer-encoding to base64 for all 8bit or binary MIME subparts.  This allows for the MIME to be exported as a string via the GetMime method.
ConvertToMultipartAlt
Converts existing MIME to a multipart/alternative. This is accomplished by creating a new outermost multipart/alternative MIME part. The existing MIME is moved into the 1st (and only) sub-part of the new multipart/alternative enclosure. Header fields from the original top-level MIME part are transferred to the new top-level multipart/alternative header, except for Content-Type, Content-Transfer-Encoding, and Content-Disposition. For example, the following simple plain-text MIME is converted as follows:
Original:
MIME-Version: 1.0 Date: Sun, 11 Aug 2013 11:18:44 -0500 Message-ID: <D105FA9A2B5F34E253C6E255D58247D26F8BD724@CHILKAT13> Content-Type: text/plain Content-Transfer-Encoding: quoted-printable X-Priority: 3 (Normal) Subject: this is the subject. From: "Chilkat Software" <support@chilkatsoft.com> To: "Chilkat Sales" <sales@chilkatsoft.com> This is the plain-text body.
After Converting:
MIME-Version: 1.0 Date: Sun, 11 Aug 2013 11:18:44 -0500 Message-ID: <D105FA9A2B5F34E253C6E255D58247D26F8BD724@CHILKAT13> X-Priority: 3 (Normal) Subject: this is the subject. From: "Chilkat Software" <support@chilkatsoft.com> To: "Chilkat Sales" <sales@chilkatsoft.com> Content-Type: multipart/alternative; boundary="------------040101040804050401050400_.ALT" --------------040101040804050401050400_.ALT Content-Type: text/plain Content-Transfer-Encoding: quoted-printable This is the plain-text body. --------------040101040804050401050400_.ALT--
Returns 1 for success, 0 for failure.
topConvertToMultipartMixed
Converts existing MIME to a multipart/mixed. This is accomplished by creating a new outermost multipart/mixed MIME part. The existing MIME is moved into the 1st (and only) sub-part of the new multipart/mixed enclosure. Header fields from the original top-level MIME part are transferred to the new top-level multipart/mixed header, except for Content-Type, Content-Transfer-Encoding, and Content-Disposition. For example, the following simple plain-text MIME is converted as follows:
Original:
MIME-Version: 1.0 Date: Sun, 11 Aug 2013 11:27:04 -0500 Message-ID: <B43DAF999B38BFE2C7240D86E691B8628D9D0BF4@CHILKAT13> Content-Type: text/plain Content-Transfer-Encoding: quoted-printable X-Priority: 3 (Normal) Subject: this is the subject. From: "Chilkat Software" <support@chilkatsoft.com> To: "Chilkat Sales" <sales@chilkatsoft.com> This is the plain-text body.
After Converting:
MIME-Version: 1.0 Date: Sun, 11 Aug 2013 11:27:04 -0500 Message-ID: <B43DAF999B38BFE2C7240D86E691B8628D9D0BF4@CHILKAT13> X-Priority: 3 (Normal) Subject: this is the subject. From: "Chilkat Software" <support@chilkatsoft.com> To: "Chilkat Sales" <sales@chilkatsoft.com> Content-Type: multipart/mixed; boundary="------------050508060709030908040207" --------------050508060709030908040207 Content-Type: text/plain Content-Transfer-Encoding: quoted-printable This is the plain-text body. --------------050508060709030908040207--
Returns 1 for success, 0 for failure.
ConvertToSigned
Digitally signs a MIME message. The MIME is converted to an application/x-pkcs7-mime which is a PKCS7 signature that includes both the original MIME message and the signature. This is different than AddDetachedSignature, where the signature is appended to the MIME.
Note: This is commonly referred to as an opaque signature.
Returns 1 for success, 0 for failure.
ConvertToSignedPk
Digitally signs the MIME to convert it to an opaque signed message using a certificate and it's associated private key.  This method would be used when the private key is external to the certificate -- for example, if a PFX/P12 file is not used, but instead a pair of .cer and .pem files are used (one for the certificate and one for the associated private key).
Returns 1 for success, 0 for failure.
Decrypt
Decrypts PKCS7 encrypted MIME (also known as S/MIME). Information about the certificates required for decryption is always embedded within PKCS7 encrypted MIME. This method will automatically find and use the certificate + private key required from three possible sources:
- PFX files that were provided in one or more calls to AddPfxSourceData or AddPfxSourceFile.
- Certificates found in an XML certificate vault provided by calling the UseCertVault method.
- (On Windows systems) Certificates found in the system's registry-based certificate stores.
Returns 1 for success, 0 for failure.
Decrypt2
The same as Decrypt, but useful when the certificate and private key are available in separate files (as opposed to a single file such as a .pfx/.p12).
Returns 1 for success, 0 for failure.
DecryptUsingCert
Decrypts PKCS7 encrypted MIME (also known as S/MIME) using a specific certificate.
Returns 1 for success, 0 for failure.
DecryptUsingPfxFile
Decrypts MIME using a specific PFX file (also known as PKCS12) as the source for any required certificates and private keys. (Note: .pfx and .p12 files are both PKCS12 format.)
Returns 1 for success, 0 for failure.
Encrypt
Encrypts the MIME to create PKCS7 encrypted MIME. A digital certificate (which always contains a public-key) is used to encrypt.
Returns 1 for success, 0 for failure.
EncryptN
Encrypt MIME using any number of digital certificates. Each certificate to be used must first be added by calling AddEncryptCert (once per certificate). See the example code below:
Returns 1 for success, 0 for failure.
GetBodyBd
Returns the body of the MIME message in a BinData object.
Returns 1 for success, 0 for failure.
GetBodyDecoded
Returns the body of the MIME message as a string. The body is automatically converted from its encoding type, such as base64 or quoted-printable, before being returned.
Returns an empty string on failure. Use the LastMethodSuccess property to check for success.
GetBodyEncoded
Returns the body of the MIME message as a String. The body is explicitly not decoded from it's encoding type, so if it was represented in Base64, you will get the Base64 encoded body, as an example.
Returns an empty string on failure. Use the LastMethodSuccess property to check for success.
GetEntireBody
Returns the entire MIME body, including all sub-parts.
Returns an empty string on failure. Use the LastMethodSuccess property to check for success.
GetEntireHead
Returns the MIME header.
Returns an empty string on failure. Use the LastMethodSuccess property to check for success.
GetHeaderField
Returns the value of a MIME header field. fieldName is case-insensitive.
Returns an empty string on failure. Use the LastMethodSuccess property to check for success.
GetHeaderFieldAttribute
Parses a MIME header field and returns the value of an attribute. MIME header fields w/ attributes are formatted like this:
Header-Name: value; attrName1="value1"; attrName2="value2"; .... attrNameN="valueN"Semi-colons separate attribute name=value pairs. The Content-Type header field often contains attributes. Here is an example:
Content-Type: multipart/signed; protocol="application/x-pkcs7-signature"; micalg=SHA1; boundary="----=_NextPart_000_0000_01CB03E4.D0BAF010"In the above example, to access the value of the
protocol attribute, call GetHeaderFieldAttribute(Content-Type, protocol);Returns an empty string on failure. Use the LastMethodSuccess property to check for success.
GetHeaderFieldName
Returns the Nth MIME header field name.
Returns an empty string on failure. Use the LastMethodSuccess property to check for success.
topGetHeaderFieldValue
Returns the Nth MIME header field value.
Returns an empty string on failure. Use the LastMethodSuccess property to check for success.
topGetLastJsonData
Provides information about what transpired in the last method called on this object instance. For many methods, there is no information. However, for some methods, details about what occurred can be obtained by getting the LastJsonData right after the method call returns. For example, after calling UnwrapSecurity, the LastJsonData will return JSON with details about the algorithms used for signature verification and decryption.
topGetMime
Returns a string containing the complete MIME message, including all sub-parts.
Returns an empty string on failure. Use the LastMethodSuccess property to check for success.
topGetMimeBd
Appends the MIME to a BinData object.
Returns 1 for success, 0 for failure.
GetMimeSb
Appends the MIME to a StringBuilder object.
Returns 1 for success, 0 for failure.
GetSignatureSigningTimeStr
Returns the signature signing date/time for the Nth signature. The number of signatures (i.e. signer certs) is indicated by the NumSignerCerts property. The HasSignatureSigningTime method may be called to determine if a signature timestamp is available. The index of the 1st signature signing time is 0. The date/time is returned in RFC822 string format.
Returns an empty string on failure. Use the LastMethodSuccess property to check for success.
topGetStructure
Returns  a string summarizing the MIME structure.   The output format is specified by fmt and can be text or xml.
Returns an empty string on failure. Use the LastMethodSuccess property to check for success.
GetXml
Converts the MIME (or S/MIME) message to XML and returns the XML as a string.
Returns an empty string on failure. Use the LastMethodSuccess property to check for success.
topHasSignatureSigningTime
Returns 1 if the Nth signature included a timestamp that recorded the signing time.  The number of signatures (i.e. signer certs) is indicated by the NumSignerCerts property.  (In most cases, the number of signer certs is 1.)   The signing time can be obtained via the GetSignatureSigningTime or GetSignatureSigningTimeStr methods.   The index of the 1st signature signing time is 0.
IsApplicationData
Return 1 if the MIME message contains application data, otherwise returns 0.
IsAttachment
Return 1 if this MIME message is an attachment, otherwise returns 0.   A MIME message is considered an attachment if the Content-Disposition header field contains the value attachment.
IsAudio
Return 1 if the MIME message contains audio data, otherwise returns 0.
IsEncrypted
Returns 1 if the MIME message is PKCS7 encrypted, otherwise returns 0.
IsHtml
Return 1 if the MIME body is HTML, otherwise returns 0.
IsImage
Return 1 if the MIME message contains image data, otherwise returns 0.
IsMultipart
Return 1 if the MIME message is multipart (multipart/mixed, multipart/related, multipart/alternative, etc.), otherwise returns 0.
IsMultipartAlternative
Return 1 if the MIME message is multipart/alternative, otherwise returns 0.
IsMultipartMixed
Return true if the MIME message is multipart/mixed, otherwise returns 0.
IsMultipartRelated
Return 1 if the MIME message is multipart/related, otherwise returns 0.
IsPlainText
Return 1 if the MIME message body is plain text, otherwise returns 0.
IsSigned
Return 1 if the MIME message is PKCS7 digitally signed, otherwise returns 0.
IsText
Return 1 if the MIME message body is any text content type, such as text/plain, text/html, text/xml, etc., otherwise returns 0.
IsVideo
Return 1 if the MIME message contains video data, otherwise returns 0.
IsXml
Return 1 if the MIME message body is XML, otherwise returns 0.
LastDecryptCert
Returns the Nth certificate found when decrypting. The NumDecryptCerts property contains the number of certificates.
Returns 1 for success, 0 for failure.
topLastSignerCert
Returns in cert the Nth digital certificate used to sign the MIME message. Indexing begins at 0.
Returns 1 for success, 0 for failure.
topLoadMime
Discards the current contents of the MIME object and loads a new MIME message from a string.
Returns 1 for success, 0 for failure.
topLoadMimeBd
Discards the current contents of the MIME object and loads a new MIME message from a BinData object.
Returns 1 for success, 0 for failure.
topLoadMimeFile
Discards the current contents of the MIME object and loads a new MIME message from a file.
Returns 1 for success, 0 for failure.
topLoadMimeSb
Discards the current contents of the MIME object and loads a new MIME message from a StringBuilder.
Returns 1 for success, 0 for failure.
LoadXml
Converts XML to MIME and replaces the MIME object's contents with the converted XML.
Returns 1 for success, 0 for failure.
topLoadXmlFile
Converts XML to MIME and replaces the MIME object's contents with the converted XML.
Returns 1 for success, 0 for failure.
topNewMessageRfc822
Clears the Mime object and initializes it such that the header contains a content-type: message/rfc822 line and the body is the MIME text of the Mime object passed to the method.
Returns 1 for success, 0 for failure.
topNewMultipartAlternative
Discards the current MIME message header fields and contents, if any, an initializes the MIME object to be an empty mulipart/alternative message.
Returns 1 for success, 0 for failure.
NewMultipartMixed
Discards the current MIME message header fields and contents, if any, an initializes the MIME object to be an empty mulipart/mixed message.
Returns 1 for success, 0 for failure.
NewMultipartRelated
Discards the current MIME message header fields and contents, if any, an initializes the MIME object to be an empty mulipart/related message.
Returns 1 for success, 0 for failure.
topPartAt
Returns the Nth sub-part in subPart, with indexing starting at 0.
Returns 1 for success, 0 for failure.
topPartsToFiles
The function recursively traverses a MIME message, extracting and saving parts that have a filename. It saves these parts to the directory specified by path. The filenames of the created files are returned in st. Filenames are derived from the filename attribute in the content-disposition header. Parts without a filename are not saved.
Returns 1 for success, 0 for failure.
topRemoveHeaderField
Removes a header field from the MIME header.  If bAllOccurrences is 1, then all occurrences of the header field are removed.  Otherwise, only the 1st occurrence is removed.
RemovePart
SaveBody
Saves the MIME message body to a file. If the body is base64 or quoted-printable encoded, it is automatically decoded.
Returns 1 for success, 0 for failure.
SaveMime
Saves the MIME message to a file, in MIME format. (This is the same as the .EML format used by Microsoft Outlook Express.)
Returns 1 for success, 0 for failure.
topSaveXml
SetBody
SetBodyBd
SetBodyFromEncoded
Sets the MIME message body from a Base64 or Quoted-Printable encoded string.
Returns 1 for success, 0 for failure.
topSetBodyFromFile
Sets the MIME message body from the contents of a file. Note: A MIME message consists of a header and a body. The body may itself be a MIME message that consists of a header and body, etc. This method loads the contents of a file into the body of a MIME message, without replacing the header.
The Content-Type and Content-Transfer-Encoding header fields are automatically updated to match the type of content loaded (based on file extension). If your application requires the MIME to have a specific Content-Type and/or Content-Transfer-Encoding, set the ContentType and Encoding properties after calling this method (not before).
Returns 1 for success, 0 for failure.
SetBodyFromHtml
Sets the MIME message body from a string containing HTML.  The Content-Type header is added or updated to the value text/html. 
 If 8bit (non-us-ascii) characters are present, and if the Charset property was not previously set, then the charset attribute is automatically added to the Content-Type header using the default value of utf-8.   This can be changed at any time by setting the Charset property.
If the Encoding property was not previously set, then the Content-Transfer-Encoding header is automatically added.  It will be set to 7bit or 8bit depending on whether the HTML body contains 8-bit non-us-ascii characters.
To set the MIME body with no intentional side-effects, use SetBody instead.
Returns 1 for success, 0 for failure.
SetBodyFromPlainText
Sets the MIME message body from a string containing plain-text.  The Content-Type header is added or updated to the value text/plain. 
 If 8bit (non-us-ascii) characters are present, and if the Charset property was not previously set, then the charset attribute is automatically added to the Content-Type header using the default value of utf-8.   This can be changed at any time by setting the Charset property.
If the Encoding property was not previously set, then the Content-Transfer-Encoding header is automatically added.  It will be set to 7bit or 8bit depending on whether the plain-text body contains 8-bit non-us-ascii characters.
To set the MIME body with no intentional side-effects, use SetBody instead.
Returns 1 for success, 0 for failure.
SetBodyFromXml
Sets the MIME message body from a string containing XML.  The Content-Type header is added or updated to the value text/xml. 
 If 8bit (non-us-ascii) characters are present, and if the Charset property was not previously set, then the charset attribute is automatically added to the Content-Type header using the default value of utf-8.   This can be changed at any time by setting the Charset property.
If the Encoding property was not previously set, then the Content-Transfer-Encoding header is automatically added.  It will be set to 7bit or 8bit depending on whether the plain-text body contains 8-bit non-us-ascii characters.
To set the MIME body with no intentional side-effects, use SetBody instead.
Returns 1 for success, 0 for failure.
SetHeaderField
Adds or replaces a MIME message header field. If the field already exists, it is automatically replaced. Otherwise it is added. Pass zero-length value to remove the header field.
Returns 1 for success, 0 for failure.
SetVerifyCert
Allows a certificate to be explicitly specified for verifying a signature.
Returns 1 for success, 0 for failure.
topUnwrapSecurity
Decrypts and/or verifies all digital signatures contained within the MIME message, and returns 1 if all decryptions and verifications succeeded. Otherwise returns 0. After unwrapping, the information regarding security and certificates can be obtained by the methods GetSignerCert and GetEncryptCert, and the properties NumEncryptCerts and NumSignerCerts.
The MIME is restored to the original structure/content prior to all signing and/or encryption.
The difference between UnwrapSecurity and methods such as Verify or Decrypt is that UnwrapSecurity will recursively traverse the MIME to decrypt and/or verify all parts.  Also, UnwrapSecurity will unwrap layers until no further encrypted/signed content is found.  For example, if a MIME message was encrypted and then subsequently signed, then UnwrapSecurity will verify and unwrap the detached signature/signed-data layer, and then decrypt the enveloped data.
Returns 1 for success, 0 for failure.
UrlEncodeBody
URL encodes the MIME body. The charset is important. For example, consider this MIME:
Content-Type: text/plain Content-Transfer-Encoding: 8bit SociétéIf the charset is set to
utf-8, then the following is produced:
Content-Type: text/plain Content-Transfer-Encoding: 8bit Soci%C3%A9t%C3%A9However, if the charset is set to
ansi, then the following is the result:
Content-Type: text/plain Content-Transfer-Encoding: 8bit Soci%E9t%E9top
UseCertVault
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.
topVerify
Verifies PKCS7 signed MIME and unwraps the signature.  The MIME is restored to the original structure that it would have originally had prior to signing.  The Verify method works with both detached signatures, as well as opaque/attached signatures.
A PKCS7 signature usually embeds both the signing certificate with its public key. Therefore, it is usually possible to verify a signature without the need to already have the certificate installed. If the signature does not embed the certificate, the Verify method will automatically locate and use the certificate if it was correctly pre-installed on the computer.
Returns 1 for success, 0 for failure.
Deprecated
NumEncryptCerts
This property is deprecated being renamed to NumDecryptCerts for consistency.  Please update your application to instead use NumDecryptCerts.
The number of certificates found when decrypting S/MIME.  This property is set after UnwrapSecurity is called.
ExtractPartsToFiles
Applications should instead call PartsToFiles.
The function recursively traverses a MIME message, extracting and saving parts that have a filename. It saves these parts to the directory specified by dirPath. It returns a StringArray containing the filenames of the created files. Filenames are derived from the filename attribute in the content-disposition header. Parts without a filename are not saved.
Returns 0 on failure
FindIssuer
This method is deprecated.  Applications can instead call the certificate object's GetIssuer method.
Finds and returns the issuer certificate. If the certificate is a root or self-issued, then the certificate returned is a copy of the caller certificate.
Returns 0 on failure
GetEncryptCert
This method is deprecated.  Applications should instead call LastDecryptCert.
Returns the Nth certificate found when decrypting. The EncryptCerts property contains the number of certificates.
Returns 0 on failure
GetPart
Applications should instead call PartAt.
Returns the Nth sub-part of the MIME, with indexing starting at 0.
Returns 0 on failure
GetSignerCert
This method is deprecated.  Applications should instead call LastSignerCert.
Returns the Nth digital certificate used to sign the MIME message. Indexing begins at 0.
Returns 0 on failure
GetSignerCertChain
This method is deprecated.  Applications can get the cert chain by calling NthSignerCert to get the certificate object, and then get the certificate chain from the certificate object.
Returns the full certificate chain for the Nth certificate used to sign the MIME message. Indexing begins at 0.
Returns 0 on failure
LastJsonData
This method is deprecated. Call GetLastJsonData instead.
Provides information about what transpired in the last method called on this object instance. For many methods, there is no information. However, for some methods, details about what occurred can be obtained by getting the LastJsonData right after the method call returns. For example, after calling UnwrapSecurity, the LastJsonData will return JSON with details about the algorithms used for signature verification and decryption.
Returns 0 on failure